Mats Bosson 92435b2667 Wizard component
17 tests passing. Implements WizardRoot, WizardStep, WizardStepList, WizardStepTrigger, WizardStepContent, WizardPrev, WizardNext with createControllableSignal step state, completedSteps Set, registerStep/unregisterStep registration, linear guard on triggers, onComplete callback, and Object.assign compound export.
2026-03-29 21:15:55 +07:00

31 lines
985 B
TypeScript

import type { JSX } from "solid-js";
import { splitProps } from "solid-js";
import { useWizardContext } from "./wizard-context";
import type { WizardNextProps } from "./wizard.props";
/** Button that marks the current step complete and advances to the next step. */
export function WizardNext(props: WizardNextProps): JSX.Element {
const [local, rest] = splitProps(props, ["children", "onClick", "disabled"]);
const ctx = useWizardContext();
const isLast = () => ctx.currentStep() === ctx.totalSteps() - 1;
const isDisabled = () => local.disabled ?? false;
const handleClick: JSX.EventHandler<HTMLButtonElement, MouseEvent> = (e) => {
if (typeof local.onClick === "function") local.onClick(e);
if (!isDisabled()) ctx.goToNext();
};
return (
<button
type="button"
disabled={isDisabled() || undefined}
data-state={isLast() ? "last" : "default"}
onClick={handleClick}
{...rest}
>
{local.children}
</button>
);
}