things3-core 1.1.0

Core library for Things 3 database access and data models
Documentation
//! Data export example
//!
//! Run with: cargo run --example export_data

use things3_core::{DataExporter, ExportData, ExportFormat, ThingsConfig, ThingsDatabase};

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    println!("Things 3 Data Export Example\n");

    // Connect to database
    let config = ThingsConfig::from_env();
    let db = ThingsDatabase::new(&config.database_path).await?;

    // Get data
    println!("Fetching data...");
    let tasks = db.get_inbox(None).await?;
    let projects = db.get_projects(None).await?;
    let areas = db.get_areas().await?;

    println!("  Tasks: {}", tasks.len());
    println!("  Projects: {}", projects.len());
    println!("  Areas: {}", areas.len());
    println!();

    // Create exporter
    let exporter = DataExporter::new_default();
    let export_data = ExportData::new(tasks, projects, areas);

    // Export to JSON
    println!("Exporting to JSON...");
    let json = exporter.export(&export_data, ExportFormat::Json)?;
    std::fs::write("export.json", &json)?;
    println!("  ✓ Saved to export.json ({} bytes)", json.len());

    // Export to CSV
    println!("Exporting to CSV...");
    let csv = exporter.export(&export_data, ExportFormat::Csv)?;
    std::fs::write("export.csv", &csv)?;
    println!("  ✓ Saved to export.csv ({} bytes)", csv.len());

    // Export to Markdown
    println!("Exporting to Markdown...");
    let markdown = exporter.export(&export_data, ExportFormat::Markdown)?;
    std::fs::write("export.md", &markdown)?;
    println!("  ✓ Saved to export.md ({} bytes)", markdown.len());

    println!("\n✓ Export completed successfully");
    Ok(())
}