Metadata-Version: 2.4
Name: chrononav
Version: 0.1.1
Summary: A sleek CLI for timezone conversions with ASCII art and rich tables.
Home-page: https://github.com/vivek378521/chrononav
Author: Vivek Khatri
Author-email: vvk3785@gmail.com
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Environment :: Console
Requires-Python: >=3.7
Description-Content-Type: text/markdown
Requires-Dist: typer[all]>=0.9.0
Requires-Dist: rich>=13.0.0
Requires-Dist: pytz>=2022.1
Requires-Dist: pyfiglet>=0.8.post1
Requires-Dist: python-dateutil>=2.8.2

# ChronoNav

> A sleek and powerful CLI for navigating timezones with ease, right from your terminal.

ChronoNav is a command-line tool that makes dealing with timezones simple and intuitive. Whether you need a quick glance at world clocks, want to know the current time for a colleague overseas, or need to schedule a meeting across multiple timezones, ChronoNav has you covered.

![Demo Screenshot](https://raw.githubusercontent.com/vivek378521/chrononav/refs/heads/main/assets/demo.png)

## Key Features

- **Live World Clocks:** Run `chrononav` with no arguments for a beautiful dashboard of current times in major world cities.
- **Specific Time Conversion:** Convert any time from a source timezone to multiple destination timezones.
- **"Now" Command:** Instantly check the current time in any list of cities or timezones.
- **12/24 Hour Format:** Use the `--am-pm` flag to toggle between 12-hour and 24-hour clock formats.
- **Smart Aliases:** Use common city names and aliases (like `nyc`, `la`, `kolkata`) instead of formal timezone identifiers.
- **Polished Interface:** Features ASCII art and rich, colorful tables for excellent readability.

## Installation

The recommended way to install ChronoNav is using `pipx`, which installs Python CLI tools in isolated environments, preventing dependency conflicts.

### Recommended Method: `pipx`

1.  **First, install pipx (you only need to do this once):**
    ```bash
    python3 -m pip install --user pipx
    python3 -m pipx ensurepath
    ```
    *(You may need to restart your terminal after this step for the `PATH` change to take effect.)*

2.  **Install ChronoNav:**
    ```bash
    pipx install chrononav
    ```

### Alternative Method: `pip`

If you prefer, you can install with `pip`. The `--user` flag is crucial to avoid modifying system packages.

1.  **Install ChronoNav for your user:**
    ```bash
    python3 -m pip install --user chrononav
    ```

2.  **Verify your PATH (Important!):** This method may install the `chrononav` command to a directory not in your shell's `PATH`. If you get a "command not found" error, you must add it. Open your `~/.bashrc`, `~/.zshrc`, or equivalent shell configuration file and add one of the following lines:
    ```bash
    # For Linux:
    export PATH="$HOME/.local/bin:$PATH"

    # For macOS (path may vary depending on Python version):
    export PATH="$HOME/Library/Python/3.9/bin:$PATH"
    ```
    Restart your terminal for the change to take effect.

## Usage Examples

### Default View (Live World Clocks)
Simply run the command by itself. Use `--am-pm` for 12-hour format.

```bash
chrononav --am-pm
```


### Usage Showcase

Here are some real-world examples of how you can use `chrononav` to solve common timezone challenges.

#### 1. Checking a Few Key Timezones
Get a quick, clean report of the current time in specific locations using the `now` command. This is great for getting a daily overview of major business hubs.

**Command:**
```bash
chrononav now london nyc tokyo dubai
```

---

#### 2. Planning an International Team Meeting
You're in **Chicago** and want to schedule a meeting for **10:00 AM** your time. What time is that for your colleagues in **Berlin** and **Kolkata**?

**Command:**
```bash
chrononav convert "10:00am" --from chicago --to berlin --to kolkata
```

---

#### 3. Announcing a Global Webinar
A webinar is scheduled for **14:00 UTC** on **November 20th, 2025**. Find out the local time for attendees in **New York** and **Sydney**, and display it in AM/PM format.

**Command:**
```bash
chrononav convert "2025-11-20 14:00" --from utc --to nyc --to sydney --am-pm
```
*Note: ChronoNav will correctly handle the date rolling over to the next day for locations across the dateline.*

---

#### 4. Coordinating a Project Deadline
A project deadline is **Friday at 5 PM Pacific Time** (Los Angeles). What time and date is that for the team in **Paris**? `chrononav` is smart enough to parse relative dates like "Friday".

**Command:**
```bash
chrononav convert "Friday 5pm" --from "America/Los_Angeles" --to "Europe/Paris"
```
*This shows how a deadline can easily be early the next morning for another team.*

---

#### 5. Decoding Server Log Timestamps
Your server logs show a critical error at **02:30 UTC**. You need to know what time this occurred for the on-call engineers in **India** (IST) and **London**. This is perfect for developers and system administrators working with globally distributed systems.

**Command:**
```bash
chrononav convert "02:30" --from utc --to kolkata --to london
```

---

#### 6. Mixing and Matching Aliases and Timezones
ChronoNav lets you use a mix of simple aliases (`la`), full timezone names (`Asia/Singapore`), and cities (`berlin`) all in the same command.

**Command:**
```bash
chrononav now la Asia/Singapore berlin
```

---

#### 7. Checking Flight Arrival Times Across the Dateline
Your flight departs from **Los Angeles** at **11:30 PM on March 15th, 2026**. What is the local time and—more importantly—the date when you land in **Tokyo**? This powerful example demonstrates how `chrononav` handles complex multi-day conversions.

**Command:**
```bash
chrononav convert "2026-03-15 11:30 PM" --from la --to tokyo --am-pm
```
