#!/usr/bin/env python3
from pathlib import Path
from typing import Tuple, Optional
import pandas as pd
import matplotlib.pyplot as plt
import matplotlib

matplotlib.use('Agg')


def plot_single_timeseries(
    time_data,
    var_data,
    var_name: str,
    output_path: Path,
    yrange: Optional[Tuple[float, float]] = None,
    title: Optional[str] = None,
    log_scale: bool = False,
) -> Tuple[bool, str]:
    try:
        if log_scale:
            import numpy as np

            var_data = np.maximum(var_data, 1e-09)
        plt.figure(figsize=(10, 6))
        plt.plot(time_data, var_data, linewidth=2)
        plt.title(title if title is not None else f'{var_name} vs Time')
        plt.xlabel('Time')
        plt.ylabel(var_name)
        plt.grid(True, alpha=0.3)
        if log_scale:
            plt.yscale('log')
        if yrange is not None:
            if log_scale:
                log_margin_factor = 1.1
                ymin = max(yrange[0] / log_margin_factor, 1e-09)
                ymax = yrange[1] * log_margin_factor
                max_decades = 15
                max_allowed = ymin * 10**max_decades
                if ymax > max_allowed:
                    ymax = max_allowed
                plt.ylim(ymin, ymax)
            else:
                margin = (yrange[1] - yrange[0]) * 0.05
                plt.ylim(yrange[0] - margin, yrange[1] + margin)
        plt.tight_layout()
        plt.savefig(output_path, dpi=150, bbox_inches='tight')
        plt.close()
        return (True, 'Created')
    except Exception as e:
        plt.close()
        return (False, f'Error plotting {var_name}: {str(e)}')


def plot_csv_file(csv_file: Path, force: int = 0, max_sampled_rows: Optional[int] = None) -> Tuple[str, bool, str]:
    try:
        df = pd.read_csv(csv_file)
        original_rows = len(df)
        sampled = False
        if max_sampled_rows is not None and original_rows > max_sampled_rows:
            if max_sampled_rows >= 2:
                if max_sampled_rows == 2:
                    selected_indices = [0, original_rows - 1]
                else:
                    middle_points = max_sampled_rows - 2
                    if middle_points > 0:
                        middle_indices = []
                        if original_rows > 3:
                            step = (original_rows - 2) / (middle_points + 1)
                            for i in range(1, middle_points + 1):
                                middle_indices.append(int(1 + i * step))
                        selected_indices = [0] + middle_indices + [original_rows - 1]
                    else:
                        selected_indices = [0, original_rows - 1]
                selected_indices = sorted(list(set(selected_indices)))
                df = df.iloc[selected_indices].reset_index(drop=True)
                sampled = True
        plot_dir = csv_file.parent / f'{csv_file.stem}.plot'
        plot_dir.mkdir(exist_ok=True)
        time_col = 't' if 't' in df.columns else df.columns[0]
        time_data = df[time_col]
        variables = [col for col in df.columns if col != time_col]
        plots_created = 0
        plots_skipped = 0
        for var in variables:
            plot_path = plot_dir / f'{var}.png'
            if not force and plot_path.exists():
                plots_skipped += 1
                continue
            (success, message) = plot_single_timeseries(time_data, df[var], var, plot_path, yrange=None)
            if not success:
                return (csv_file.name, False, message)
            else:
                plots_created += 1
        message = f'Created {plots_created} plots'
        if plots_skipped > 0:
            message += f' (skipped {plots_skipped} existing)'
        if sampled:
            message += f' (sampled {len(df)} of {original_rows} rows)'
        return (csv_file.name, True, message)
    except Exception as e:
        return (csv_file.name, False, f'Error reading CSV: {str(e)}')
