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>
70 lines
2.3 KiB
JavaScript
70 lines
2.3 KiB
JavaScript
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.fireEvent = void 0;
|
|
var _dom = require("@testing-library/dom");
|
|
// react-testing-library's version of fireEvent will call
|
|
// dom-testing-library's version of fireEvent. The reason
|
|
// we make this distinction however is because we have
|
|
// a few extra events that work a bit differently
|
|
const fireEvent = (...args) => (0, _dom.fireEvent)(...args);
|
|
exports.fireEvent = fireEvent;
|
|
Object.keys(_dom.fireEvent).forEach(key => {
|
|
fireEvent[key] = (...args) => _dom.fireEvent[key](...args);
|
|
});
|
|
|
|
// React event system tracks native mouseOver/mouseOut events for
|
|
// running onMouseEnter/onMouseLeave handlers
|
|
// @link https://github.com/facebook/react/blob/b87aabdfe1b7461e7331abb3601d9e6bb27544bc/packages/react-dom/src/events/EnterLeaveEventPlugin.js#L24-L31
|
|
const mouseEnter = fireEvent.mouseEnter;
|
|
const mouseLeave = fireEvent.mouseLeave;
|
|
fireEvent.mouseEnter = (...args) => {
|
|
mouseEnter(...args);
|
|
return fireEvent.mouseOver(...args);
|
|
};
|
|
fireEvent.mouseLeave = (...args) => {
|
|
mouseLeave(...args);
|
|
return fireEvent.mouseOut(...args);
|
|
};
|
|
const pointerEnter = fireEvent.pointerEnter;
|
|
const pointerLeave = fireEvent.pointerLeave;
|
|
fireEvent.pointerEnter = (...args) => {
|
|
pointerEnter(...args);
|
|
return fireEvent.pointerOver(...args);
|
|
};
|
|
fireEvent.pointerLeave = (...args) => {
|
|
pointerLeave(...args);
|
|
return fireEvent.pointerOut(...args);
|
|
};
|
|
const select = fireEvent.select;
|
|
fireEvent.select = (node, init) => {
|
|
select(node, init);
|
|
// React tracks this event only on focused inputs
|
|
node.focus();
|
|
|
|
// React creates this event when one of the following native events happens
|
|
// - contextMenu
|
|
// - mouseUp
|
|
// - dragEnd
|
|
// - keyUp
|
|
// - keyDown
|
|
// so we can use any here
|
|
// @link https://github.com/facebook/react/blob/b87aabdfe1b7461e7331abb3601d9e6bb27544bc/packages/react-dom/src/events/SelectEventPlugin.js#L203-L224
|
|
fireEvent.keyUp(node, init);
|
|
};
|
|
|
|
// React event system tracks native focusout/focusin events for
|
|
// running blur/focus handlers
|
|
// @link https://github.com/facebook/react/pull/19186
|
|
const blur = fireEvent.blur;
|
|
const focus = fireEvent.focus;
|
|
fireEvent.blur = (...args) => {
|
|
fireEvent.focusOut(...args);
|
|
return blur(...args);
|
|
};
|
|
fireEvent.focus = (...args) => {
|
|
fireEvent.focusIn(...args);
|
|
return focus(...args);
|
|
}; |