Skip to content

Latest commit

Β 

History

History
133 lines (119 loc) Β· 7.2 KB

File metadata and controls

133 lines (119 loc) Β· 7.2 KB

UI Layout Diagram

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ DOCX β†’ Markdown Translation Workbench                                        [─][β–‘][Γ—] β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚ File   View   Settings                                                              β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                                                     β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”‚
β”‚  β”‚                 β”‚ β”‚                               β”‚ β”‚                       β”‚  β”‚
β”‚  β”‚  DOCX Preview   β”‚ β”‚   Segment Inspector           β”‚ β”‚  Markdown Preview     β”‚  β”‚
β”‚  β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”‚ β”‚   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”‚ β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”‚  β”‚
β”‚  β”‚  β”‚Read-only   β”‚ β”‚ β”‚   β”‚ # β”‚Type β”‚Styleβ”‚...  β”‚   β”‚ β”‚  β”‚ Rendered β”‚ Raw  β”‚  β”‚  β”‚
β”‚  β”‚  β”‚view of     β”‚ β”‚ β”‚   β”œβ”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€   β”‚ β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€  β”‚  β”‚
β”‚  β”‚  β”‚original    β”‚ β”‚ β”‚   β”‚ 0 β”‚Head β”‚H1   β”‚...  β”‚   β”‚ β”‚  β”‚                 β”‚  β”‚  β”‚
β”‚  β”‚  β”‚DOCX        β”‚ β”‚ β”‚   β”‚ 1 β”‚Para β”‚Norm β”‚...  β”‚   β”‚ β”‚  β”‚ # Sample Doc    β”‚  β”‚  β”‚
β”‚  β”‚  β”‚document    β”‚ β”‚ β”‚   β”‚ 2 β”‚Head β”‚H2   β”‚...  β”‚   β”‚ β”‚  β”‚                 β”‚  β”‚  β”‚
β”‚  β”‚  β”‚            β”‚ β”‚ β”‚   β”‚ 3 β”‚List β”‚List β”‚...  β”‚   β”‚ β”‚  β”‚ This is a       β”‚  β”‚  β”‚
β”‚  β”‚  β”‚Shows:      β”‚ β”‚ β”‚   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β”‚ β”‚  β”‚ sample para...  β”‚  β”‚  β”‚
β”‚  β”‚  β”‚β€’ Title     β”‚ β”‚ β”‚                               β”‚ β”‚  β”‚                 β”‚  β”‚  β”‚
β”‚  β”‚  β”‚β€’ Segments  β”‚ β”‚ β”‚   Columns:                    β”‚ β”‚  β”‚ ## Features     β”‚  β”‚  β”‚
β”‚  β”‚  β”‚β€’ Content   β”‚ β”‚ β”‚   β€’ Order Index               β”‚ β”‚  β”‚                 β”‚  β”‚  β”‚
β”‚  β”‚  β”‚            β”‚ β”‚ β”‚   β€’ Type                      β”‚ β”‚  β”‚ - Three-pane    β”‚  β”‚  β”‚
β”‚  β”‚  β”‚            β”‚ β”‚ β”‚   β€’ Style                     β”‚ β”‚  β”‚   workbench     β”‚  β”‚  β”‚
β”‚  β”‚  β”‚            β”‚ β”‚ β”‚   β€’ Content                   β”‚ β”‚  β”‚                 β”‚  β”‚  β”‚
β”‚  β”‚  β”‚            β”‚ β”‚ β”‚   β€’ Markdown                  β”‚ β”‚  β”‚                 β”‚  β”‚  β”‚
β”‚  β”‚  β”‚            β”‚ β”‚ β”‚   β€’ Diagnostics               β”‚ β”‚  β”‚                 β”‚  β”‚  β”‚
β”‚  β”‚  β”‚            β”‚ β”‚ β”‚   β€’ Exclude β˜‘                 β”‚ β”‚  β”‚                 β”‚  β”‚  β”‚
β”‚  β”‚  β”‚            β”‚ β”‚ β”‚                               β”‚ β”‚  β”‚                 β”‚  β”‚  β”‚
β”‚  β”‚  β”‚            β”‚ β”‚ β”‚   Features:                   β”‚ β”‚  β”‚                 β”‚  β”‚  β”‚
β”‚  β”‚  β”‚            β”‚ β”‚ β”‚   β€’ Row selection             β”‚ β”‚  β”‚                 β”‚  β”‚  β”‚
β”‚  β”‚  β”‚            β”‚ β”‚ β”‚   β€’ Editable exclusion        β”‚ β”‚  β”‚                 β”‚  β”‚  β”‚
β”‚  β”‚  β”‚            β”‚ β”‚ β”‚   β€’ Diagnostics view          β”‚ β”‚  β”‚                 β”‚  β”‚  β”‚
β”‚  β”‚  β”‚            β”‚ β”‚ β”‚   β€’ Segment overrides         β”‚ β”‚  β”‚                 β”‚  β”‚  β”‚
β”‚  β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜ β”‚ β”‚                               β”‚ β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β”‚  β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β”‚
β”‚                                                                                     β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚ Status: Loaded 4 segments. 1 diagnostics.                                          β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Component Breakdown

Menu Bar

  • File: Open, Export, Exit
  • View: Toggle pane visibility
  • Settings: Conversion options (checkboxes for various settings)

Left Pane (DOCX Preview)

  • Displays original document content
  • Shows document title
  • Lists segments in order
  • Read-only view

Middle Pane (Segment Inspector)

  • DataGrid with all document segments
  • Interactive column headers
  • Sortable columns
  • Editable exclusion checkboxes
  • Displays diagnostic counts
  • Row selection syncs other panes

Right Pane (Markdown Preview)

  • Toggle button for Rendered/Raw view
  • Rendered mode: Rich Markdown display
  • Raw mode: Editable text with monospace font
  • Scrollable content
  • Live updates

Status Bar

  • Shows current operation
  • Document load status
  • Segment and diagnostic counts
  • Error messages

Interaction Flow

User Opens File
      ↓
File Dialog β†’ Select DOCX
      ↓
Parse Document
      ↓
β”œβ”€β†’ Update DOCX Preview (Left)
β”œβ”€β†’ Populate Segment Inspector (Middle)
└─→ Render Markdown Preview (Right)
      ↓
User Selects Segment in Inspector
      ↓
β”œβ”€β†’ Highlight in DOCX Preview*
└─→ Scroll to in Markdown Preview*
      
      (* Future enhancement)

Settings Integration

User Changes Setting (e.g., "Infer Headings")
      ↓
OnSettingsChanged event
      ↓
If document loaded:
      ↓
β”œβ”€β†’ Recreate converter with new settings
β”œβ”€β†’ Reconvert document
└─→ Update all panes
      ↓
Status: "Document reconverted with new settings."

Data Flow

DOCX File
    ↓
DocxParser (Core)
    ↓
DocumentModel
    ↓
MarkdownConverter (Core)
    ↓
Segments with Markdown
    ↓
ObservableCollection<Segment>
    ↓
β”œβ”€β†’ DataGrid Binding (Inspector)
β”œβ”€β†’ Text Binding (DOCX Preview)
└─→ Markdown Binding (Preview)