Metadata-Version: 2.4
Name: clipgenius
Version: 1.0.0
Summary: AI-powered command-line tool for downloading videos from YouTube and other platforms
Home-page: https://github.com/alexusa404-creator/Clipgenius
Author: Alex Mills And Team
Author-email: ClipGenius Team <team@clipgenius.com>
License: MIT
Project-URL: Homepage, https://github.com/alexusa404-creator/Clipgenius
Project-URL: Repository, https://github.com/alexusa404-creator/Clipgenius
Project-URL: Issues, https://github.com/alexusa404-creator/Clipgenius/issues
Keywords: video,downloader,youtube,ai,cli,yt-dlp
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: End Users/Desktop
Classifier: Topic :: Multimedia :: Video
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Requires-Python: >=3.8
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: yt-dlp>=2023.10.13
Requires-Dist: openai>=1.0.0
Requires-Dist: click>=8.0.0
Requires-Dist: colorama>=0.4.6
Requires-Dist: requests>=2.31.0
Requires-Dist: beautifulsoup4>=4.12.0
Dynamic: author
Dynamic: home-page
Dynamic: license-file
Dynamic: requires-python

# ClipGenius 🎬🤖

AI-powered command-line tool for downloading videos from YouTube and other platforms with conversational assistance.

## Features

- 🎯 **AI-Powered Interactions**: Conversational assistant that guides you through the download process
- 📱 **Multi-Platform Support**: Works with YouTube, Vimeo, and many other video platforms via yt-dlp
- 🎵 **Flexible Downloads**: Choose between video+audio, audio-only, or specific formats
- 📊 **Smart Analysis**: Get video metadata, duration, quality options before downloading
- 🎨 **Subtitle & Thumbnail Support**: Download subtitles and thumbnails alongside videos
- 🔧 **Error Handling**: AI-powered troubleshooting suggestions when downloads fail
- 🎪 **Interactive CLI**: Beautiful, colorful command-line interface
- 🔄 **Batch Processing**: Download multiple videos from URL lists or web pages
- 🏷️ **Smart Filenames**: AI-suggested custom filenames based on video content

## Installation

### Prerequisites

- Python 3.8 or higher
- pip (Python package installer)

### Install from Source (Development)

```bash
# Clone the repository
git clone https://github.com/alexusa404-creator/Clipgenius.git
cd Clipgenius

# Install in editable mode with all dependencies
pip install -e .
```

### Using virtual environment (recommended)

```bash
# Create virtual environment
python -m venv clipgenius-env

# Activate virtual environment
# On Windows:
clipgenius-env\Scripts\activate
# On macOS/Linux:
source clipgenius-env/bin/activate

# Install ClipGenius
pip install -e .
```

### Install from Package (Future)

Once published to PyPI, you'll be able to install directly:

```bash
pip install clipgenius
```

## Configuration

### OpenAI API Key (Optional but Recommended)

For AI-powered conversational features, you'll need an OpenAI API key:

1. Get your API key from [OpenAI](https://platform.openai.com/api-keys)
2. Set it as an environment variable:

```bash
# Linux/macOS
export OPENAI_API_KEY="your-api-key-here"

# Windows
set OPENAI_API_KEY=your-api-key-here
```

3. Or create a `.env` file (copy from `.env.example`):

```env
OPENAI_API_KEY=your-api-key-here
```

**Note**: ClipGenius works without an API key, but you'll miss the AI conversational features.

## Usage

### Basic Usage

```bash
# Interactive mode with AI assistance
clipgenius "https://www.youtube.com/watch?v=dQw4w9WgXcQ"

# Quick download without AI interaction
clipgenius "https://www.youtube.com/watch?v=dQw4w9WgXcQ" --no-ai

# Audio only download
clipgenius "https://www.youtube.com/watch?v=dQw4w9WgXcQ" --audio-only

# Custom download directory
clipgenius "https://www.youtube.com/watch?v=dQw4w9WgXcQ" --download-path ~/Videos

# Batch download from file
clipgenius --batch urls.txt

# Batch download from webpage (extract video URLs)
clipgenius --batch "https://example.com/video-page" --batch-webpage
```

### Advanced Options

```bash
# Specify video quality
clipgenius "URL" --quality 720p

# Run as Python module
python -m clipgenius "URL"

# Get help
clipgenius --help
```

### Interactive Experience

When you run ClipGenius in interactive mode, it will:

1. 🤖 **Greet you** and analyze your URL
2. 📊 **Show video details** (title, duration, channel, etc.)
3. 🎯 **Ask about preferences** (quality, format, subtitles, etc.)
4. 📺 **Display available formats** (if requested)
5. 🚀 **Download your video** with progress feedback
6. 🎁 **Offer additional resources** (subtitles, thumbnails)

## Examples

### Example 1: YouTube Video with AI

```bash
$ clipgenius "https://www.youtube.com/watch?v=dQw4w9WgXcQ"

╔═══════════════════════════════════════╗
║            🎬 ClipGenius 🤖            ║
║    AI-Powered Video Download Tool     ║
╚═══════════════════════════════════════╝

👋 Hello! I'm ClipGenius, your AI assistant for video downloads!

I can see you want to download from YouTube. Let me analyze this video for you...

🎬 Video Analysis
==================================================
📹 "Rick Astley - Never Gonna Give You Up" by Rick Astley
⏱️  Duration: 3m 33s | 👀 1.4B views

This classic 80s hit has become an internet phenomenon! Ready to download this timeless track?

❓ Video or audio only? (video/audio) video
❓ Quality preference? (best/720p/480p/360p/worst) 720p
❓ Download subtitles? (yes/no) yes
❓ Download thumbnail? (yes/no) yes
❓ Custom filename? (leave blank for default) 

✅ Download completed successfully!
✅ Subtitles downloaded!
✅ Thumbnail downloaded!
```

### Example 2: Quick Audio Download

```bash
$ clipgenius "https://www.youtube.com/watch?v=dQw4w9WgXcQ" --audio-only --no-ai

🎵 Quick audio download completed!
📁 Saved to: ./downloads/
```

### Example 3: Batch Download from File

Create a file `videos.txt`:
```
https://www.youtube.com/watch?v=dQw4w9WgXcQ
https://www.youtube.com/watch?v=9bZkp7q19f0
https://youtu.be/jNQXAC9IVRw
```

Then run:
```bash
$ clipgenius --batch videos.txt

🔄 Batch Download Mode
==================================================
✅ Found 3 video URLs:
  1. https://www.youtube.com/watch?v=dQw4w9WgXcQ
  2. https://www.youtube.com/watch?v=9bZkp7q19f0
  3. https://youtu.be/jNQXAC9IVRw

📋 Batch Download Preferences
==================================================
❓ Download all as audio only? (yes/no) no
❓ Quality for all videos? (best/720p/480p/etc.) 720p
❓ Download subtitles for all? (yes/no) yes
❓ Download thumbnails for all? (yes/no) no

🎉 Batch Download Complete!
==================================================
✅ Successful: 3
❌ Failed: 0
```

### Example 4: Extract Videos from Webpage

```bash
$ clipgenius --batch "https://example.com/playlist-page" --batch-webpage

🔍 Extracting video URLs from webpage...
✅ Found 5 video URLs from the webpage!
```

## Supported Platforms

ClipGenius uses yt-dlp under the hood, supporting 1000+ websites including:

- YouTube
- Vimeo
- Twitch
- TikTok
- Instagram
- Twitter
- Facebook
- And many more!

## Project Structure

```
clipgenius/
├── __init__.py          # Package initialization
├── __main__.py          # Entry point for python -m clipgenius
├── cli.py               # Command-line interface and main logic
├── ai_agent.py          # AI conversational assistant
├── downloader.py        # Video downloading logic (yt-dlp wrapper)
├── batch.py             # Batch processing and web scraping
└── utils.py             # Utility functions
```

## Development

### Running Tests

```bash
# Install development dependencies
pip install -e ".[dev]"

# Run tests (when available)
python -m pytest
```

### Contributing

1. Fork the repository
2. Create a feature branch (`git checkout -b feature/amazing-feature`)
3. Make your changes
4. Commit your changes (`git commit -m 'Add amazing feature'`)
5. Push to the branch (`git push origin feature/amazing-feature`)
6. Open a Pull Request

### Publishing to PyPI

For maintainers who want to publish this package to PyPI, see [PUBLISHING.md](PUBLISHING.md) for detailed instructions.

## Troubleshooting

### Common Issues

1. **"No OpenAI API key found"**
   - Set the OPENAI_API_KEY environment variable
   - Or use `--no-ai` flag to skip AI features

2. **"Could not extract video information"**
   - Check if the URL is correct and accessible
   - Some videos might be region-restricted or private
   - Try updating yt-dlp: `pip install --upgrade yt-dlp`

3. **Permission errors when downloading**
   - Make sure you have write permissions to the download directory
   - Try using a different download path with `--download-path`

### Getting Help

- Check the output of `clipgenius --help`
- Look at the error messages - ClipGenius provides helpful suggestions
- Open an issue on GitHub if you encounter bugs

## License

This project is licensed under the MIT License - see the LICENSE file for details.

## Acknowledgments

- [yt-dlp](https://github.com/yt-dlp/yt-dlp) for the robust video downloading backend
- [OpenAI](https://openai.com/) for the conversational AI capabilities
- [Click](https://click.palletsprojects.com/) for the command-line interface framework
- [BeautifulSoup](https://www.crummy.com/software/BeautifulSoup/) for web scraping functionality
