2026-01-07 20:42:28 +01:00
|
|
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
2026-01-07 20:22:49 +01:00
|
|
|
// src/app/document/vector.rs
|
|
|
|
|
//
|
|
|
|
|
// Vector documents (SVG, etc.).
|
|
|
|
|
|
|
|
|
|
use std::path::PathBuf;
|
|
|
|
|
|
|
|
|
|
use cosmic::iced::widget::image as iced_image;
|
|
|
|
|
|
|
|
|
|
/// Represents a vector document such as SVG.
|
|
|
|
|
/// For now this only stores the raw data and a rasterized handle.
|
|
|
|
|
pub struct VectorDocument {
|
|
|
|
|
pub path: PathBuf,
|
|
|
|
|
pub raw_data: String,
|
|
|
|
|
pub handle: iced_image::Handle,
|
|
|
|
|
/// Cached dimensions of the rasterized representation.
|
|
|
|
|
pub width: u32,
|
|
|
|
|
pub height: u32,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
impl VectorDocument {
|
|
|
|
|
pub fn open(path: PathBuf) -> anyhow::Result<Self> {
|
|
|
|
|
let raw_data = std::fs::read_to_string(&path)?;
|
|
|
|
|
|
|
|
|
|
// TODO: proper SVG parsing and rendering.
|
|
|
|
|
// For now, use a placeholder size based on a typical default.
|
|
|
|
|
let (width, height) = (800, 600);
|
|
|
|
|
let handle = iced_image::Handle::from_rgba(1, 1, vec![0, 0, 0, 0]);
|
|
|
|
|
|
|
|
|
|
Ok(Self {
|
|
|
|
|
path,
|
|
|
|
|
raw_data,
|
|
|
|
|
handle,
|
|
|
|
|
width,
|
|
|
|
|
height,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// Returns the dimensions of the rasterized representation.
|
|
|
|
|
pub fn dimensions(&self) -> (u32, u32) {
|
|
|
|
|
(self.width, self.height)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
pub fn refresh_handle(&mut self) {
|
|
|
|
|
// TODO: re-render SVG to DynamicImage and rebuild handle.
|
|
|
|
|
// Update self.width and self.height accordingly.
|
|
|
|
|
}
|
Implement comprehensive metadata extraction for raster images with
EXIF support and display in the right panel.
New features:
- Extract basic metadata (filename, format, resolution, file size, color type)
- Parse EXIF data (camera, date, exposure, aperture, ISO, focal length, GPS)
- Display metadata in collapsible right panel (toggle with 'i' key)
- Auto-refresh metadata on document navigation
Changes by file:
Cargo.toml, Cargo.lock:
- Add kamadak-exif dependency for EXIF parsing
i18n/en/noctua.ftl:
- Add translation strings for all metadata labels
src/app/document/meta.rs:
- New module for metadata types (BasicMeta, ExifMeta, DocumentMeta)
- Extraction logic with EXIF parsing via kamadak-exif
- Helper methods for formatted display (resolution, file size, camera, GPS)
src/app/document/mod.rs:
- Re-export meta module
src/app/document/{raster,vector,portable}.rs:
- Add extract_metadata() method stubs (full impl for raster)
src/app/document/file.rs:
- Reset metadata on document change
src/app/message.rs:
- Add ToggleRightPanel and RefreshMetadata messages
src/app/model.rs:
- Add metadata: Option<DocumentMeta> field
- Add show_right_panel: bool field
src/app/update.rs:
- Handle panel toggle and metadata refresh
- Auto-refresh metadata on navigation when panel visible
src/app/view/panels.rs:
- Implement right_panel() with metadata display
- Conditional sections for basic info and EXIF data
src/app/view/canvas.rs:
- Integrate right panel into layout"
2026-01-10 11:46:07 +01:00
|
|
|
/// Extract metadata for this vector document.
|
|
|
|
|
pub fn extract_meta(&self) -> super::meta::DocumentMeta {
|
|
|
|
|
let (width, height) = self.dimensions();
|
|
|
|
|
|
|
|
|
|
super::meta::build_vector_meta(&self.path, width, height)
|
|
|
|
|
}
|
2026-01-07 20:22:49 +01:00
|
|
|
}
|