Skip to main content

Django and Tailwind integration based on the prebuilt Tailwind CSS CLI.

Project description

django-tailwind-cli

GitHub Workflow Status PyPI Code style: black GitHub

This project provides an integration of Tailwind CSS for Django that is based on the precompiled versions of the Tailwind CSS CLI.

It is inspired by the implementation of the Tailwind integration for Phoenix which completely skips the neccesity of a node installation. So it is a perfect match, if you are a user of htmx or any other framework that tries to avoid JavaScript coding in your web app. My personal motivation was, that I discovered that I never needed any other plugin besides the official plugins, which are already included in the CLI.

If you want to use node or you have to use it because of other dependencies, then the package django-tailwind by Tim Kamamin might be a better solution for you.

Features

  • Management Commands...
    • ...to install the the CLI for your operating system and machine architecture.
    • ...to start the CLI in watch mode to incrementally compile your style sheet.
    • ...to create a theme app which includes a basic stylesheet and a tailwind configuration which you can extend.
    • ...to build the production ready CSS file.
  • A template tag to include the CSS file in your base template.
  • All the official plugins (typography, form, line-clamp, and aspect-ratio) integrated in the CLI are activated in the default configuration.

Requirements

Python 3.8 or newer with Django >= 3.2.

Installation

  1. Install the package inside your Django project.

    python -m pip install django-tailwind-cli
    
  2. Add django_tailwind_cli to INSTALLED_APPS in settings.py.

    INSTALLED_APPS = [
        # other Django apps
        "django_tailwind_cli",
    ]
    
  3. Run the management command to install the cli and initialize the theme app.

    python manage.py tailwind installcli
    python manage.py tailwind init
    

    This installs the CLI to $HOME/.local/bin/ and creates a new app in your project with the name theme.

  4. Add the new theme app to INSTALLED_APPS in settings.py.

    INSTALLED_APPS = [
        # other Django apps
        "django_tailwind_cli",
        "theme",
    ]
    
  5. Edit your base template to include Tailwind's stylesheet.

    {% load tailwind_cli %}
    ...
    <head>
      ...
      {% tailwind_css %}
      ...
    </head>
    
  6. Start the Tailwind CLI in watch mode.

    python manage.py tailwind startwatcher
    
  7. (Optional) Add django-browser-reload if you enjoy automatic reloading during development.

Configuration

The default configuration for this package is.

{
    "TAILWIND_VERSION": "3.1.8",
    "TAILWIND_CLI_PATH": "~/.local/bin/",
    "TAILWIND_THEME_APP": "theme",
    "TAILWIND_SRC_CSS": "src/styles.css",
    "TAILWIND_DIST_CSS": "css/styles.css",
}
  • Set TAILWIND_VERSION to the version of Tailwind you want to use.
  • TAILWIND_CLI_PATH defines where the CLI is installed. The default makes sense on macOS or Linux. On Windows it might helpful to pick a different path.
  • TAILWIND_THEME_APP defines the name of the theme application created by the management command tailwind init.
  • TAILWIND_SRC_CSS and TAILWIND_DIST_CSS defines the internal structure of the theme app. TAILWIND_DIST_CSS is a path always relative to the static folder of the theme app.

Management Commands

Command Description
 tailwind installcli Download the CLI version TAILWIND_VERSION to TAILWIND_CLI_PATH.
 tailwind init Create a new theme app with the name TAILWIND_THEME_APP inside the settings.BASE_DIR of your project.
 tailwind startwatcher Start the CLI in watch and incremental compilation mode.
 tailwind build Create a production ready build of the Tailwind stylesheet. You have to run this before calling the collectstatic command.

Template Tags

This package provides a single template tag to include the Tailwind CSS. Depending on the value of settings.DEBUG it activates preload or not.

{% load tailwind_cli %}
...
<head>
    ...
    {% tailwind_css %}
    ...
</head>

DEBUG == False creates the following output:

<link rel="preload" href="/static/css/styles.css" as="style">
<link rel="stylesheet" href="/static/css/styles.css">

DEBUG == True creates this output:

<link rel="stylesheet" href="/static/css/styles.css">

License

This software is licensed under MIT license. Copyright (c) 2022 Oliver Andrich.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django_tailwind_cli-0.9.2.tar.gz (9.1 kB view details)

Uploaded Source

Built Distribution

django_tailwind_cli-0.9.2-py3-none-any.whl (8.7 kB view details)

Uploaded Python 3

File details

Details for the file django_tailwind_cli-0.9.2.tar.gz.

File metadata

  • Download URL: django_tailwind_cli-0.9.2.tar.gz
  • Upload date:
  • Size: 9.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.2 CPython/3.10.8 Darwin/22.1.0

File hashes

Hashes for django_tailwind_cli-0.9.2.tar.gz
Algorithm Hash digest
SHA256 8ac17123e9860aaa4dbb4c383f569b531cbb073bd568b145c101f289eb8eeb50
MD5 2ac419ff4a6f72afe15b1cdf5a29c45b
BLAKE2b-256 9f91a40a98aa31f0714e5ef987265942faac65b98abe68cfefb1de0daeab60fd

See more details on using hashes here.

File details

Details for the file django_tailwind_cli-0.9.2-py3-none-any.whl.

File metadata

File hashes

Hashes for django_tailwind_cli-0.9.2-py3-none-any.whl
Algorithm Hash digest
SHA256 16cff213e490f3a9982a52cff9c2a57e36a61f73244cc3e6d04d9e3d736846fa
MD5 2fe9f93cfc1a0b2d079663fb15c65de0
BLAKE2b-256 8be4d12bd26b64ba2d85f279200269126bb63538d563552cbc453d2d597bce4b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page