Skip to main content

USWDS components for Django Cotton

Project description

django-cotton-uswds

USWDS components as Django Cotton templates.

Use the U.S. Web Design System in your Django projects with a clean, declarative component syntax.

Installation

git clone https://github.com/iversondiles/django-cotton-uswds.git
cd django-cotton-uswds
pip install -e .

Then add both django_cotton and django_cotton_uswds to your INSTALLED_APPS:

INSTALLED_APPS = [
    # ...
    "django_cotton",
    "django_cotton_uswds",
]

Usage

Components follow the <c-component> naming convention:

<c-alert type="info" heading="Informative status">
    This is an informative alert.
</c-alert>

Attributes pass through to the underlying USWDS markup, so you can use the same options documented on the USWDS component pages.

USWDS Assets

This package provides markup only — no CSS or JavaScript is bundled. You need to add USWDS assets to your project separately.

See the USWDS getting started guide for instructions on compiling and including the USWDS stylesheet and scripts.

Available Components

This project is in early development. Components are being added incrementally. See the USWDS components page for reference on what's planned.

Form Rendering

The package includes a USWDS form renderer that automatically styles Django forms with USWDS markup — labels, hints, error messages, and all standard widget types.

Per-form via mixin

from django import forms
from django_cotton_uswds.mixins import USWDSFormMixin

class ContactForm(USWDSFormMixin, forms.Form):
    name = forms.CharField(label="Full name")
    email = forms.EmailField()
    message = forms.CharField(widget=forms.Textarea)

Globally via settings

# settings.py
FORM_RENDERER = "django_cotton_uswds.renderer.USWDSFormRenderer"

Widget attribute passthrough

USWDS-specific attributes can be passed through widget attrs:

class MyForm(USWDSFormMixin, forms.Form):
    name = forms.CharField(
        widget=forms.TextInput(attrs={"width": "md"}),
    )
    resume = forms.FileField(
        widget=forms.ClearableFileInput(attrs={"accept": ".pdf,.doc"}),
    )

Supported widget mappings

Django widget USWDS rendering
TextInput, EmailInput, NumberInput, etc. usa-input text field
Textarea usa-textarea
Select usa-select dropdown
RadioSelect Fieldset with usa-radio buttons
CheckboxSelectMultiple Fieldset with usa-checkbox items
CheckboxInput (boolean) Single usa-checkbox
ClearableFileInput usa-file-input

Demo

A demo project is included to showcase components. Requires just and uv.

# Install the package with demo dependencies
just install

# Run the development server at http://127.0.0.1:8000/
just demo

# Build a static site into demo_project/dist/
just build

Requirements

  • Python 3.10+
  • Django 4.2+
  • django-cotton 1.2.1+

Domain Language

See UBIQUITOUS_LANGUAGE.md for a glossary of canonical domain terms used in this project.

License

MIT

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_cotton_uswds-1.1.0.tar.gz (101.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_cotton_uswds-1.1.0-py3-none-any.whl (51.2 kB view details)

Uploaded Python 3

File details

Details for the file django_cotton_uswds-1.1.0.tar.gz.

File metadata

  • Download URL: django_cotton_uswds-1.1.0.tar.gz
  • Upload date:
  • Size: 101.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for django_cotton_uswds-1.1.0.tar.gz
Algorithm Hash digest
SHA256 1a0c8c03f775355b77e4c0f310e0a3b6e1a6d0307b83772f80af3e32a8871c21
MD5 1b8c20944102e8e122e1d92e59e5e79b
BLAKE2b-256 6a7bf2f8c9663419eca80656d7a4a87c7b313180a23dabb3d6976d6f790527c3

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_cotton_uswds-1.1.0.tar.gz:

Publisher: publish.yml on focusconsulting/django-cotton-uswds

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file django_cotton_uswds-1.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for django_cotton_uswds-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 be48a770b71c8e9a290a7f9f8f924b5f071601c4a73ce3f293388cae91e75a5d
MD5 985dede8674ab28e88c1962369962bf8
BLAKE2b-256 46887ed237f704a8fe975f44990d3bf13f5dc6f426bf344228f4d2de004c6cd2

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_cotton_uswds-1.1.0-py3-none-any.whl:

Publisher: publish.yml on focusconsulting/django-cotton-uswds

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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