Implements Phases 1-8 of the TFTSR implementation plan. Rust backend (Tauri 2.x, src-tauri/): - Multi-provider AI: OpenAI-compatible, Anthropic, Gemini, Mistral, Ollama - PII detection engine: 11 regex patterns with overlap resolution - SQLCipher AES-256 encrypted database with 10 versioned migrations - 28 Tauri IPC commands for triage, analysis, document, and system ops - Ollama: hardware probe, model recommendations, pull/delete with events - RCA and blameless post-mortem Markdown document generators - PDF export via printpdf - Audit log: SHA-256 hash of every external data send - Integration stubs for Confluence, ServiceNow, Azure DevOps (v0.2) Frontend (React 18 + TypeScript + Vite, src/): - 9 pages: full triage workflow NewIssue→LogUpload→Triage→Resolution→RCA→Postmortem→History+Settings - 7 components: ChatWindow, TriageProgress, PiiDiffViewer, DocEditor, HardwareReport, ModelSelector, UI primitives - 3 Zustand stores: session, settings (persisted), history - Type-safe tauriCommands.ts matching Rust backend types exactly - 8 IT domain system prompts (Linux, Windows, Network, K8s, DB, Virt, HW, Obs) DevOps: - .woodpecker/test.yml: rustfmt, clippy, cargo test, tsc, vitest on every push - .woodpecker/release.yml: linux/amd64 + linux/arm64 builds, Gogs release upload Verified: - cargo check: zero errors - tsc --noEmit: zero errors - vitest run: 13/13 unit tests passing Co-Authored-By: Claude Sonnet 4.6 (1M context) <noreply@anthropic.com>
178 lines
4.2 KiB
TypeScript
178 lines
4.2 KiB
TypeScript
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;
|