refactor(ui): Reorganize metadata into compact two-column layout

- Replaced single-column Form widget with two-column grid layout
- Created makeRow helper for compact key-value pairs
- Left column: File, Format, Resolution, Aspect, Duration, FPS, etc.
- Right column: Codecs, Bitrates, Pixel Format, Channels, etc.
- More efficient use of space, matches modern UI design
- Text truncation prevents overflow

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
This commit is contained in:
Stu Leak 2025-12-29 12:19:15 -05:00
parent 3645291988
commit 16767a5ca6

63
main.go
View File

@ -9110,34 +9110,43 @@ Metadata: %s`,
metadata, metadata,
) )
info := widget.NewForm( // Helper function to create compact key-value rows
widget.NewFormItem("File", widget.NewLabel(src.DisplayName)), makeRow := func(key, value string) fyne.CanvasObject {
widget.NewFormItem("Format Family", widget.NewLabel(utils.FirstNonEmpty(src.Format, "Unknown"))), keyLabel := widget.NewLabel(key + ":")
widget.NewFormItem("Resolution", widget.NewLabel(fmt.Sprintf("%dx%d", src.Width, src.Height))), keyLabel.TextStyle = fyne.TextStyle{Bold: true}
widget.NewFormItem("Aspect Ratio", widget.NewLabel(src.AspectRatioString())), valueLabel := widget.NewLabel(value)
widget.NewFormItem("Pixel Aspect Ratio", widget.NewLabel(par)), valueLabel.Wrapping = fyne.TextTruncate
widget.NewFormItem("Duration", widget.NewLabel(src.DurationString())), return container.NewBorder(nil, nil, keyLabel, nil, container.NewHBox(layout.NewSpacer(), valueLabel))
widget.NewFormItem("Video Codec", widget.NewLabel(utils.FirstNonEmpty(src.VideoCodec, "Unknown"))), }
widget.NewFormItem("Video Bitrate", widget.NewLabel(bitrate)),
widget.NewFormItem("Frame Rate", widget.NewLabel(fmt.Sprintf("%.2f fps", src.FrameRate))), // Organize metadata into a compact two-column grid
widget.NewFormItem("Pixel Format", widget.NewLabel(utils.FirstNonEmpty(src.PixelFormat, "Unknown"))), col1 := container.NewVBox(
widget.NewFormItem("Interlacing", widget.NewLabel(interlacing)), makeRow("File", src.DisplayName),
widget.NewFormItem("Color Space", widget.NewLabel(colorSpace)), makeRow("Format", utils.FirstNonEmpty(src.Format, "Unknown")),
widget.NewFormItem("Color Range", widget.NewLabel(colorRange)), makeRow("Resolution", fmt.Sprintf("%dx%d", src.Width, src.Height)),
widget.NewFormItem("GOP Size", widget.NewLabel(gopSize)), makeRow("Aspect Ratio", src.AspectRatioString()),
widget.NewFormItem("Audio Codec", widget.NewLabel(utils.FirstNonEmpty(src.AudioCodec, "Unknown"))), makeRow("Duration", src.DurationString()),
widget.NewFormItem("Audio Bitrate", widget.NewLabel(audioBitrate)), makeRow("Frame Rate", fmt.Sprintf("%.2f fps", src.FrameRate)),
widget.NewFormItem("Audio Rate", widget.NewLabel(fmt.Sprintf("%d Hz", src.AudioRate))), makeRow("Interlacing", interlacing),
widget.NewFormItem("Channels", widget.NewLabel(utils.ChannelLabel(src.Channels))), makeRow("Color Space", colorSpace),
widget.NewFormItem("Chapters", widget.NewLabel(chapters)), makeRow("Color Range", colorRange),
widget.NewFormItem("Metadata", widget.NewLabel(metadata)), makeRow("GOP Size", gopSize),
) )
for _, item := range info.Items {
if lbl, ok := item.Widget.(*widget.Label); ok { col2 := container.NewVBox(
lbl.Wrapping = fyne.TextWrapWord makeRow("Video Codec", utils.FirstNonEmpty(src.VideoCodec, "Unknown")),
lbl.TextStyle = fyne.TextStyle{} // prevent selection makeRow("Video Bitrate", bitrate),
} makeRow("Pixel Format", utils.FirstNonEmpty(src.PixelFormat, "Unknown")),
} makeRow("Pixel AR", par),
makeRow("Audio Codec", utils.FirstNonEmpty(src.AudioCodec, "Unknown")),
makeRow("Audio Bitrate", audioBitrate),
makeRow("Audio Rate", fmt.Sprintf("%d Hz", src.AudioRate)),
makeRow("Channels", utils.ChannelLabel(src.Channels)),
makeRow("Chapters", chapters),
makeRow("Metadata", metadata),
)
info := container.NewHBox(col1, col2)
// Copy metadata button - beside header text // Copy metadata button - beside header text
copyBtn := widget.NewButton("📋", func() { copyBtn := widget.NewButton("📋", func() {