Skip to main content
userTourKit
@tour-kit/announcementsHeadless

HeadlessModal

HeadlessAnnouncementModal: unstyled dialog primitive with focus trap, backdrop click, and Escape key dismiss handling

domidex01Published

Unstyled modal component that provides state and behavior through render props.

Render Props

Prop

Type

Example

import { HeadlessModal } from '@tour-kit/announcements/headless';

<HeadlessModal
  id="welcome"
  render={({ isVisible, config, hide, dismiss, titleId, descriptionId }) => {
    if (!isVisible) return null;

    return (
      <div className="modal-container">
        <div className="overlay" onClick={hide} />
        <div
          role="dialog"
          aria-modal="true"
          aria-labelledby={titleId}
          aria-describedby={descriptionId}
          className="modal-content"
        >
          <h2 id={titleId}>{config.title}</h2>
          <p id={descriptionId}>{config.description}</p>
          <button onClick={hide}>Close</button>
          <button onClick={() => dismiss()}>Don't Show Again</button>
        </div>
      </div>
    );
  }}
/>
Free & open source

Ship onboarding, not config.

npm i @tour-kit/core is MIT and free. The Pro packages work unlicensed too — a one-time $99 license removes the production watermark when you ship.

MIT-licensed — no signup, no credit card. Pay once, only when you ship.