Skip to main content

Facilitates the usage of HTMX with Django

Project description

hx-requests

Full documentation: hx-requests Documentation Demo Website: https://hx-requests-demo.com/


pre-commit Code style: ruff Code style: djlint

Overview

What Are hx-requests?

To start with a high-level explanation, hx-requests are quasi Django + Htmx views. They mimic Django's class-based views but with added functionality to work seamlessly with Htmx. Using a View mixin, it elegantly handles multiple Htmx requests on a single page. Each Htmx request is routed to a specific hx-request (think of it as a view), which returns the necessary HTML to update the DOM. A more detailed explanation can be found below.

Why The Name?

Excellent question! The package was named early on in the development process when the behavior wasn't exactly clear. All that was clear was that there needed to be an easier way to work with Htmx in Django. Hx comes from Htmx, and requests because every use of Htmx is a request to the server. If it was named today, it would probably be called something like Django-Htmx-Views, but hx-requests has stuck.

Why Use hx-requests?

This is where we will get into the details of why hx-requests is needed.

There are multiple ways of integrating Htmx in a Django project.

1. Using The Page View

The most common way is re-hitting the view that loaded the page.

The base view:

class MyView(View):
    def get(self, request):
        return render(request, "my_template.html")

The template:

<div hx-get="{% url 'my_view' %}">
    <p>Click me to use hx-get</p>
</div>

Handling the request:

class MyView(View):
    def get(self, request):
        if request.headers.get("HX-Request"):
            return render(request, "my_template.html")
        return render(request, "my_template.html")

This approach works well for views with one Htmx request, but what if you have multiple Htmx requests on the same page?

Handling multiple Htmx requests:

class MyView(View):
    def get(self, request):
        if request.headers.get("HX-Request"):
            if request.headers.get("Unique-Identifier") == "get_user_info":
                return render(request, "user_info_card.html")
            if request.headers.get("Unique-Identifier") == "get_user_profile":
                return render(request, "user_profile_card.html")
        return render(request, "my_template.html")

Issues with this approach:

  • It gets messy if there are multiple Htmx requests on the same page.
  • Handling POST requests with specific logic dynamically adds complexity.
  • The logic for handling Htmx requests is tightly coupled to the view, making reuse difficult.

2. Using Separate Views

Each Htmx request is routed to a separate view.

# Page View
class MyView(View):
    def get(self, request):
        context = {'complex-context': "This is a complex context"}
        return render(request, "my_template.html", context)

# Htmx Request 1
class GetUserInfo(View):
    def get(self, request):
        return render(request, "user_info_card.html")

# Htmx Request 2
class GetUserProfile(View):
    def get(self, request):
        return render(request, "user_profile_card.html")

Issues with this approach:

  • Each Htmx request requires a separate URL.
  • Context is not shared across views, leading to code duplication.
  • Using Django's built-in ListView, duplicating logic for Htmx requests becomes a nightmare.

hx-requests: The Solution

hx-requests solves all of these issues. It allows multiple Htmx requests on the same page while sharing context across requests. Every Htmx request routes to an hx-request.

Advantages:

  • The parent view is not cluttered with extra logic for handling multiple Htmx requests.
  • HxRequests are reusable across views, reducing duplication.
  • No extra URLs are needed.
  • The view's context is shared across all Htmx requests, making it easier to manage.

Additionally, hx-requests includes built-in functionality to help with common Htmx use cases:

  • Form validation and automatic return of errors when using FormHxRequest.
  • Easy integration with Django's messages framework.
  • Compatibility with django-render-block for partial template rendering.
  • Built-in support for handling modals with Htmx.

Full documentation: hx-requests Documentation


Contributing to this repository

Getting setup

  • This project is using poetry
  • pre-commit is used for CI (code formatting, linting, etc...)
  • There is a dev container that can be used with vs-code

Committing

Must follow Conventional Commit

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

hx_requests-0.41.0.tar.gz (18.8 kB view details)

Uploaded Source

Built Distribution

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

hx_requests-0.41.0-py3-none-any.whl (20.0 kB view details)

Uploaded Python 3

File details

Details for the file hx_requests-0.41.0.tar.gz.

File metadata

  • Download URL: hx_requests-0.41.0.tar.gz
  • Upload date:
  • Size: 18.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.5 CPython/3.8.18 Linux/6.14.0-1017-azure

File hashes

Hashes for hx_requests-0.41.0.tar.gz
Algorithm Hash digest
SHA256 b0e2d6c90d1b68c093bb48e4c758c284013640e20b542514aae3ab237a8b7d3c
MD5 1e198d17e34c20eddb560aecf7e3ba73
BLAKE2b-256 4a82c6b93613f143e7da24be364ec6034eb30d08ab0470bd8bb6966d1c940dbc

See more details on using hashes here.

File details

Details for the file hx_requests-0.41.0-py3-none-any.whl.

File metadata

  • Download URL: hx_requests-0.41.0-py3-none-any.whl
  • Upload date:
  • Size: 20.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.5 CPython/3.8.18 Linux/6.14.0-1017-azure

File hashes

Hashes for hx_requests-0.41.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ca95ea56d5fe7c669282bf31306b27c114a7d41fa10a36dc55088617e4306f89
MD5 cc44110296cb0b99f7b75bcf66633f90
BLAKE2b-256 9d87bf0cd94cb974117ac678376806920ee8a4bc1f5165db7fb51866e4ff2b77

See more details on using hashes here.

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