Metadata-Version: 2.4
Name: stattic
Version: 1.0.0
Summary: A simple yet powerful static site generator written in Python
Home-page: https://github.com/getstattic/stattic
Author: Robert DeVore
Author-email: Robert DeVore <me@robertdevore.com>
License-Expression: MIT
Project-URL: Homepage, https://github.com/getstattic/stattic
Project-URL: Bug Reports, https://github.com/getstattic/stattic/issues
Project-URL: Source, https://github.com/getstattic/stattic
Project-URL: Documentation, https://docs.stattic.site
Keywords: static site generator,markdown,jinja2,blog,website
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: Operating System :: OS Independent
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
Classifier: Topic :: Internet :: WWW/HTTP :: Site Management
Classifier: Topic :: Software Development :: Code Generators
Classifier: Topic :: Text Processing :: Markup :: HTML
Requires-Python: >=3.8
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: markdown==3.4.1
Requires-Dist: Jinja2>=3.1.6
Requires-Dist: pyyaml==6.0
Requires-Dist: watchdog==2.1.9
Requires-Dist: requests==2.32.4
Requires-Dist: Pillow==10.3.0
Requires-Dist: tqdm==4.66.3
Requires-Dist: csscompressor==0.9.5
Requires-Dist: rjsmin==1.2.0
Requires-Dist: mistune==2.0.3
Dynamic: author
Dynamic: home-page
Dynamic: license-file
Dynamic: requires-python

# Stattic - Decentralized Publishing

**Stattic** is a Python-based static site generator that converts Markdown content into static HTML websites using Jinja2 templates. It supports features such as posts, tags, categories, authors, SEO metadata, image optimization, and asset minification, making it ideal for creating fast, lightweight, and SEO-friendly websites.

## Features

- **Markdown-based Content**: Write your content in Markdown files with YAML frontmatter for metadata.
- **Jinja2 Templating**: Customize site layouts using Jinja2 templates located in the `templates/` directory.
- **Pretty Permalinks & Custom URLs**: Generate clean URLs with trailing slashes and set custom URLs via frontmatter.
- **Tags and Categories**: Organize posts with tags and categories, automatically creating archive pages.
- **Authors Support**: Associate posts with authors loaded from `content/authors.yml`.
- **SEO Support**: Add metadata (title, keywords, description) for better SEO.
- **Pagination**: Control the number of posts per page on the homepage.
- **Image Handling**: Automatically download external images, convert them to WebP for optimization, and update URLs in content.
- **Google Fonts Integration**: Download specified Google Fonts and generate corresponding CSS.
- **Asset Management**: Copy and manage CSS, JS, and font assets, with optional minification.
- **RSS Feed and XML Sitemap**: Generate RSS feeds and sitemaps for your site when a site URL is provided.
- **LLMs.txt for AI Crawlers**: Generate structured content files for AI and LLM crawlers to better understand your site.
- **404 Page Generation**: Create a custom `404.html` page for error handling.
- **Logging**: Detailed logs of the build process, including performance metrics and errors.
- **Error Handling**: Gracefully manage template syntax errors, missing files, and download failures.

## Table of Contents

1. [Installation](#installation)
2. [Usage](#usage)
3. [Content Organization](#content-organization)
4. [Customization](#customization)
5. [SEO and Metadata](#seo-and-metadata)
6. [Image Optimization](#image-optimization)
7. [Asset Minification](#asset-minification)
8. [RSS Feed and Sitemap](#rss-feed-and-sitemap)
9. [LLMs.txt for AI Crawlers](#llmstxt-for-ai-crawlers)
10. [Logging](#logging)
11. [Contributing](#contributing)
12. [License](#license)

---

## Installation

### Option 1: Install from PyPI (Recommended)

Install Stattic directly from PyPI using pip:

```bash
pip install stattic
```

After installation, you can use the `stattic` command from anywhere in your terminal.

### Option 2: Install from Source

1. **Clone the Repository:**

    ```bash
    git clone https://github.com/getstattic/stattic.git
    cd stattic
    ```

2. **Install Required Python Dependencies:**

    Ensure you have Python 3.8 or higher installed.

    ```bash
    pip install -r requirements.txt
    ```

3. **Install the package in development mode:**

    ```bash
    pip install -e .
    ```

### Requirements

**Python packages (install via pip)**

- `markdown`: Converts Markdown files to HTML.
- `jinja2`: Template engine for rendering HTML pages.
- `pyyaml`: Parses YAML frontmatter from Markdown files.
- `requests`: Downloads external resources like images and fonts.
- `Pillow`: Handles image processing and conversion to WebP.
- `csscompressor`: Minifies CSS files.
- `rjsmin`: Minifies JavaScript files.
- `mistune`: Markdown parser with custom rendering.
- `watchdog`: (Optional) Monitors file changes in watch mode.

---

## Usage

### **Configuration File (Recommended)**

Stattic supports configuration files to avoid typing command-line arguments repeatedly. Create a configuration file and complete starter project structure in your project directory:

```bash
stattic --init yml
```

This creates a `stattic.yml` file with all available settings and sets up your entire project structure including:

- **Configuration file**: `stattic.yml` (or `.yaml`/`.json` based on your choice)
- **Directory structure**: `templates/`, `content/posts/`, `content/pages/`, `assets/css/`, `assets/js/`, `assets/images/`
- **Template files**: All default HTML templates (`base.html`, `post.html`, `index.html`, etc.)
- **Sample content**: `sample-post.md` and `sample-page.md` to get you started
- **Configuration files**: `authors.yml`, `categories.yml`, `tags.yml` with sample data

The generated `stattic.yml` contains all available settings:

```yaml
# Stattic Configuration File
# Configure your static site generator settings here

# Site information
site_url: https://demo.stattic.site
site_title: My Static Site
site_tagline: Built with Stattic

# Build settings
output: output
content: content
templates: templates
assets: assets
blog_slug: blog

# Content settings
posts_per_page: 5
sort_by: date  # date, title, author, order

# Styling
fonts:
  - Quicksand

# SEO settings
robots: public  # public or private
llms: public    # public or private

# Development settings
minify: true
watch: false
```

After creating your configuration file, simply run:

```bash
stattic
```

Stattic will automatically load settings from:
- `stattic.yml` or `stattic.yaml` (YAML format)
- `stattic.json` (JSON format)

Command-line arguments still work and will override configuration file settings.

### **Basic Usage**

After installation, you can use the `stattic` command from anywhere in your terminal:

```bash
stattic
```

This command processes the content in the `content/` directory, applies the templates from `templates/`, and outputs the static site to the `output/` directory.

### **Command-Line Arguments**

- `--output`: Specify the output directory. Default is `output`.
    ```bash
    stattic --output ~/Documents/demo
    ```

- `--content`: Specify the content directory. Default is `content`.
    ```bash
    stattic --content ~/Documents/demo-content
    ```

- `--templates`: Specify the templates directory. Default is `templates`.
    ```bash
    stattic --templates ~/Documents/demo-templates
    ```

- `--assets`: Specify the assets directory. Default is `assets`.
    ```bash
    stattic --assets ~/Documents/demo-assets
    ```

- `--posts-per-page`: Number of posts per index (homepage) page. Default is `5`.
    ```bash
    stattic --posts-per-page 10
    ```

- `--sort-by`: Sort posts by `date`, `title`, `author` or `order`. Default is `date`.
    ```bash
    stattic --sort-by title
    ```

- `--fonts`: Comma-separated list of Google Fonts to download.
    ```bash
    stattic --fonts "Quicksand, Roboto"
    ```

- `--site-title`: Specify the site title for production builds.
    ```bash
    stattic --site-title "Demo title goes here"
    ```

- `--site-tagline`: Specify the site tagline for production builds.
    ```bash
    stattic --site-tagline "Demo tagline goes here"
    ```

- `--site-url`: Specify the site URL for production builds. Enables RSS feed and sitemap generation.
    ```bash
    stattic --site-url "https://demo.stattic.site"
    ```

- `--robots`: Specify if the robots.txt file is public or private. Default is `public`.
    ```bash
    stattic --robots public
    ```

- `--llms`: Specify if the llms.txt file is public or private. Default is `public`.
    ```bash
    stattic --llms public
    ```

- `--init`: Create a sample configuration file and starter project structure. Choose from `yml`, `yaml`, or `json`.
    ```bash
    stattic --init yml
    ```
    This command creates:
    - Sample configuration file (`stattic.yml`, `stattic.yaml`, or `stattic.json`)
    - Complete directory structure (`templates/`, `content/`, `assets/`)
    - Default template files
    - Sample content files (`sample-post.md`, `sample-page.md`)
    - Sample YAML configuration files (`authors.yml`, `categories.yml`, `tags.yml`)

- `--watch`: _(Not Implemented)_ Enable watch mode to automatically rebuild on file changes.
    
    ```bash
    stattic --watch
    ```    

- `--minify`: Minify CSS and JS into single files.
    
    ```bash
    stattic --minify
    ```    

- `--blog-slug`: Custom slug for posts instead of 'blog'. Default is `blog`.
    ```bash
    stattic --blog-slug "articles"
    ```

- `--version`: Show the version number.
    
    ```bash
    stattic --version
    ```

- `--help`: Show help message with all available options.
    
    ```bash
    stattic --help
    ```

**Note:** The `--watch` feature is defined but not yet implemented in the current version.

### **Example: Building the Site with Custom Fonts and Minification**
```bash
stattic --output ~/Documents/demo --posts-per-page 10 --sort-by title --fonts "Quicksand, Roboto" --site-url "https://demo.stattic.site" --blog-slug "articles" --llms public --minify
```

* * *

## Content Organization

### **Directory Structure**

- `content/`
    - `posts/`: Place all blog posts here as Markdown (`.md`) files.
    - `pages/`: Place all static pages (e.g., About, Contact) here as Markdown (`.md`) files.
    - `categories.yml`: Define categories for your posts.
    - `tags.yml`: Define tags for your posts.
    - `authors.yml`: Define authors and their details.
- `templates/`: Contains Jinja2 templates (`base.html`, `post.html`, `index.html`, etc.).
- `assets/`: Contains CSS, JS, and font files to be copied to the `output/assets/` directory.
- `output/`: The generated static site will be placed here.
- `logs/`: Build logs are stored here.

### **Markdown Files with Frontmatter**

Each Markdown file should start with a YAML frontmatter block specifying metadata.

**Example: Blog Post (`content/posts/my-first-post.md`)**

```
---
title: "My First Blog Post"
date: 2024-09-25
tags: [Python, Static Sites]
categories: [Technology]
description: "An introduction to Stattic, a simple static site generator."
custom_url: "my-first-post"
author: 1
draft: false
---

# Welcome to Stattic!

This is my first blog post using **Stattic**.
```

**Example: Static Page (`content/pages/about.md`)**

```
---
title: "About"
custom_url: "about"
description: "Learn more about Stattic and its features."
author: 1
nav_hide: false
---

# About Stattic

Stattic is a Python-based static site generator...
```

* * *

## Customization

### **Templates**

Customize your site's layout by editing Jinja2 templates in the `templates/` directory.

- **`base.html`**: The global layout for all pages. Includes header, footer, and asset links.
- **`post.html`**: Template for individual blog posts.
- **`index.html`**: The main homepage template listing recent posts.
- **`404.html`**: Custom 404 error page.

### **Adding Custom Templates**

You can create additional templates for specific layouts or sections by following the naming conventions and extending `base.html`.

* * *

## SEO and Metadata

Enhance your site's SEO by adding metadata in the frontmatter of your Markdown files.

- **`title`**: The title of the page or post.
- **`description`**: A brief description for SEO purposes.
- **`keywords`**: Relevant keywords for the page or post.
- **`author`**: The author ID as defined in `authors.yml`.
- **`custom_url`**: Custom URL slug for the page or post.
- **`canonical`**: The canonical URL for the page or post.

**Example:**

```
---
title: "SEO Optimization with Stattic"
description: "Learn how to optimize your static site for search engines."
keywords: [SEO, Static Site, Optimization]
custom_url: "seo-optimization"
canonical: "https://yourdomain.com/custom-url"
author: 2
---
```

* * *

## Image Optimization

Stattic automatically handles image optimization by:

1. **Downloading External Images**: Images referenced via URLs in your content are downloaded and stored locally in the `output/images/` directory.
2. **Converting to WebP**: Downloaded images are converted to WebP format for better performance.
3. **Updating Image URLs**: Image references in your content are updated to point to the optimized WebP versions.

**Example:**

```    
![Logo](https://example.com/images/logo.png)
```

After processing, the above will be converted to:

```
<img src="images/logo.webp" alt="Logo">
```

* * *

## Asset Minification

Improve your site's performance by minifying CSS and JavaScript assets.

- **Enable Minification**: Use the `--minify` flag when running `stattic.py`.

```
python3 stattic.py --minify
```

- **Minified Files**:

    - `output/assets/css/main.min.css`: Combined and minified CSS.
    - `output/assets/js/main.min.js`: Combined and minified JavaScript.

**Note:** Ensure that your templates reference these minified files when the `--minify` flag is used.
* * *

## RSS Feed and Sitemap

Generate an RSS feed and XML sitemap for your site by providing the `--site-url` argument.

- **Generate RSS Feed and Sitemap**:
    ```
    python3 stattic.py --site-url "https://demo.stattic.site"
    ```

- **Generated Files**:

    - `output/feed/index.xml`: RSS feed containing your latest posts.
    - `output/sitemap.xml`: XML sitemap listing all pages and posts.

**Note:** RSS and sitemap generation are only enabled when a valid `--site-url` is provided.
* * *

## LLMs.txt for AI Crawlers

Generate an `llms.txt` file that provides structured content for AI crawlers and Large Language Models (LLMs). This file helps AI systems understand and index your site's content more effectively.

- **Generate LLMs.txt**:
    ```bash
    stattic --site-url "https://demo.stattic.site" --llms public
    ```

- **Disable LLMs.txt Generation**:
    ```bash
    stattic --llms private
    ```

- **Generated File**:
    - `output/llms.txt`: Structured content listing with posts, pages, and site information formatted for LLM consumption.

**File Content Includes:**
- Site title and description
- List of all blog posts with titles, URLs, and unique IDs
- List of all pages with titles, URLs, and unique IDs  
- Sitemap reference for comprehensive site structure

**Example `llms.txt` Content:**
```
# My Static Site - a Python-based static site generator's demo website

This site contains structured content formatted for LLM-friendly consumption.

## Posts
- [Welcome to Your New Static Site](https://demo.stattic.site/blog/sample-post/): ID 3851798142

## Pages
- [About This Site](https://demo.stattic.site/sample-page/): ID 4646506025

## Sitemap
https://demo.stattic.site/sitemap.xml
```

**Note:** LLMs.txt generation is enabled by default (`--llms public`) when a valid `--site-url` is provided. Use `--llms private` to disable it for development or private sites.
* * *

## Logging

Stattic provides detailed logs of the build process, including performance metrics and errors.

- **Log Files**: Stored in the `logs/` directory with timestamps.

**Example Log Entry:**

```
2024-09-27 12:34:56 - INFO - Starting build process...
2024-09-27 12:34:56 - INFO - Created output directory: output
2024-09-27 12:34:57 - INFO - Loaded 3 categories and 5 tags
2024-09-27 12:34:57 - INFO - Converted Markdown to HTML using Mistune (Time taken: 0.45 seconds)
2024-09-27 12:34:58 - INFO - Generated post: output/blog/my-first-post/index.html
2024-09-27 12:34:59 - INFO - Generated index page: output/index.html
2024-09-27 12:34:59 - INFO - Site build completed successfully in 3.00 seconds.
```

- **Console Output**: Also displays INFO level logs for real-time feedback.
* * *

## Contributing

We welcome contributions! To contribute:

1. **Fork the Repository:**

```
git clone git@github.com:getstattic/stattic.git
cd stattic
```

2. **Create a New Branch:**

```
git checkout -b feature-branch
```

3. **Make Your Changes**: Implement your features or fixes.

4. **Commit Your Changes:**

```
git commit -m "Add feature XYZ"
```

5. **Push to Your Fork:**

```
git push origin feature-branch
```

6. **Submit a Pull Request**: Open a pull request detailing your changes.

* * *

## License

This project is licensed under the MIT License. See the [LICENSE](/LICENSE) file for details.
