|
|
declare namespace postcssValueParser {
|
|
|
interface BaseNode {
|
|
|
/**
|
|
|
* The offset, inclusive, inside the CSS value at which the node starts.
|
|
|
*/
|
|
|
sourceIndex: number;
|
|
|
|
|
|
/**
|
|
|
* The offset, exclusive, inside the CSS value at which the node ends.
|
|
|
*/
|
|
|
sourceEndIndex: number;
|
|
|
|
|
|
/**
|
|
|
* The node's characteristic value
|
|
|
*/
|
|
|
value: string;
|
|
|
}
|
|
|
|
|
|
interface ClosableNode {
|
|
|
/**
|
|
|
* Whether the parsed CSS value ended before the node was properly closed
|
|
|
*/
|
|
|
unclosed?: true;
|
|
|
}
|
|
|
|
|
|
interface AdjacentAwareNode {
|
|
|
/**
|
|
|
* The token at the start of the node
|
|
|
*/
|
|
|
before: string;
|
|
|
|
|
|
/**
|
|
|
* The token at the end of the node
|
|
|
*/
|
|
|
after: string;
|
|
|
}
|
|
|
|
|
|
interface CommentNode extends BaseNode, ClosableNode {
|
|
|
type: "comment";
|
|
|
}
|
|
|
|
|
|
interface DivNode extends BaseNode, AdjacentAwareNode {
|
|
|
type: "div";
|
|
|
}
|
|
|
|
|
|
interface FunctionNode extends BaseNode, ClosableNode, AdjacentAwareNode {
|
|
|
type: "function";
|
|
|
|
|
|
/**
|
|
|
* Nodes inside the function
|
|
|
*/
|
|
|
nodes: Node[];
|
|
|
}
|
|
|
|
|
|
interface SpaceNode extends BaseNode {
|
|
|
type: "space";
|
|
|
}
|
|
|
|
|
|
interface StringNode extends BaseNode, ClosableNode {
|
|
|
type: "string";
|
|
|
|
|
|
/**
|
|
|
* The quote type delimiting the string
|
|
|
*/
|
|
|
quote: '"' | "'";
|
|
|
}
|
|
|
|
|
|
interface UnicodeRangeNode extends BaseNode {
|
|
|
type: "unicode-range";
|
|
|
}
|
|
|
|
|
|
interface WordNode extends BaseNode {
|
|
|
type: "word";
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* Any node parsed from a CSS value
|
|
|
*/
|
|
|
type Node =
|
|
|
| CommentNode
|
|
|
| DivNode
|
|
|
| FunctionNode
|
|
|
| SpaceNode
|
|
|
| StringNode
|
|
|
| UnicodeRangeNode
|
|
|
| WordNode;
|
|
|
|
|
|
interface CustomStringifierCallback {
|
|
|
/**
|
|
|
* @param node The node to stringify
|
|
|
* @returns The serialized CSS representation of the node
|
|
|
*/
|
|
|
(nodes: Node): string | undefined;
|
|
|
}
|
|
|
|
|
|
interface WalkCallback {
|
|
|
/**
|
|
|
* @param node The currently visited node
|
|
|
* @param index The index of the node in the series of parsed nodes
|
|
|
* @param nodes The series of parsed nodes
|
|
|
* @returns Returning `false` will prevent traversal of descendant nodes (only applies if `bubble` was set to `true` in the `walk()` call)
|
|
|
*/
|
|
|
(node: Node, index: number, nodes: Node[]): void | boolean;
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* A CSS dimension, decomposed into its numeric and unit parts
|
|
|
*/
|
|
|
interface Dimension {
|
|
|
number: string;
|
|
|
unit: string;
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* A wrapper around a parsed CSS value that allows for inspecting and walking nodes
|
|
|
*/
|
|
|
interface ParsedValue {
|
|
|
/**
|
|
|
* The series of parsed nodes
|
|
|
*/
|
|
|
nodes: Node[];
|
|
|
|
|
|
/**
|
|
|
* Walk all parsed nodes, applying a callback
|
|
|
*
|
|
|
* @param callback A visitor callback that will be executed for each node
|
|
|
* @param bubble When set to `true`, walking will be done inside-out instead of outside-in
|
|
|
*/
|
|
|
walk(callback: WalkCallback, bubble?: boolean): this;
|
|
|
}
|
|
|
|
|
|
interface ValueParser {
|
|
|
/**
|
|
|
* Decompose a CSS dimension into its numeric and unit part
|
|
|
*
|
|
|
* @param value The dimension to decompose
|
|
|
* @returns An object representing `number` and `unit` part of the dimension or `false` if the decomposing fails
|
|
|
*/
|
|
|
unit(value: string): Dimension | false;
|
|
|
|
|
|
/**
|
|
|
* Serialize a series of nodes into a CSS value
|
|
|
*
|
|
|
* @param nodes The nodes to stringify
|
|
|
* @param custom A custom stringifier callback
|
|
|
* @returns The generated CSS value
|
|
|
*/
|
|
|
stringify(nodes: Node | Node[], custom?: CustomStringifierCallback): string;
|
|
|
|
|
|
/**
|
|
|
* Walk a series of nodes, applying a callback
|
|
|
*
|
|
|
* @param nodes The nodes to walk
|
|
|
* @param callback A visitor callback that will be executed for each node
|
|
|
* @param bubble When set to `true`, walking will be done inside-out instead of outside-in
|
|
|
*/
|
|
|
walk(nodes: Node[], callback: WalkCallback, bubble?: boolean): void;
|
|
|
|
|
|
/**
|
|
|
* Parse a CSS value into a series of nodes to operate on
|
|
|
*
|
|
|
* @param value The value to parse
|
|
|
*/
|
|
|
new (value: string): ParsedValue;
|
|
|
|
|
|
/**
|
|
|
* Parse a CSS value into a series of nodes to operate on
|
|
|
*
|
|
|
* @param value The value to parse
|
|
|
*/
|
|
|
(value: string): ParsedValue;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
declare const postcssValueParser: postcssValueParser.ValueParser;
|
|
|
|
|
|
export = postcssValueParser;
|