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>
85 lines
1.9 KiB
JavaScript
85 lines
1.9 KiB
JavaScript
let Declaration = require('../declaration')
|
|
let {
|
|
getGridGap,
|
|
inheritGridGap,
|
|
parseGridAreas,
|
|
prefixTrackProp,
|
|
prefixTrackValue,
|
|
warnGridGap,
|
|
warnMissedAreas
|
|
} = require('./grid-utils')
|
|
|
|
function getGridRows(tpl) {
|
|
return tpl
|
|
.trim()
|
|
.slice(1, -1)
|
|
.split(/["']\s*["']?/g)
|
|
}
|
|
|
|
class GridTemplateAreas extends Declaration {
|
|
/**
|
|
* Translate grid-template-areas to separate -ms- prefixed properties
|
|
*/
|
|
insert(decl, prefix, prefixes, result) {
|
|
if (prefix !== '-ms-') return super.insert(decl, prefix, prefixes)
|
|
|
|
let hasColumns = false
|
|
let hasRows = false
|
|
let parent = decl.parent
|
|
let gap = getGridGap(decl)
|
|
gap = inheritGridGap(decl, gap) || gap
|
|
|
|
// remove already prefixed rows
|
|
// to prevent doubling prefixes
|
|
parent.walkDecls(/-ms-grid-rows/, i => i.remove())
|
|
|
|
// add empty tracks to rows
|
|
parent.walkDecls(/grid-template-(rows|columns)/, trackDecl => {
|
|
if (trackDecl.prop === 'grid-template-rows') {
|
|
hasRows = true
|
|
let { prop, value } = trackDecl
|
|
trackDecl.cloneBefore({
|
|
prop: prefixTrackProp({ prefix, prop }),
|
|
value: prefixTrackValue({ gap: gap.row, value })
|
|
})
|
|
} else {
|
|
hasColumns = true
|
|
}
|
|
})
|
|
|
|
let gridRows = getGridRows(decl.value)
|
|
|
|
if (hasColumns && !hasRows && gap.row && gridRows.length > 1) {
|
|
decl.cloneBefore({
|
|
prop: '-ms-grid-rows',
|
|
raws: {},
|
|
value: prefixTrackValue({
|
|
gap: gap.row,
|
|
value: `repeat(${gridRows.length}, auto)`
|
|
})
|
|
})
|
|
}
|
|
|
|
// warnings
|
|
warnGridGap({
|
|
decl,
|
|
gap,
|
|
hasColumns,
|
|
result
|
|
})
|
|
|
|
let areas = parseGridAreas({
|
|
gap,
|
|
rows: gridRows
|
|
})
|
|
|
|
warnMissedAreas(areas, decl, result)
|
|
|
|
return decl
|
|
}
|
|
}
|
|
|
|
GridTemplateAreas.names = ['grid-template-areas']
|
|
|
|
module.exports = GridTemplateAreas
|