Files
dealplustech/node_modules/hast-util-parse-selector/lib/index.d.ts
Kunthawat 77ac4d2d05 feat: Upgrade to Astro with full PDPA compliance
PDPA Features:
 Cookie consent banner
 Consent logging API
 Admin dashboard
 Privacy Policy
 Terms & Conditions

Technical:
 Astro 5.x + Tailwind v4
 Docker on port 80
 SQLite database
 15 pages built

Ready for Easypanel deployment.
2026-03-12 10:01:04 +07:00

28 lines
1.5 KiB
TypeScript

/**
* Create a hast element from a simple CSS selector.
*
* @template {string} Selector
* Type of selector.
* @template {string} [DefaultTagName='div']
* Type of default tag name (default: `'div'`).
* @param {Selector | null | undefined} [selector]
* Simple CSS selector (optional).
*
* Can contain a tag name (`foo`), classes (`.bar`), and an ID (`#baz`).
* Multiple classes are allowed.
* Uses the last ID if multiple IDs are found.
* @param {DefaultTagName | null | undefined} [defaultTagName='div']
* Tag name to use if `selector` does not specify one (default: `'div'`).
* @returns {Element & {tagName: ExtractTagName<Selector, DefaultTagName>}}
* Built element.
*/
export function parseSelector<Selector extends string, DefaultTagName extends string = "div">(selector?: Selector | null | undefined, defaultTagName?: DefaultTagName | null | undefined): import("hast").Element & {
tagName: ExtractTagName<Selector, DefaultTagName>;
};
export type Element = import('hast').Element;
export type Properties = import('hast').Properties;
/**
* Extract tag name from a simple selector.
*/
export type ExtractTagName<SimpleSelector extends string, DefaultTagName extends string> = SimpleSelector extends "" ? DefaultTagName : SimpleSelector extends `${infer TagName}.${infer Rest}` ? ExtractTagName<TagName, DefaultTagName> : SimpleSelector extends `${infer TagName_1}#${infer Rest_1}` ? ExtractTagName<TagName_1, DefaultTagName> : SimpleSelector extends string ? SimpleSelector : DefaultTagName;