A modern and intuitive calendar interface for visualizing your DAG schedules in Apache Airflow.
Reason this release was yanked:
Feature bug
Project description
📅 Airflow Calendar
A modern and intuitive calendar interface for visualizing your DAG schedules in Apache Airflow. Transform complex cron expressions into a clear and searchable time grid inspired by the Google Calendar experience.
🎯 Why Airflow Calendar?
Have you ever felt lost trying to keep track of your Airflow DAG schedules?
When managing complex environments with dozens of DAGs, each with different execution requirements, losing control of your schedule is common.
While Airflow provides features to visualize the execution history of individual DAGs, it lacks a "global" view to see all scheduled DAGs at once.
This is where Airflow Calendar comes in. It provides a visual timeline of all your DAG schedules, allowing you to see at a glance when each DAG is set to run, identify potential overlaps, avoid resource conflicts, and manage concurrency and dependencies effectively.
You can check more details about the project in the Medium article.
✨ Key Features
- Timeline View: Visualize all your DAG schedules in clear monthly, weekly, or daily grids, making it easy to spot execution windows and potential load spikes.
- Smart Info-Popup: Instant access to critical DAG run details upon clicking an event.
- Displays Execution Time, Cron Expression, Estimated Duration, and Stats History (Last 5 runs).
- Color-Coded Status: Immediate visual identification of success, failure, or "no-run" states through dynamic colors.
- Native Deep Linking: Directly jump to the native Airflow Grid View for any specific DAG with a single click.
🚀 Installation
The recommended way to install Airflow Calendar is via pip. In your environment where Airflow is installed, run the following command:
pip install airflow-calendar
Otherwise, you can also clone the repository and install it manually by moving the airflow_calendar directory to your Airflow plugins folder.
Note: You may need to restart your Airflow Webserver after installation for the plugin to be picked up.
If everything is set up correctly, you should see a new "Calendar" option under the "Browse" menu in the Airflow UI:
⚙️ Configuration & Permissions
If the plugin is loaded but the Calendar option is not visible under the Browse menu, you likely need to grant permissions to your user role:
- Navigate to Security > List Roles.
- Edit your specific role (e.g., Admin, Op, or Viewer).
- Add the permission:
menu access on Calendar. - Save and refresh the page.
🔍 Troubleshooting
If the "Calendar" option still doesn't show up in the menu:
- Check Plugin Status: Go to Admin > Plugins. You should see
airflow_calendarlisted there. - Logs: If it's not listed, check your webserver logs.
- CLI: Run
airflow pluginsin your terminal to verify if the package was loaded correctly into the environment and check for any errors during loading.
🛠️ Roadmap
This project is in its early stages. Upcoming features include:
- Airflow 3 Compatibility: Support for the next generation of Airflow.
- Tag-Based Filtering: Filter calendar events using your existing DAG tags.
- Dynamic Styling: Background colors for events based on DAG tags.
- Search functionality: Quickly find specific events within the calendar.
- Schedule tool: Schedule or edit your DAGs directly through the calendar view.
🤝 Contributing
This project is open to contributions! Whether it's reporting a bug, suggesting a feature, or submitting a Pull Request:
- Open an issue to discuss the change you wish to make.
- Fork the repository and create your feature branch.
- Commit your changes with clear descriptions.
- Push to the branch and open a Pull Request.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file airflow_calendar-0.8.0.tar.gz.
File metadata
- Download URL: airflow_calendar-0.8.0.tar.gz
- Upload date:
- Size: 22.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
665ac3a9b32c3d1ef8307a934f25425db5dff7d72977a70e04c741e5828b808e
|
|
| MD5 |
313b301cd8ff8548a66fabf20e9fca46
|
|
| BLAKE2b-256 |
0b8f41f0a8616d853f58253fd85d550c29bbbbfe928658d65c1aa11d5f62500e
|
File details
Details for the file airflow_calendar-0.8.0-py3-none-any.whl.
File metadata
- Download URL: airflow_calendar-0.8.0-py3-none-any.whl
- Upload date:
- Size: 108.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a9e484037ad6ddda633c95391da7a805c66349cb168ff45acde9d7b0c398b3f8
|
|
| MD5 |
3a98af64db5b3b603e85dc1353fa0ec4
|
|
| BLAKE2b-256 |
10d837d2ad541e4ee68e78254e76bc0e106a7d042b12342d2c4b000e3befb48a
|