hx

Types

Event

Used by the trigger function.

A trigger can also have additional modifiers that change its behavior, represented as a List(EventModifier).

pub type Event {
  Event(event: String, modifiers: List(EventModifier))
}

Constructors

  • Event(event: String, modifiers: List(EventModifier))
pub type EventModifier {
  Once
  Changed
  Delay(Timing)
  Throttle(Timing)
  From(extended_css_selector: ExtendedCssSelector)
  Target(css_selector: String)
  Consume
  QueueEvent(Option(Queue))
}

Constructors

  • Once
  • Changed
  • Delay(Timing)
  • Throttle(Timing)
  • From(extended_css_selector: ExtendedCssSelector)
  • Target(css_selector: String)
  • Consume
  • QueueEvent(Option(Queue))
pub type ExtendedCssSelector {
  CssSelector(css_selector: String)
  Document
  Window
  Closest(css_selector: String)
  Find(css_selector: String)
  Next(css_selector: Option(String))
  Previous(css_selector: Option(String))
  This
}

Constructors

  • CssSelector(css_selector: String)
  • Document
  • Window
  • Closest(css_selector: String)
  • Find(css_selector: String)
  • Next(css_selector: Option(String))
  • Previous(css_selector: Option(String))
  • This
pub type Queue {
  First
  Last
  All
}

Constructors

  • First
  • Last
  • All
pub type Scroll {
  Top
  Bottom
}

Constructors

  • Top
  • Bottom
pub type Swap {
  InnerHTML
  OuterHTML
  After
  Afterbegin
  Beforebegin
  Beforeend
  Afterend
  Delete
  SwapNone
}

Constructors

  • InnerHTML
  • OuterHTML
  • After
  • Afterbegin
  • Beforebegin
  • Beforeend
  • Afterend
  • Delete
  • SwapNone
pub type SwapOption {
  Transition(Bool)
  Swap(Timing)
  Settle(Timing)
  IgnoreTitle(Bool)
  Scroll(Scroll)
  Show(Scroll)
  FocusScroll(Bool)
}

Constructors

  • Transition(Bool)
  • Swap(Timing)
  • Settle(Timing)
  • IgnoreTitle(Bool)
  • Scroll(Scroll)
  • Show(Scroll)
  • FocusScroll(Bool)
pub type SyncOption {
  Default(css_selector: String)
  Drop(css_selector: String)
  Abort(css_selector: String)
  Replace(css_selector: String)
  SyncQueue(css_selector: String, queue: Queue)
}

Constructors

  • Default(css_selector: String)
  • Drop(css_selector: String)
  • Abort(css_selector: String)
  • Replace(css_selector: String)
  • SyncQueue(css_selector: String, queue: Queue)
pub type Timing {
  Seconds(Int)
  Milliseconds(Int)
}

Constructors

  • Seconds(Int)
  • Milliseconds(Int)

Functions

pub fn boost(set: Bool) -> Attribute(a)

hx-boost

Makes regular links and forms use AJAX for navigation.

The hx-boost attribute progressively enhances links and forms to use AJAX instead of full page reloads, while falling back to standard navigation if JavaScript is disabled.

Example

import lustre/element.{a, button, div, form, text}
import hx

// Apply boost to an entire section - all links/forms inside will use AJAX
div([hx.boost(True)], [
  a([href("/products")], [text("Products")]),
  a([href("/about")], [text("About")]),
  form([action("/search"), method("get")], [
    // Form elements...
    button([], [text("Search")])
  ])
])
pub fn confirm(confirm_text: String) -> Attribute(a)

hx-confirm

Shows a confirmation dialog before making a request.

The hx-confirm attribute is useful for dangerous or destructive operations that you want the user to confirm before proceeding.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // Simple confirmation message
  button([
    hx.delete("/user/123"), 
    hx.confirm("Are you sure you want to delete this user?")
  ], [
    text("Delete User")
  ])
])
pub fn delete(url url: String) -> Attribute(a)

hx-delete

Issues a DELETE request to the given URL when the element is triggered. By default, AJAX requests are triggered by the “natural” event of an element:

  • input, textarea & select are triggered on the change event
  • form is triggered on the submit event
  • everything else is triggered by the click event

If you want different behavior you can use the hx-trigger attribute, provided by lustre_hx.trigger, to specify which event will cause the request.

pub fn disable() -> Attribute(a)

hx-disable

Disables HTMX processing for a given element.

The hx-disable attribute is useful when you want to temporarily or conditionally disable HTMX processing on an element.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // This button will not process HTMX attributes
  button([
    hx.get("/api/data"),  // This will be ignored 
    hx.disable()
  ], [
    text("HTMX Disabled")
  ])
])
pub fn disable_elt(
  extended_css_selectors: List(ExtendedCssSelector),
) -> Attribute(a)

hx-disable-elt

Disables elements during requests.

The hx-disable-elt attribute allows you to specify elements that should be disabled during the course of an AJAX request. Useful for preventing duplicate form submissions.

Example

import lustre/element.{button, div, form, input, text}
import hx

div([], [
  form([
    hx.post("/api/submit"),
    // Disable the submit button during the request
    hx.disable_elt([hx.CssSelector("button[type='submit']")])
  ], [
    input([type_("text"), name("name")], []),
    button([type_("submit")], [text("Submit")])
  ]),
  
  // Disable multiple elements
  form([
    hx.post("/api/complex-submit"),
    hx.disable_elt([
      hx.CssSelector("input"), 
      hx.CssSelector("button"), 
      hx.This
    ])
  ], [
    // Form elements...
  ])
])
pub fn disinherit(attributes: List(String)) -> Attribute(a)

hx-disinherit

Controls which attributes are inherited from ancestor elements.

The hx-disinherit attribute allows you to prevent specific HTMX attributes from being inherited by an element from its ancestors.

Example

import lustre/element.{button, div, text}
import hx

div([
  // Parent has a trigger which will be inherited by children
  hx.trigger([hx.Event(event: "click", modifiers: [])])
], [
  // This button will inherit the click trigger
  button([hx.get("/data1")], [text("Inherited Trigger")]),
  
  // This button will NOT inherit the click trigger
  button([
    hx.get("/data2"),
    hx.disinherit(["hx-trigger"])
  ], [
    text("No Trigger Inheritance")
  ])
])
pub fn disinherit_all() -> Attribute(a)

hx-disinherit (all attributes)

Prevents inheritance of all HTMX attributes from ancestor elements.

The disinherit_all function is a shorthand for preventing the inheritance of all HTMX attributes, which can help isolate parts of your UI from unwanted inheritance.

Example

import lustre/element.{button, div, text}
import hx

div([
  // Parent has multiple HTMX attributes
  hx.get("/parent-data"),
  hx.trigger([hx.Event(event: "click", modifiers: [])]),
  hx.swap(hx.InnerHTML, None)
], [
  // This button will inherit all HTMX attributes from parent
  button([], [text("Inherited Everything")]),
  
  // This button won't inherit any HTMX attributes
  button([
    hx.post("/isolated"),
    hx.disinherit_all()
  ], [
    text("No Inheritance")
  ])
])
pub fn encoding(encoding: String) -> Attribute(a)

hx-encoding

Sets the encoding type for the request.

The hx-encoding attribute allows you to specify the encoding for HTMX requests, particularly useful for form submissions that include file uploads.

Example

import lustre/element.{button, div, form, input, text}
import hx

div([], [
  // Form with file uploads
  form([
    hx.post("/upload"),
    hx.encoding("multipart/form-data")
  ], [
    input([type_("file"), name("file")], []),
    button([type_("submit")], [text("Upload File")])
  ])
])
pub fn ext(ext: List(String)) -> Attribute(a)

hx-ext

Includes one or more HTMX extensions for an element.

HTMX extensions allow you to extend the functionality of HTMX with additional features and behaviors.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // Using the client-side templates extension
  button([
    hx.get("/api/data"),
    hx.ext(["client-side-templates"])
  ], [
    text("Load With Template")
  ]),
  
  // Using multiple extensions
  button([
    hx.post("/api/data"),
    hx.ext(["json-enc", "ajax-header"])
  ], [
    text("With Multiple Extensions")
  ])
])
pub fn get(url url: String) -> Attribute(a)

hx-get

Issues a GET request to the given URL when the element is triggered. By default, AJAX requests are triggered by the “natural” event of an element:

  • input, textarea & select are triggered on the change event
  • form is triggered on the submit event
  • everything else is triggered by the click event

If you want different behavior you can use the hx-trigger attribute, provided by lustre_hx.trigger, to specify which event will cause the request.

pub fn headers(
  headers: Json,
  compute_value: Bool,
) -> Attribute(a)

hx-headers

Adds custom headers to AJAX requests.

The hx-headers attribute allows you to specify additional HTTP headers to be included in an AJAX request.

Example

import gleam/json
import lustre/element.{button, div, text}
import hx

div([], [
  // Static headers
  button([
    hx.get("/api/data"), 
    hx.headers(
      json.object([
        #("X-Requested-With", json.string("XMLHttpRequest")),
        #("Authorization", json.string("Bearer token123"))
      ]),
      False
    )
  ], [
    text("With Custom Headers")
  ]),
  
  // Dynamic headers using JavaScript
  button([
    hx.post("/api/submit"), 
    hx.headers(
      json.object([
        #("X-Session-Token", json.string("localStorage.getItem('token')"))
      ]),
      True
    )
  ], [
    text("With Dynamic Headers")
  ])
])
pub fn history(should_be_saved: Bool) -> Attribute(a)

hx-history

Controls if the element should be included in the browser history.

The hx-history attribute allows you to control whether requests for a given element should be recorded in the browser’s history.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // This will be added to browser history (default behavior with push_url)
  button([
    hx.get("/page1"),
    hx.push_url(True),
    hx.history(True)
  ], [
    text("Navigate with History")
  ]),
  
  // This will not be added to browser history even though push_url is True
  button([
    hx.get("/temp-view"),
    hx.push_url(True),
    hx.history(False)
  ], [
    text("Temporary View")
  ])
])
pub fn history_elt() -> Attribute(a)

hx-history-elt

Marks the element that should be included in the browser history.

The hx-history-elt attribute specifies that this element’s innerHTML should be saved and restored when the user navigates through browser history.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // The main content area that should be saved in browser history
  div([hx.history_elt()], [
    text("This content will be saved in browser history")
  ]),
  
  // Navigation buttons
  button([hx.get("/page1"), hx.push_url(True)], [text("Page 1")]),
  button([hx.get("/page2"), hx.push_url(True)], [text("Page 2")])
])
pub fn hyper_script(script: String) -> Attribute(a)

Hyperscript integration (_)

Adds hyperscript to an element using the “_” attribute.

Hyperscript is a companion language for HTMX that allows you to add client-side interactivity with a concise, readable syntax.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // Toggle a class on click
  button([
    hx.hyper_script("on click toggle .active on me")
  ], [
    text("Toggle Active")
  ]),
  
  // Hide an element after a delay
  div([
    hx.hyper_script("on load wait 3s then add .hidden")
  ], [
    text("I will disappear in 3 seconds")
  ])
])
pub fn include(
  extended_css_selector: ExtendedCssSelector,
) -> Attribute(a)

hx-include

Includes additional elements in the AJAX request.

The hx-include attribute allows you to include values from other elements in the current request. This is useful for gathering data from multiple parts of a form.

Example

import lustre/element.{button, div, form, input, text}
import hx

div([], [
  form([id("search-form")], [
    input([type_("text"), name("query")], []),
    // Filter options outside the form
    div([id("filters")], [
      input([type_("checkbox"), name("filter1"), value("yes")], []),
      text("Include results from archive")
    ])
  ]),
  
  // This button includes both the form and the filters
  button([
    hx.get("/search"),
    hx.include(hx.CssSelector("#search-form, #filters"))
  ], [
    text("Search")
  ])
])
pub fn indicator(
  css_selector_or_closest css_selector_or_closest: String,
) -> Attribute(a)

hx-indicator

Shows elements during the AJAX request.

The hx-indicator attribute allows you to specify which element will have the htmx-request class during a request. This can be used to show spinners or loading indicators while the request is in progress.

Example

import lustre/element.{button, div, span, text}
import hx

// Show a loading indicator during request
div([hx.get("/data"), hx.indicator(".loading-indicator")], [
  span([class("loading-indicator")], [text("Loading...")]),
  button([], [text("Load Data")])
])
pub fn inherit(attributes: List(String)) -> Attribute(a)

hx-inherit

Explicitly specifies which attributes to inherit from ancestors.

The hx-inherit attribute is the opposite of hx-disinherit. It allows you to specify which HTMX attributes should be inherited from ancestor elements.

Example

import lustre/element.{button, div, text}
import hx

div([
  // Parent has multiple HTMX attributes
  hx.get("/parent-data"),
  hx.trigger([hx.Event(event: "click", modifiers: [])]),
  hx.swap(hx.OuterHTML, None)
], [
  // This button will only inherit the hx-trigger attribute
  button([
    hx.post("/button-action"),
    hx.inherit(["hx-trigger"])
  ], [
    text("Inherit Trigger Only")
  ])
])
pub fn inherit_all() -> Attribute(a)

hx-inherit (all attributes)

Explicitly inherits all attributes from ancestors.

The inherit_all function ensures that all HTMX attributes are inherited, which can be useful to override a previous hx-disinherit attribute.

Example

import lustre/element.{button, div, text}
import hx

div([
  // Block inheritance for all children
  hx.get("/parent-data"),
  hx.trigger([hx.Event(event: "click", modifiers: [])]),
  hx.disinherit_all()
], [
  // This button won't inherit any HTMX attributes
  button([hx.post("/action1")], [text("No Inheritance")]),
  
  // This button will force inheritance of all attributes
  button([
    hx.post("/action2"),
    hx.inherit_all()
  ], [
    text("Force Inheritance")
  ])
])
pub fn no_replace_url() -> Attribute(a)

hx-replace-url (disable)

Disables URL replacement for the request.

The no_replace_url function explicitly disables URL replacement, which can be useful to override an inherited behavior.

Example

import lustre/element.{button, div, text}
import hx

div([hx.replace_url()], [
  // This button will replace the URL (inherited from parent)
  button([hx.get("/view/1")], [text("View 1")]),
  
  // This button won't replace the URL
  button([
    hx.get("/view/2"),
    hx.no_replace_url()
  ], [
    text("View 2")
  ])
])
pub fn params(params: String) -> Attribute(a)

hx-params

Controls which parameters are submitted with a request.

The hx-params attribute allows you to filter which parameters should be submitted in an AJAX request, such as form fields.

Example

import lustre/element.{button, div, form, input, text}
import hx

div([], [
  form([id("user-form")], [
    input([type_("text"), name("username")], []),
    input([type_("password"), name("password")], []),
    input([type_("hidden"), name("csrf_token")], []),
    
    // Only send the username and csrf_token
    button([
      hx.post("/check-username"),
      hx.params("username,csrf_token")
    ], [
      text("Check Username")
    ]),
    
    // Send none of the form fields (only values from hx-vals would be sent)
    button([
      hx.post("/custom-action"),
      hx.params("none")
    ], [
      text("Custom Action")
    ]),
    
    // Send all except password
    button([
      hx.post("/save-profile"),
      hx.params("not password")
    ], [
      text("Save Profile")
    ])
  ])
])
pub fn patch(url url: String) -> Attribute(a)

hx-patch

Issues a PATCH request to the given URL when the element is triggered. By default, AJAX requests are triggered by the “natural” event of an element:

  • input, textarea & select are triggered on the change event
  • form is triggered on the submit event
  • everything else is triggered by the click event

If you want different behavior you can use the hx-trigger attribute, provided by lustre_hx.trigger, to specify which event will cause the request.

pub fn post(url url: String) -> Attribute(a)

hx-post

Issues a POST request to the given URL when the element is triggered. By default, AJAX requests are triggered by the “natural” event of an element:

  • input, textarea & select are triggered on the change event
  • form is triggered on the submit event
  • everything else is triggered by the click event

If you want different behavior you can use the hx-trigger attribute, provided by lustre_hx.trigger, to specify which event will cause the request.

pub fn preserve() -> Attribute(a)

hx-preserve

Preserves an element’s state between requests.

The hx-preserve attribute ensures that an element is not re-rendered when a parent element is re-rendered by HTMX. This is useful for preserving input values, scroll positions, etc.

Example

import lustre/element.{button, div, input, text, textarea}
import hx

div([id("form-container")], [
  // This textarea will keep its content even when the parent is refreshed
  textarea([hx.preserve()], []),
  
  // This will also keep its current input value
  input([type_("text"), name("name"), hx.preserve()], []),
  
  // This button refreshes the parent container
  button([
    hx.get("/refresh-form"),
    hx.target(hx.CssSelector("#form-container"))
  ], [
    text("Refresh Form")
  ])
])
pub fn prompt(prompt_text: String) -> Attribute(a)

hx-prompt

Displays a prompt before submitting a request.

The hx-prompt attribute shows a prompt dialog that asks for user input before making the AJAX request. The prompt value is included in the request.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // Ask for a comment when deleting
  button([
    hx.delete("/items/123"),
    hx.prompt("Please provide a reason for deletion:")
  ], [
    text("Delete Item")
  ])
])
pub fn push_url(bool: Bool) -> Attribute(a)

hx-push-url

Pushes a URL into the browser’s location bar.

The hx-push-url attribute allows you to update the browser’s URL without causing a full page reload. This is useful for maintaining proper history navigation and bookmarkable URLs with AJAX.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // Push URL to browser history
  button([
    hx.get("/products/123"), 
    hx.push_url(True)
  ], [
    text("View Product")
  ]),
  
  // Don't push URL (useful for background updates)
  button([
    hx.get("/refresh-status"), 
    hx.push_url(False)
  ], [
    text("Refresh Status")
  ])
])
pub fn put(url url: String) -> Attribute(a)

hx-put

Issues a PUT request to the given URL when the element is triggered. By default, AJAX requests are triggered by the “natural” event of an element:

  • input, textarea & select are triggered on the change event
  • form is triggered on the submit event
  • everything else is triggered by the click event

If you want different behavior you can use the hx-trigger attribute, provided by lustre_hx.trigger, to specify which event will cause the request.

pub fn replace_url() -> Attribute(a)

hx-replace-url (enable)

Replaces the current URL after the request completes.

The replace_url function enables URL replacement, which is useful for single-page applications to update the browser’s address bar without adding a history entry.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // Replace the URL without adding to history
  button([
    hx.get("/view/123"),
    hx.replace_url()
  ], [
    text("View Item")
  ])
])
pub fn replace_url_with(url: String) -> Attribute(a)

hx-replace-url (with URL)

Replaces the current URL with a specified one.

The replace_url_with function allows you to specify a different URL to put in the browser’s address bar than the one that was requested.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // Use a different URL in the address bar than the API endpoint
  button([
    hx.post("/api/items/add"),
    hx.replace_url_with("/items")
  ], [
    text("Add Item")
  ])
])
pub fn request(request: String) -> Attribute(a)

hx-request

Configures various aspects of the AJAX request.

The hx-request attribute allows you to configure various aspects of the AJAX request using a simple JSON-like syntax.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // Configure timeout and show progress
  button([
    hx.get("/api/long-process"),
    hx.request("{timeout:10000, showProgress:true}")
  ], [
    text("Start Long Process")
  ]),
  
  // Configure to not process responses
  button([
    hx.post("/api/fire-and-forget"),
    hx.request("{noHeaders:true, ignoreTitle:true}")
  ], [
    text("Send Notification")
  ])
])
pub fn select(css_selector: String) -> Attribute(a)

hx-select

Selects a subset of the server response to process.

The hx-select attribute allows you to select a specific part of the server response for swapping, using CSS selectors. This is useful when you want to extract only a portion of a larger HTML response.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // Select only the div with id "content" from the response
  button([
    hx.get("/page"), 
    hx.select("#content")
  ], [
    text("Load Content Only")
  ]),
  
  // Select elements matching a class
  button([
    hx.get("/items"), 
    hx.select(".item")
  ], [
    text("Load Items")
  ])
])
pub fn select_oob(
  css_selector: String,
  swap_strategies: List(Swap),
) -> Attribute(a)

Out-of-band selection

Selects content from a response to be swapped in to the current page.

The select_oob function allows you to process multiple pieces of content from a response, selecting them with different CSS selectors and applying different swap strategies.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // Basic select with no swap strategies
  button([
    hx.get("/update"),
    hx.select_oob(".status", [])
  ], [
    text("Update Status")
  ]),
  
  // With a single swap strategy
  button([
    hx.get("/update-card"),
    hx.select_oob(".card-content", [hx.InnerHTML])
  ], [
    text("Update Card Content")
  ]),
  
  // With multiple swap strategies
  button([
    hx.get("/update-multiple"),
    hx.select_oob(".data", [hx.OuterHTML, hx.After, hx.Delete])
  ], [
    text("Complex Update")
  ])
])
pub fn swap(
  swap swap: Swap,
  with_option option: Option(SwapOption),
) -> Attribute(a)

hx-swap

Controls how content is swapped into the DOM.

The hx-swap attribute allows you to specify how the response will be swapped relative to the target. You can control the swap method (innerHTML, outerHTML, etc.) and additional options through modifiers.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // Basic swap using innerHTML (default)
  button([hx.get("/content"), hx.swap(hx.InnerHTML, None)], [
    text("Load Content")
  ]),
  
  // Using outerHTML with transition
  button([hx.get("/replace"), hx.swap(hx.OuterHTML, Some(hx.Transition(True)))], [
    text("Replace Completely")
  ]),
  
  // Add content after the target with a timing modifier
  button([hx.get("/append"), hx.swap(hx.After, Some(hx.Swap(hx.Milliseconds(500))))], [
    text("Append Slowly")
  ]),
  
  // Add content and scroll to top
  button([hx.get("/more"), hx.swap(hx.Beforeend, Some(hx.Scroll(hx.Top)))], [
    text("Load More and Scroll")
  ])
])
pub fn swap_oob(
  swap swap: Swap,
  with_css_selector css_selector: Option(String),
  with_modifier modifier: Option(SwapOption),
) -> Attribute(a)

hx-swap-oob

Allows you to specify that some content in a response should be swapped “out of band” (somewhere other than the target).

This is useful for updating multiple parts of the page with a single request. Combines with the hx-select-oob attribute.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // Basic out-of-band swap
  button([
    hx.get("/update-multiple"),
    hx.swap_oob(swap: hx.InnerHTML, with_css_selector: None, with_modifier: None)
  ], [
    text("Update Multiple Elements")
  ]),
  
  // With CSS selector targeting
  button([
    hx.get("/update-status"),
    hx.swap_oob(swap: hx.InnerHTML, with_css_selector: Some("#status"), with_modifier: None)
  ], [
    text("Update Status")
  ]),
  
  // With both CSS selector and modifier
  button([
    hx.get("/update-content"),
    hx.swap_oob(
      swap: hx.Beforeend, 
      with_css_selector: Some("#log"), 
      with_modifier: Some(hx.Scroll(hx.Bottom))
    )
  ], [
    text("Add To Log")
  ]),
  
  div([id("status")], [text("Status: Ready")]),
  div([id("log")], [])
])
pub fn sync(syncronize_on: List(SyncOption)) -> Attribute(a)

hx-sync

Synchronizes AJAX requests with other elements.

The hx-sync attribute allows you to coordinate AJAX requests so that they do not all fire at once or in a way that might confuse the user or overwhelm the server. You can specify different sync options to control request behavior.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // Default sync option with a form
  button([
    hx.get("/data"), 
    hx.sync([hx.Default("#myForm")])
  ], [
    text("Synchronized with form")
  ]),
  
  // Drop previous requests
  button([
    hx.get("/api/search"), 
    hx.sync([hx.Drop("#searchForm")])
  ], [
    text("New search cancels previous")
  ]),
  
  // Queue requests
  button([
    hx.post("/api/queue"), 
    hx.sync([hx.SyncQueue("#queueTarget", hx.First)])
  ], [
    text("Queue (first)")
  ]),
  
  // Multiple sync options
  button([
    hx.post("/api/complex"), 
    hx.sync([hx.Drop("#form1"), hx.SyncQueue("#form2", hx.Last)])
  ], [
    text("Complex sync")
  ])
])
pub fn target(
  extended_css_selector extended_css_selector: ExtendedCssSelector,
) -> Attribute(a)

hx-target

Specifies the target element to swap content into.

By default, htmx swaps content into the element that triggered the request. The hx-target attribute allows you to target a different element for content swapping.

Example

import lustre/element.{button, div, text}
import hx

div([], [
  // Target a specific element with ID
  button([hx.get("/data"), hx.target(hx.CssSelector("#result"))], [
    text("Load Data")
  ]),
  
  // Using 'this' to target the element itself
  button([hx.get("/status"), hx.target(hx.This)], [
    text("Check Status")
  ]),
  
  // Using 'closest' to target a parent element
  div([class("card")], [
    button([hx.get("/content"), hx.target(hx.Closest(".card"))], [
      text("Refresh Card")
    ])
  ]),
  
  div([id("result")], [])
])
pub fn trigger(events: List(Event)) -> Attribute(a)

hx-trigger

By default, AJAX requests are triggered by the “natural” event of an element:

  • input, textarea & select are triggered on the change event
  • form is triggered on the submit event
  • everything else is triggered by the click event

If you want different behavior you can use the hx-trigger attribute to specify which event will cause the request.

pub fn trigger_load_polling(
  timing timing: Timing,
  filters filters: String,
) -> Attribute(a)

Load with polling trigger

Creates an attribute that triggers a request on page load and then continues on a polling basis.

  • timing specifies how frequently the polling should occur (Seconds or Milliseconds)
  • filters conditions that can filter when the polling is active (required)

Example

// Poll every 5 seconds while the element is visible
hx.trigger_load_polling(timing: hx.Seconds(5), filters: "when_visible")

// Poll every 2 seconds while a condition is met
hx.trigger_load_polling(timing: hx.Seconds(2), filters: "this.getAttribute('data-ready') === 'true'")
pub fn trigger_polling(
  timing timing: Timing,
  filters filters: Option(String),
) -> Attribute(a)

Polling trigger

Creates an attribute that triggers a request on a polling basis.

  • timing specifies how frequently the polling should occur (Seconds or Milliseconds)
  • filters optional conditions that can filter when the polling is active

Examples

// Simple polling every 5 seconds
hx.trigger_polling(timing: hx.Seconds(5), filters: None)

// Polling with a condition - only poll when element is visible
hx.trigger_polling(timing: hx.Seconds(10), filters: Some("intersect"))

// Polling with a custom condition
hx.trigger_polling(timing: hx.Milliseconds(500), filters: Some("this.value.length > 3"))
pub fn validate(bool: Bool) -> Attribute(a)

hx-validate

Controls whether form validation should occur before a request.

The hx-validate attribute determines whether HTML5 validation should occur on form inputs before a request is sent.

Example

import lustre/element.{button, div, form, input, text}
import hx

div([], [
  form([], [
    input([type_("email"), required(True), name("email")], []),
    
    // This will validate the email field
    button([
      hx.post("/api/subscribe"),
      hx.validate(True)
    ], [
      text("Subscribe (with validation)")
    ]),
    
    // This will skip validation
    button([
      hx.post("/api/quick-subscribe"),
      hx.validate(False)
    ], [
      text("Quick Subscribe")
    ])
  ])
])
pub fn vals(json: Json, compute_value: Bool) -> Attribute(a)

hx-vals

Sets values to be included in requests.

The hx-vals attribute allows you to add additional values to an AJAX request. This is useful for including data that isn’t part of a form.

Example

import gleam/json
import lustre/element.{button, div, text}
import hx

div([], [
  // Add static JSON values to the request
  button([
    hx.get("/api/fetch"), 
    hx.vals(
      json.object([
        #("user_id", json.string("123")), 
        #("version", json.number(2.0))
      ]),
      False
    )
  ], [
    text("Fetch Data")
  ]),
  
  // Use JavaScript to compute values at runtime
  button([
    hx.post("/api/save"), 
    hx.vals(
      json.object([
        #("timestamp", json.string("now"))
      ]),
      True
    )
  ], [
    text("Save with Timestamp")
  ])
])
Search Document