@markuplint/selector
Advanced tools
Comparing version 3.0.0-dev.186 to 3.0.0-dev.290
@@ -1,2 +0,2 @@ | ||
import type { Specificity } from './types'; | ||
import type { Specificity } from './types.js'; | ||
export declare function compareSpecificity(a: Specificity, b: Specificity): 0 | 1 | -1; |
@@ -1,5 +0,2 @@ | ||
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.compareSpecificity = void 0; | ||
function compareSpecificity(a, b) { | ||
export function compareSpecificity(a, b) { | ||
if (a[0] < b[0]) { | ||
@@ -25,2 +22,1 @@ return -1; | ||
} | ||
exports.compareSpecificity = compareSpecificity; |
import type { MLMLSpec } from '@markuplint/ml-spec'; | ||
import { Selector } from './selector'; | ||
export declare function createSelector(selector: string, specs: MLMLSpec): Selector; | ||
import { Selector } from './selector.js'; | ||
export declare function createSelector(selector: string, specs?: MLMLSpec): Selector; |
@@ -1,10 +0,7 @@ | ||
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.createSelector = void 0; | ||
const aria_pseudo_class_1 = require("./extended-selector/aria-pseudo-class"); | ||
const aria_role_pseudo_class_1 = require("./extended-selector/aria-role-pseudo-class"); | ||
const content_model_pseudo_class_1 = require("./extended-selector/content-model-pseudo-class"); | ||
const selector_1 = require("./selector"); | ||
import { ariaPseudoClass } from './extended-selector/aria-pseudo-class.js'; | ||
import { ariaRolePseudoClass } from './extended-selector/aria-role-pseudo-class.js'; | ||
import { contentModelPseudoClass } from './extended-selector/content-model-pseudo-class.js'; | ||
import { Selector } from './selector.js'; | ||
const caches = new Map(); | ||
function createSelector(selector, specs) { | ||
export function createSelector(selector, specs) { | ||
let instance = caches.get(selector); | ||
@@ -14,10 +11,11 @@ if (instance) { | ||
} | ||
instance = new selector_1.Selector(selector, { | ||
model: (0, content_model_pseudo_class_1.contentModelPseudoClass)(specs), | ||
aria: (0, aria_pseudo_class_1.ariaPseudoClass)(), | ||
role: (0, aria_role_pseudo_class_1.ariaRolePseudoClass)(specs), | ||
}); | ||
instance = new Selector(selector, specs | ||
? { | ||
model: contentModelPseudoClass(specs), | ||
aria: ariaPseudoClass(), | ||
role: ariaRolePseudoClass(specs), | ||
} | ||
: undefined); | ||
caches.set(selector, instance); | ||
return instance; | ||
} | ||
exports.createSelector = createSelector; |
@@ -1,18 +0,13 @@ | ||
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.enableDebug = exports.log = void 0; | ||
const tslib_1 = require("tslib"); | ||
const debug_1 = tslib_1.__importDefault(require("debug")); | ||
import debug from 'debug'; | ||
const CLI_NS = 'markuplint-cli'; | ||
exports.log = (0, debug_1.default)('selector'); | ||
function enableDebug() { | ||
if (!exports.log.enabled) { | ||
debug_1.default.enable(`${exports.log.namespace}*`); | ||
(0, exports.log)(`Debug enable: ${exports.log.namespace}`); | ||
if (!debug_1.default.enabled(CLI_NS)) { | ||
debug_1.default.enable(`${exports.log.namespace}*,${CLI_NS}*`); | ||
(0, exports.log)(`Debug enable: ${exports.log.namespace}, ${CLI_NS}`); | ||
export const log = debug('selector'); | ||
export function enableDebug() { | ||
if (!log.enabled) { | ||
debug.enable(`${log.namespace}*`); | ||
log(`Debug enable: ${log.namespace}`); | ||
if (!debug.enabled(CLI_NS)) { | ||
debug.enable(`${log.namespace}*,${CLI_NS}*`); | ||
log(`Debug enable: ${log.namespace}, ${CLI_NS}`); | ||
} | ||
} | ||
} | ||
exports.enableDebug = enableDebug; |
@@ -1,2 +0,2 @@ | ||
import type { SelectorResult } from '../types'; | ||
import type { SelectorResult } from '../types.js'; | ||
/** | ||
@@ -3,0 +3,0 @@ * Version Syntax is not support yet. |
@@ -1,9 +0,6 @@ | ||
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.ariaPseudoClass = void 0; | ||
const ml_spec_1 = require("@markuplint/ml-spec"); | ||
import { validateAriaVersion, ARIA_RECOMMENDED_VERSION, getAccname } from '@markuplint/ml-spec'; | ||
/** | ||
* Version Syntax is not support yet. | ||
*/ | ||
function ariaPseudoClass() { | ||
export function ariaPseudoClass() { | ||
return (content) => ( | ||
@@ -13,3 +10,3 @@ // eslint-disable-next-line @typescript-eslint/prefer-readonly-parameter-types | ||
const aria = ariaPseudoClassParser(content); | ||
const name = (0, ml_spec_1.getAccname)(el); | ||
const name = getAccname(el); | ||
switch (aria.type) { | ||
@@ -47,8 +44,7 @@ case 'hasName': { | ||
} | ||
exports.ariaPseudoClass = ariaPseudoClass; | ||
function ariaPseudoClassParser(syntax) { | ||
const [_query, _version] = syntax.split('|'); | ||
const query = _query === null || _query === void 0 ? void 0 : _query.replace(/\s+/g, '').toLowerCase(); | ||
const version = _version !== null && _version !== void 0 ? _version : ml_spec_1.ARIA_RECOMMENDED_VERSION; | ||
if (!(0, ml_spec_1.validateAriaVersion)(version)) { | ||
const query = _query?.replace(/\s+/g, '').toLowerCase(); | ||
const version = _version ?? ARIA_RECOMMENDED_VERSION; | ||
if (!validateAriaVersion(version)) { | ||
throw new SyntaxError(`Unsupported ARIA version: ${version}`); | ||
@@ -55,0 +51,0 @@ } |
@@ -1,3 +0,3 @@ | ||
import type { SelectorResult } from '../types'; | ||
import type { SelectorResult } from '../types.js'; | ||
import type { MLMLSpec } from '@markuplint/ml-spec'; | ||
export declare function ariaRolePseudoClass(specs: MLMLSpec): (content: string) => (el: Element) => SelectorResult; |
@@ -1,13 +0,9 @@ | ||
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.ariaRolePseudoClass = void 0; | ||
const ml_spec_1 = require("@markuplint/ml-spec"); | ||
function ariaRolePseudoClass(specs) { | ||
import { validateAriaVersion, ARIA_RECOMMENDED_VERSION, getComputedRole } from '@markuplint/ml-spec'; | ||
export function ariaRolePseudoClass(specs) { | ||
return (content) => ( | ||
// eslint-disable-next-line @typescript-eslint/prefer-readonly-parameter-types | ||
el) => { | ||
var _a, _b; | ||
const aria = ariaPseudoClassParser(content); | ||
const computed = (0, ml_spec_1.getComputedRole)(specs, el, (_a = aria.version) !== null && _a !== void 0 ? _a : ml_spec_1.ARIA_RECOMMENDED_VERSION); | ||
if (((_b = computed.role) === null || _b === void 0 ? void 0 : _b.name) === aria.role) { | ||
const computed = getComputedRole(specs, el, aria.version ?? ARIA_RECOMMENDED_VERSION); | ||
if (computed.role?.name === aria.role) { | ||
return { | ||
@@ -26,14 +22,12 @@ specificity: [0, 1, 0], | ||
} | ||
exports.ariaRolePseudoClass = ariaRolePseudoClass; | ||
function ariaPseudoClassParser(syntax) { | ||
var _a; | ||
const [roleName, _version] = syntax.split('|'); | ||
const version = _version !== null && _version !== void 0 ? _version : ml_spec_1.ARIA_RECOMMENDED_VERSION; | ||
if (!(0, ml_spec_1.validateAriaVersion)(version)) { | ||
const version = _version ?? ARIA_RECOMMENDED_VERSION; | ||
if (!validateAriaVersion(version)) { | ||
throw new SyntaxError(`Unsupported ARIA version: ${version}`); | ||
} | ||
return { | ||
role: (_a = roleName === null || roleName === void 0 ? void 0 : roleName.trim().toLowerCase()) !== null && _a !== void 0 ? _a : syntax.trim().toLowerCase(), | ||
role: roleName?.trim().toLowerCase() ?? syntax.trim().toLowerCase(), | ||
version, | ||
}; | ||
} |
@@ -1,3 +0,3 @@ | ||
import type { SelectorResult } from '../types'; | ||
import type { SelectorResult } from '../types.js'; | ||
import type { MLMLSpec } from '@markuplint/ml-spec'; | ||
export declare function contentModelPseudoClass(specs: MLMLSpec): (category: string) => (el: Element) => SelectorResult; |
@@ -1,7 +0,4 @@ | ||
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.contentModelPseudoClass = void 0; | ||
const ml_spec_1 = require("@markuplint/ml-spec"); | ||
const create_selector_1 = require("../create-selector"); | ||
function contentModelPseudoClass(specs) { | ||
import { contentModelCategoryToTagNames } from '@markuplint/ml-spec'; | ||
import { createSelector } from '../create-selector.js'; | ||
export function contentModelPseudoClass(specs) { | ||
return (category) => ( | ||
@@ -11,3 +8,3 @@ // eslint-disable-next-line @typescript-eslint/prefer-readonly-parameter-types | ||
category = category.trim().toLowerCase(); | ||
const selectors = (0, ml_spec_1.contentModelCategoryToTagNames)(`#${category}`, specs.def); | ||
const selectors = contentModelCategoryToTagNames(`#${category}`, specs.def); | ||
const matched = selectors | ||
@@ -42,3 +39,3 @@ .map(selector => { | ||
} | ||
return (0, create_selector_1.createSelector)(selector, specs).search(el); | ||
return createSelector(selector, specs).search(el); | ||
}) | ||
@@ -61,2 +58,1 @@ .flat() | ||
} | ||
exports.contentModelPseudoClass = contentModelPseudoClass; |
@@ -1,4 +0,5 @@ | ||
export { compareSpecificity } from './compare-specificity'; | ||
export { matchSelector } from './match-selector'; | ||
export { createSelector } from './create-selector'; | ||
export * from './types'; | ||
export { compareSpecificity } from './compare-specificity.js'; | ||
export { matchSelector } from './match-selector.js'; | ||
export { createSelector } from './create-selector.js'; | ||
export { InvalidSelectorError } from './invalid-selector-error.js'; | ||
export * from './types.js'; |
@@ -1,11 +0,5 @@ | ||
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.createSelector = exports.matchSelector = exports.compareSpecificity = void 0; | ||
const tslib_1 = require("tslib"); | ||
var compare_specificity_1 = require("./compare-specificity"); | ||
Object.defineProperty(exports, "compareSpecificity", { enumerable: true, get: function () { return compare_specificity_1.compareSpecificity; } }); | ||
var match_selector_1 = require("./match-selector"); | ||
Object.defineProperty(exports, "matchSelector", { enumerable: true, get: function () { return match_selector_1.matchSelector; } }); | ||
var create_selector_1 = require("./create-selector"); | ||
Object.defineProperty(exports, "createSelector", { enumerable: true, get: function () { return create_selector_1.createSelector; } }); | ||
tslib_1.__exportStar(require("./types"), exports); | ||
export { compareSpecificity } from './compare-specificity.js'; | ||
export { matchSelector } from './match-selector.js'; | ||
export { createSelector } from './create-selector.js'; | ||
export { InvalidSelectorError } from './invalid-selector-error.js'; | ||
export * from './types.js'; |
export declare class InvalidSelectorError extends Error { | ||
name: string; | ||
name: string; | ||
selector: string; | ||
constructor(selector: string, message?: string); | ||
} |
@@ -1,10 +0,7 @@ | ||
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.InvalidSelectorError = void 0; | ||
class InvalidSelectorError extends Error { | ||
constructor() { | ||
super(...arguments); | ||
export class InvalidSelectorError extends Error { | ||
constructor(selector, message) { | ||
super(message ?? `Invalid selector: "${selector}"`); | ||
this.name = 'InvalidSelectorError'; | ||
this.selector = selector; | ||
} | ||
} | ||
exports.InvalidSelectorError = InvalidSelectorError; |
@@ -1,5 +0,2 @@ | ||
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.isPureHTMLElement = exports.isNonDocumentTypeChildNode = exports.isElement = void 0; | ||
function isElement( | ||
export function isElement( | ||
// eslint-disable-next-line @typescript-eslint/prefer-readonly-parameter-types | ||
@@ -9,4 +6,3 @@ node) { | ||
} | ||
exports.isElement = isElement; | ||
function isNonDocumentTypeChildNode( | ||
export function isNonDocumentTypeChildNode( | ||
// eslint-disable-next-line @typescript-eslint/prefer-readonly-parameter-types | ||
@@ -16,4 +12,3 @@ node) { | ||
} | ||
exports.isNonDocumentTypeChildNode = isNonDocumentTypeChildNode; | ||
function isPureHTMLElement( | ||
export function isPureHTMLElement( | ||
// eslint-disable-next-line @typescript-eslint/prefer-readonly-parameter-types | ||
@@ -23,2 +18,1 @@ el) { | ||
} | ||
exports.isPureHTMLElement = isPureHTMLElement; |
@@ -1,13 +0,13 @@ | ||
import type { Specificity, RegexSelector } from './types'; | ||
import type { Specificity, RegexSelector } from './types.js'; | ||
export type SelectorMatches = SelectorMatched | SelectorUnmatched; | ||
type SelectorMatched = { | ||
readonly matched: true; | ||
readonly selector: string; | ||
readonly specificity: Specificity; | ||
readonly data?: Readonly<Record<string, string>>; | ||
readonly matched: true; | ||
readonly selector: string; | ||
readonly specificity: Specificity; | ||
readonly data?: Readonly<Record<string, string>>; | ||
}; | ||
type SelectorUnmatched = { | ||
readonly matched: false; | ||
readonly matched: false; | ||
}; | ||
export declare function matchSelector(el: Node, selector: string | RegexSelector | undefined): SelectorMatches; | ||
export {}; |
@@ -1,10 +0,7 @@ | ||
"use strict"; | ||
var _SelectorTarget_combinedFrom, _SelectorTarget_selector; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.matchSelector = void 0; | ||
const tslib_1 = require("tslib"); | ||
const is_1 = require("./is"); | ||
const regex_selector_matches_1 = require("./regex-selector-matches"); | ||
const selector_1 = require("./selector"); | ||
function matchSelector( | ||
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib"; | ||
import { isElement, isNonDocumentTypeChildNode, isPureHTMLElement } from './is.js'; | ||
import { regexSelectorMatches } from './regex-selector-matches.js'; | ||
import { Selector } from './selector.js'; | ||
export function matchSelector( | ||
// eslint-disable-next-line @typescript-eslint/prefer-readonly-parameter-types | ||
@@ -18,3 +15,3 @@ el, selector) { | ||
if (typeof selector === 'string') { | ||
const sel = new selector_1.Selector(selector); | ||
const sel = new Selector(selector); | ||
const specificity = sel.match(el); | ||
@@ -34,3 +31,2 @@ if (specificity !== false) { | ||
} | ||
exports.matchSelector = matchSelector; | ||
function regexSelect( | ||
@@ -53,6 +49,6 @@ // eslint-disable-next-line @typescript-eslint/prefer-readonly-parameter-types | ||
_SelectorTarget_selector.set(this, void 0); | ||
tslib_1.__classPrivateFieldSet(this, _SelectorTarget_selector, selector, "f"); | ||
__classPrivateFieldSet(this, _SelectorTarget_selector, selector, "f"); | ||
} | ||
from(target, combinator) { | ||
tslib_1.__classPrivateFieldSet(this, _SelectorTarget_combinedFrom, { target, combinator }, "f"); | ||
__classPrivateFieldSet(this, _SelectorTarget_combinedFrom, { target, combinator }, "f"); | ||
} | ||
@@ -66,9 +62,9 @@ match( | ||
} | ||
if (!tslib_1.__classPrivateFieldGet(this, _SelectorTarget_combinedFrom, "f")) { | ||
if (!__classPrivateFieldGet(this, _SelectorTarget_combinedFrom, "f")) { | ||
return unitCheck; | ||
} | ||
if (!(0, is_1.isNonDocumentTypeChildNode)(el)) { | ||
if (!isNonDocumentTypeChildNode(el)) { | ||
return unitCheck; | ||
} | ||
const { target, combinator } = tslib_1.__classPrivateFieldGet(this, _SelectorTarget_combinedFrom, "f"); | ||
const { target, combinator } = __classPrivateFieldGet(this, _SelectorTarget_combinedFrom, "f"); | ||
switch (combinator) { | ||
@@ -148,3 +144,3 @@ // Descendant combinator | ||
default: { | ||
throw new Error(`Unsupported ${tslib_1.__classPrivateFieldGet(this, _SelectorTarget_combinedFrom, "f").combinator} combinator in selector`); | ||
throw new Error(`Unsupported ${__classPrivateFieldGet(this, _SelectorTarget_combinedFrom, "f").combinator} combinator in selector`); | ||
} | ||
@@ -156,3 +152,3 @@ } | ||
el) { | ||
return uncombinedRegexSelect(el, tslib_1.__classPrivateFieldGet(this, _SelectorTarget_selector, "f")); | ||
return uncombinedRegexSelect(el, __classPrivateFieldGet(this, _SelectorTarget_selector, "f")); | ||
} | ||
@@ -164,3 +160,3 @@ } | ||
el, selector) { | ||
if (!(0, is_1.isElement)(el)) { | ||
if (!isElement(el)) { | ||
return { | ||
@@ -176,3 +172,3 @@ matched: false, | ||
if (selector.nodeName) { | ||
const matchedNodeName = (0, regex_selector_matches_1.regexSelectorMatches)(selector.nodeName, el.localName, (0, is_1.isPureHTMLElement)(el)); | ||
const matchedNodeName = regexSelectorMatches(selector.nodeName, el.localName, isPureHTMLElement(el)); | ||
if (matchedNodeName) { | ||
@@ -195,3 +191,3 @@ delete matchedNodeName.$0; | ||
const attrName = attr.name; | ||
const matchedAttrName = (0, regex_selector_matches_1.regexSelectorMatches)(selectorAttrName, attrName, (0, is_1.isPureHTMLElement)(el)); | ||
const matchedAttrName = regexSelectorMatches(selectorAttrName, attrName, isPureHTMLElement(el)); | ||
if (matchedAttrName) { | ||
@@ -216,3 +212,3 @@ delete matchedAttrName.$0; | ||
const attrValue = attr.value; | ||
const matchedAttrValue = (0, regex_selector_matches_1.regexSelectorMatches)(selectorAttrValue, attrValue, (0, is_1.isPureHTMLElement)(el)); | ||
const matchedAttrValue = regexSelectorMatches(selectorAttrValue, attrValue, isPureHTMLElement(el)); | ||
if (matchedAttrValue) { | ||
@@ -219,0 +215,0 @@ delete matchedAttrValue.$0; |
@@ -1,7 +0,3 @@ | ||
export declare function regexSelectorMatches( | ||
reg: string, | ||
raw: string, | ||
ignoreCase: boolean, | ||
): { | ||
[x: string]: string; | ||
export declare function regexSelectorMatches(reg: string, raw: string, ignoreCase: boolean): { | ||
[x: string]: string; | ||
} | null; |
@@ -1,5 +0,2 @@ | ||
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.regexSelectorMatches = void 0; | ||
function regexSelectorMatches(reg, raw, ignoreCase) { | ||
export function regexSelectorMatches(reg, raw, ignoreCase) { | ||
const res = {}; | ||
@@ -18,3 +15,2 @@ const pattern = toRegexp(reg); | ||
} | ||
exports.regexSelectorMatches = regexSelectorMatches; | ||
function toRegexp(pattern) { | ||
@@ -21,0 +17,0 @@ const matched = pattern.match(/^\/(.+)\/([ig]*)$/i); |
@@ -1,9 +0,9 @@ | ||
import type { SelectorResult, Specificity } from './types'; | ||
import type { SelectorResult, Specificity } from './types.js'; | ||
type ExtendedPseudoClass = Readonly<Record<string, (content: string) => (el: Element) => SelectorResult>>; | ||
export declare class Selector { | ||
#private; | ||
constructor(selector: string, extended?: ExtendedPseudoClass); | ||
match(el: Node, scope?: ParentNode | null): Specificity | false; | ||
search(el: Node, scope?: ParentNode | null): SelectorResult[]; | ||
#private; | ||
constructor(selector: string, extended?: ExtendedPseudoClass); | ||
match(el: Node, scope?: ParentNode | null): Specificity | false; | ||
search(el: Node, scope?: ParentNode | null): SelectorResult[]; | ||
} | ||
export {}; |
@@ -1,18 +0,15 @@ | ||
"use strict"; | ||
var _Selector_ruleset, _Ruleset_selectorGroup, _StructuredSelector_edge, _StructuredSelector_selector, _SelectorTarget_combinedFrom, _SelectorTarget_extended, _SelectorTarget_isAdded; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.Selector = void 0; | ||
const tslib_1 = require("tslib"); | ||
const ml_spec_1 = require("@markuplint/ml-spec"); | ||
const postcss_selector_parser_1 = tslib_1.__importStar(require("postcss-selector-parser")); | ||
const compare_specificity_1 = require("./compare-specificity"); | ||
const debug_1 = require("./debug"); | ||
const invalid_selector_error_1 = require("./invalid-selector-error"); | ||
const is_1 = require("./is"); | ||
const selLog = debug_1.log.extend('selector'); | ||
const resLog = debug_1.log.extend('result'); | ||
class Selector { | ||
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib"; | ||
import { resolveNamespace } from '@markuplint/ml-spec'; | ||
import parser from 'postcss-selector-parser'; | ||
import { compareSpecificity } from './compare-specificity.js'; | ||
import { log as coreLog } from './debug.js'; | ||
import { InvalidSelectorError } from './invalid-selector-error.js'; | ||
import { isElement, isNonDocumentTypeChildNode, isPureHTMLElement } from './is.js'; | ||
const selLog = coreLog.extend('selector'); | ||
const resLog = coreLog.extend('result'); | ||
export class Selector { | ||
constructor(selector, extended = {}) { | ||
_Selector_ruleset.set(this, void 0); | ||
tslib_1.__classPrivateFieldSet(this, _Selector_ruleset, Ruleset.parse(selector, extended), "f"); | ||
__classPrivateFieldSet(this, _Selector_ruleset, Ruleset.parse(selector, extended), "f"); | ||
} | ||
@@ -24,3 +21,3 @@ match( | ||
scope) { | ||
scope = (0, is_1.isElement)(el) ? el : null; | ||
scope = isElement(el) ? el : null; | ||
const results = this.search(el, scope); | ||
@@ -39,7 +36,6 @@ for (const result of results) { | ||
scope) { | ||
scope = (0, is_1.isElement)(el) ? el : null; | ||
return tslib_1.__classPrivateFieldGet(this, _Selector_ruleset, "f").match(el, scope); | ||
scope = isElement(el) ? el : null; | ||
return __classPrivateFieldGet(this, _Selector_ruleset, "f").match(el, scope); | ||
} | ||
} | ||
exports.Selector = Selector; | ||
_Selector_ruleset = new WeakMap(); | ||
@@ -50,3 +46,3 @@ class Ruleset { | ||
try { | ||
(0, postcss_selector_parser_1.default)(root => { | ||
parser(root => { | ||
selectors.push(...root.nodes); | ||
@@ -57,3 +53,3 @@ }).processSync(selector); | ||
if (e instanceof Error) { | ||
throw new Error(`${e.message} At the selector: "${selector}"`); | ||
throw new InvalidSelectorError(selector); | ||
} | ||
@@ -65,10 +61,12 @@ throw e; | ||
constructor(selectors, extended, depth) { | ||
var _a, _b; | ||
_Ruleset_selectorGroup.set(this, []); | ||
tslib_1.__classPrivateFieldGet(this, _Ruleset_selectorGroup, "f").push(...selectors.map(selector => new StructuredSelector(selector, depth, extended))); | ||
const head = tslib_1.__classPrivateFieldGet(this, _Ruleset_selectorGroup, "f")[0]; | ||
this.headCombinator = (_a = head === null || head === void 0 ? void 0 : head.headCombinator) !== null && _a !== void 0 ? _a : null; | ||
__classPrivateFieldGet(this, _Ruleset_selectorGroup, "f").push(...selectors.map(selector => new StructuredSelector(selector, depth, extended))); | ||
const head = __classPrivateFieldGet(this, _Ruleset_selectorGroup, "f")[0]; | ||
this.headCombinator = head?.headCombinator ?? null; | ||
if (this.headCombinator) { | ||
if (depth <= 0) { | ||
throw new invalid_selector_error_1.InvalidSelectorError(`'${(_b = tslib_1.__classPrivateFieldGet(this, _Ruleset_selectorGroup, "f")[0]) === null || _b === void 0 ? void 0 : _b.selector}' is not a valid selector`); | ||
if (__classPrivateFieldGet(this, _Ruleset_selectorGroup, "f")[0]?.selector) { | ||
throw new InvalidSelectorError(__classPrivateFieldGet(this, _Ruleset_selectorGroup, "f")[0]?.selector); | ||
} | ||
throw new Error('Combinated selector depth is not expected'); | ||
} | ||
@@ -82,7 +80,7 @@ } | ||
scope) { | ||
(0, debug_1.log)('<%s> (%s)', (0, is_1.isElement)(el) ? el.localName : el.nodeName, scope ? ((0, is_1.isElement)(scope) ? scope.localName : scope.nodeName) : null); | ||
return tslib_1.__classPrivateFieldGet(this, _Ruleset_selectorGroup, "f").map(selector => { | ||
coreLog('<%s> (%s)', isElement(el) ? el.localName : el.nodeName, scope ? (isElement(scope) ? scope.localName : scope.nodeName) : null); | ||
return __classPrivateFieldGet(this, _Ruleset_selectorGroup, "f").map(selector => { | ||
selLog('"%s"', selector.selector); | ||
const res = selector.match(el, scope); | ||
resLog('%s "%s" => %o', (0, is_1.isElement)(el) ? el.localName : el.nodeName, selector.selector, res); | ||
resLog('%s "%s" => %o', isElement(el) ? el.localName : el.nodeName, selector.selector, res); | ||
return res; | ||
@@ -95,12 +93,12 @@ }); | ||
constructor(selector, depth, extended) { | ||
var _a, _b; | ||
_StructuredSelector_edge.set(this, void 0); | ||
_StructuredSelector_selector.set(this, void 0); | ||
tslib_1.__classPrivateFieldSet(this, _StructuredSelector_selector, selector, "f"); | ||
tslib_1.__classPrivateFieldSet(this, _StructuredSelector_edge, new SelectorTarget(extended, depth), "f"); | ||
__classPrivateFieldSet(this, _StructuredSelector_selector, selector, "f"); | ||
__classPrivateFieldSet(this, _StructuredSelector_edge, new SelectorTarget(extended, depth), "f"); | ||
this.headCombinator = | ||
((_a = tslib_1.__classPrivateFieldGet(this, _StructuredSelector_selector, "f").nodes[0]) === null || _a === void 0 ? void 0 : _a.type) === 'combinator' ? (_b = tslib_1.__classPrivateFieldGet(this, _StructuredSelector_selector, "f").nodes[0].value) !== null && _b !== void 0 ? _b : null : null; | ||
const nodes = tslib_1.__classPrivateFieldGet(this, _StructuredSelector_selector, "f").nodes.slice(); | ||
__classPrivateFieldGet(this, _StructuredSelector_selector, "f").nodes[0]?.type === 'combinator' ? __classPrivateFieldGet(this, _StructuredSelector_selector, "f").nodes[0].value ?? null : null; | ||
const nodes = __classPrivateFieldGet(this, _StructuredSelector_selector, "f").nodes.slice(); | ||
if (0 < depth && this.headCombinator) { | ||
nodes.unshift((0, postcss_selector_parser_1.pseudo)({ value: ':scope' })); | ||
// eslint-disable-next-line import/no-named-as-default-member | ||
nodes.unshift(parser.pseudo({ value: ':scope' })); | ||
} | ||
@@ -111,4 +109,4 @@ nodes.forEach(node => { | ||
const combinedTarget = new SelectorTarget(extended, depth); | ||
combinedTarget.from(tslib_1.__classPrivateFieldGet(this, _StructuredSelector_edge, "f"), node); | ||
tslib_1.__classPrivateFieldSet(this, _StructuredSelector_edge, combinedTarget, "f"); | ||
combinedTarget.from(__classPrivateFieldGet(this, _StructuredSelector_edge, "f"), node); | ||
__classPrivateFieldSet(this, _StructuredSelector_edge, combinedTarget, "f"); | ||
break; | ||
@@ -127,3 +125,3 @@ } | ||
default: { | ||
tslib_1.__classPrivateFieldGet(this, _StructuredSelector_edge, "f").add(node); | ||
__classPrivateFieldGet(this, _StructuredSelector_edge, "f").add(node); | ||
} | ||
@@ -134,3 +132,3 @@ } | ||
get selector() { | ||
return tslib_1.__classPrivateFieldGet(this, _StructuredSelector_selector, "f").nodes.join(''); | ||
return __classPrivateFieldGet(this, _StructuredSelector_selector, "f").nodes.join(''); | ||
} | ||
@@ -142,3 +140,3 @@ match( | ||
scope) { | ||
return tslib_1.__classPrivateFieldGet(this, _StructuredSelector_edge, "f").match(el, scope, 0); | ||
return __classPrivateFieldGet(this, _StructuredSelector_edge, "f").match(el, scope, 0); | ||
} | ||
@@ -157,7 +155,7 @@ } | ||
this.tag = null; | ||
tslib_1.__classPrivateFieldSet(this, _SelectorTarget_extended, extended, "f"); | ||
__classPrivateFieldSet(this, _SelectorTarget_extended, extended, "f"); | ||
this.depth = depth; | ||
} | ||
add(selector) { | ||
tslib_1.__classPrivateFieldSet(this, _SelectorTarget_isAdded, true, "f"); | ||
__classPrivateFieldSet(this, _SelectorTarget_isAdded, true, "f"); | ||
switch (selector.type) { | ||
@@ -188,3 +186,3 @@ case 'tag': | ||
from(target, combinator) { | ||
tslib_1.__classPrivateFieldSet(this, _SelectorTarget_combinedFrom, { target, combinator }, "f"); | ||
__classPrivateFieldSet(this, _SelectorTarget_combinedFrom, { target, combinator }, "f"); | ||
} | ||
@@ -196,11 +194,10 @@ match( | ||
scope, count) { | ||
var _a, _b, _c; | ||
const result = this._match(el, scope, count); | ||
if (selLog.enabled) { | ||
const nodeName = el.nodeName; | ||
const selector = (_b = (_a = tslib_1.__classPrivateFieldGet(this, _SelectorTarget_combinedFrom, "f")) === null || _a === void 0 ? void 0 : _a.target.toString()) !== null && _b !== void 0 ? _b : this.toString(); | ||
const selector = __classPrivateFieldGet(this, _SelectorTarget_combinedFrom, "f")?.target.toString() ?? this.toString(); | ||
const combinator = result.combinator ? ` ${result.combinator}` : ''; | ||
selLog('The %s element by "%s" => %s (%d)', nodeName, `${selector}${combinator}`, result.matched, count); | ||
if (selector === ':scope') { | ||
selLog(`† Scope is the ${(_c = scope === null || scope === void 0 ? void 0 : scope.nodeName) !== null && _c !== void 0 ? _c : null}`); | ||
selLog(`† Scope is the ${scope?.nodeName ?? null}`); | ||
} | ||
@@ -212,5 +209,4 @@ } | ||
toString() { | ||
var _a, _b; | ||
return [ | ||
(_b = (_a = this.tag) === null || _a === void 0 ? void 0 : _a.toString()) !== null && _b !== void 0 ? _b : '', | ||
this.tag?.toString() ?? '', | ||
this.id.map(id => `#${id.value}`).join(''), | ||
@@ -231,9 +227,9 @@ this.class.map(c => `.${c.value}`).join(''), | ||
} | ||
if (!tslib_1.__classPrivateFieldGet(this, _SelectorTarget_combinedFrom, "f")) { | ||
if (!__classPrivateFieldGet(this, _SelectorTarget_combinedFrom, "f")) { | ||
return unitCheck; | ||
} | ||
if (!(0, is_1.isNonDocumentTypeChildNode)(el)) { | ||
if (!isNonDocumentTypeChildNode(el)) { | ||
return unitCheck; | ||
} | ||
const { target, combinator } = tslib_1.__classPrivateFieldGet(this, _SelectorTarget_combinedFrom, "f"); | ||
const { target, combinator } = __classPrivateFieldGet(this, _SelectorTarget_combinedFrom, "f"); | ||
switch (combinator.value) { | ||
@@ -246,3 +242,3 @@ // Descendant combinator | ||
let ancestor = el.parentElement; | ||
let specificity; | ||
let specificity = undefined; | ||
while (ancestor) { | ||
@@ -385,3 +381,3 @@ const res = target.match(ancestor, scope, count + 1); | ||
let prev = el.previousElementSibling; | ||
let specificity; | ||
let specificity = undefined; | ||
while (prev) { | ||
@@ -436,3 +432,3 @@ const res = target.match(prev, scope, count + 1); | ||
default: { | ||
throw new Error(`Unsupported ${tslib_1.__classPrivateFieldGet(this, _SelectorTarget_combinedFrom, "f").combinator.value} combinator in selector`); | ||
throw new Error(`Unsupported ${__classPrivateFieldGet(this, _SelectorTarget_combinedFrom, "f").combinator.value} combinator in selector`); | ||
} | ||
@@ -446,5 +442,4 @@ } | ||
scope) { | ||
var _a; | ||
const specificity = [0, 0, 0]; | ||
if (!(0, is_1.isElement)(el)) { | ||
if (!isElement(el)) { | ||
return { | ||
@@ -476,3 +471,3 @@ specificity, | ||
default: { | ||
throw new invalid_selector_error_1.InvalidSelectorError(`The ${namespace} namespace is not supported`); | ||
throw new InvalidSelectorError(`The ${namespace} namespace is not supported`); | ||
} | ||
@@ -482,3 +477,3 @@ } | ||
let matched = true; | ||
if (!tslib_1.__classPrivateFieldGet(this, _SelectorTarget_isAdded, "f") && !isScope(el, scope)) { | ||
if (!__classPrivateFieldGet(this, _SelectorTarget_isAdded, "f") && !isScope(el, scope)) { | ||
matched = false; | ||
@@ -499,3 +494,3 @@ } | ||
for (const pseudo of this.pseudo) { | ||
const pseudoRes = pseudoMatch(pseudo, el, scope, tslib_1.__classPrivateFieldGet(this, _SelectorTarget_extended, "f"), this.depth); | ||
const pseudoRes = pseudoMatch(pseudo, el, scope, __classPrivateFieldGet(this, _SelectorTarget_extended, "f"), this.depth); | ||
specificity[0] += pseudoRes.specificity[0]; | ||
@@ -508,3 +503,3 @@ specificity[1] += pseudoRes.specificity[1]; | ||
else { | ||
not.push(...((_a = pseudoRes.not) !== null && _a !== void 0 ? _a : [])); | ||
not.push(...(pseudoRes.not ?? [])); | ||
matched = false; | ||
@@ -517,3 +512,3 @@ } | ||
let b = el.localName; | ||
if ((0, is_1.isPureHTMLElement)(el)) { | ||
if (isPureHTMLElement(el)) { | ||
a = a.toLowerCase(); | ||
@@ -550,3 +545,3 @@ b = b.toLowerCase(); | ||
if (attr.namespace != null && attr.namespace !== true && attr.namespace !== '*') { | ||
const ns = (0, ml_spec_1.resolveNamespace)(attrOfEl.localName, attrOfEl.namespaceURI); | ||
const ns = resolveNamespace(attrOfEl.localName, attrOfEl.namespaceURI); | ||
if (attr.namespace !== ns.namespace) { | ||
@@ -821,4 +816,3 @@ return false; | ||
scope) { | ||
var _a; | ||
return (_a = el === scope) !== null && _a !== void 0 ? _a : el.parentNode === null; | ||
return el === scope ?? el.parentNode === null; | ||
} | ||
@@ -838,4 +832,3 @@ function getDescendants( | ||
el) { | ||
var _a, _b; | ||
return Array.from((_b = (_a = el.parentElement) === null || _a === void 0 ? void 0 : _a.children) !== null && _b !== void 0 ? _b : []); | ||
return Array.from(el.parentElement?.children ?? []); | ||
} | ||
@@ -845,6 +838,6 @@ function getSpecificity( | ||
results) { | ||
let specificity; | ||
let specificity = undefined; | ||
for (const result of results) { | ||
if (specificity) { | ||
const order = (0, compare_specificity_1.compareSpecificity)(specificity, result.specificity); | ||
const order = compareSpecificity(specificity, result.specificity); | ||
if (order === -1) { | ||
@@ -851,0 +844,0 @@ specificity = result.specificity; |
export type Specificity = readonly [number, number, number]; | ||
export type SelectorResult = SelectorMatchedResult | SelectorUnmatchedResult; | ||
export type SelectorMatchedResult = { | ||
readonly specificity: Specificity; | ||
readonly matched: true; | ||
readonly nodes: readonly (Element | Text)[]; | ||
readonly has: readonly SelectorMatchedResult[]; | ||
readonly specificity: Specificity; | ||
readonly matched: true; | ||
readonly nodes: readonly (Element | Text)[]; | ||
readonly has: readonly SelectorMatchedResult[]; | ||
}; | ||
export type SelectorUnmatchedResult = { | ||
readonly specificity: Specificity; | ||
readonly matched: false; | ||
readonly not?: readonly SelectorMatchedResult[]; | ||
readonly specificity: Specificity; | ||
readonly matched: false; | ||
readonly not?: readonly SelectorMatchedResult[]; | ||
}; | ||
export type RegexSelector = RegexSelectorWithoutCombination & { | ||
readonly combination?: { | ||
readonly combinator: RegexSelectorCombinator; | ||
} & RegexSelector; | ||
readonly combination?: { | ||
readonly combinator: RegexSelectorCombinator; | ||
} & RegexSelector; | ||
}; | ||
export type RegexSelectorCombinator = ' ' | '>' | '+' | '~' | ':has(+)' | ':has(~)'; | ||
export type RegexSelectorWithoutCombination = { | ||
readonly nodeName?: string; | ||
readonly attrName?: string; | ||
readonly attrValue?: string; | ||
readonly nodeName?: string; | ||
readonly attrName?: string; | ||
readonly attrValue?: string; | ||
}; |
@@ -1,2 +0,1 @@ | ||
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
export {}; |
{ | ||
"name": "@markuplint/selector", | ||
"version": "3.0.0-dev.186+37ceba57", | ||
"version": "3.0.0-dev.290+af676442", | ||
"description": "Extended W3C Selectors matcher", | ||
@@ -9,3 +9,8 @@ "repository": "git@github.com:markuplint/markuplint.git", | ||
"private": false, | ||
"main": "lib/index.js", | ||
"type": "module", | ||
"exports": { | ||
".": { | ||
"import": "./lib/index.js" | ||
} | ||
}, | ||
"types": "lib/index.d.ts", | ||
@@ -24,14 +29,14 @@ "publishConfig": { | ||
"dependencies": { | ||
"@markuplint/ml-spec": "3.0.0-dev.186+37ceba57", | ||
"@types/debug": "^4.1.7", | ||
"@markuplint/ml-spec": "3.0.0-dev.290+af676442", | ||
"@types/debug": "^4.1.9", | ||
"debug": "^4.3.4", | ||
"postcss-selector-parser": "^6.0.11", | ||
"tslib": "^2.4.1", | ||
"type-fest": "^3.8.0" | ||
"postcss-selector-parser": "^6.0.13", | ||
"tslib": "^2.6.2", | ||
"type-fest": "^4.3.1" | ||
}, | ||
"devDependencies": { | ||
"@types/jsdom": "21.1.1", | ||
"jsdom": "21.1.1" | ||
"@types/jsdom": "21.1.3", | ||
"jsdom": "22.1.0" | ||
}, | ||
"gitHead": "37ceba578aff49e0326c5e374cef3da6be303b25" | ||
"gitHead": "af6764422feecb56d1d84659028f53daf685bb78" | ||
} |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Manifest confusion
Supply chain riskThis package has inconsistent metadata. This could be malicious or caused by an error when publishing the package.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Manifest confusion
Supply chain riskThis package has inconsistent metadata. This could be malicious or caused by an error when publishing the package.
Found 1 instance in 1 package
Yes
2
41
63546
29
1410
+ Addedtype-fest@4.30.2(transitive)
- Removedtype-fest@3.13.1(transitive)
Updated@types/debug@^4.1.9
Updatedtslib@^2.6.2
Updatedtype-fest@^4.3.1