Skip to content

ashuhlee/starlit

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

starlit

A minimal and customizable weather CLI, written in Python 🐍

preview Powered by the OpenWeatherMap API and styled with the Python rich library + terminal text effects ✨

GitHub Repo stars GitHub Issues or Pull Requests GitHub commit activity GitHub repo size

Requirements

  • Python 3.13+
  • Poetry or pip package manager
  • An OpenWeatherMap API key
  • UTF-8 terminal with 256 colors and nerd font

Installation

Installing starlit is quick and easy. The built-in setup command guides you through configuration.

Option 1: Install from PyPI

The easiest way to install starlit is via pip:

pip install starlit-cli

Then set up your configuration:

starlit --setup # creates ~/.config/starlit/.env
starlit --edit  # opens .env file (add your api key here) 

Option 2: Install from source

For local development, contributing, or if you want an isolated installation:

  1. Clone this repository
git clone https://github.com/ashuhlee/starlit.git
cd starlit
  1. Create the virtual environment
# macOS / Linux / Windows
python -m venv .venv

Activate the virtual environment:

source .venv/bin/activate # macOS / Linux
.venv\Scripts\Activate    # Windows (Powershell)
  1. Install dependencies

Some packages are required for this project. They will automatically be installed if you run:

pip install .
  1. Set up your .env file

Generate a configuration file from the example template and open the file:

starlit --setup
starlit --edit

Get your OpenWeatherMap API key and paste it into the .env file under API_KEY=

Configuration

starlit creates a default configuration file when you run starlit --setup. The .env file stores your API key, default city and display preferences.

  • Linux/macOS: ~/.config/starlit/.env
  • Windows: C:\users\username\.config\starlit\.env
Setting Description
API_KEY Your OpenWeatherMap API key
DEFAULT_CITY The city shown when you don’t pass one
UNITS Options: metric (°C) or imperial (°F)
DISABLE_ANIMATION Turns off all animations in starlit
SHOW_DT Shows local date and time
SHOW_ASCII Shows the little ASCII art to the left
SHOW_MSG Adds a cute message at the bottom
SHOW_EMOJI Shows emojis in your terminal
EMOJI_TYPE Choose a cute emoji for messages

Customize colors

You can also set your own colors for the gradient title and message labels. Use six-digit RGB hex codes (no # needed):

Setting Description Example
COLOR_1 Gradient color stop 1 color1 5D63FF
COLOR_2 Gradient color stop 2 color1 F7A4F4
LABEL_COLOR Message label color color1 5CE7F9

Usage

# basic usage
starlit

# specify city via command line
starlit seattle

# start interactive mode
starlit --interactive 

# opens the .env file in your default editor
starlit --edit

# shows config in .env file (if found)
starlit --config

# shows contents of .env file (if found)
starlit --config --show-full

# show version
starlit --version

# show help
starlit --help

Usage examples

preview-1 preview-2
preview-3 preview-4
preview-5 preview-6

What's next

  • 🕐 Different Modes: Add live updates or full forecast modes
  • Interactive Mode+: Add a full command line interface when using starlit -i
  • 🎨 Color Themes: Support for .json theme files so you can easily switch between color palettes
  • 🌍 Multi-language Support: Option to view weather info in different languages

Tech stack

About this project

I built this fun little project as a way to learn more about APIs and creating colorful terminal apps. It grew into a CLI project I'm proud of!

Thank you to charm for the color palette and design interface inspo 🎨 and to wego for the ASCII icons

⭐ If you like this project, please consider giving it a star!

About

a minimal, cute and customizable weather cli ✨

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages