{
  "name": "DatePicker",
  "package": "@magicblocksai/ui",
  "file": "packages/ui/src/components/DatePicker.tsx",
  "chapterTag": "04 Forms & Inputs",
  "chapter": "05-forms-and-inputs.html",
  "sectionId": "date-picker",
  "elName": "DatePicker",
  "demoUrl": "https://brand.magicblocks.ai/components/05-forms-and-inputs#date-picker",
  "hasLiveDemo": false,
  "description": "Single-date picker — trigger button shows the formatted date; a popover\nwith a single-month calendar opens on click. Keyboard: arrow keys\nnavigate days, Enter selects, Esc closes.",
  "useClient": true,
  "interactivity": "interactive",
  "namedExports": [
    {
      "name": "DatePicker",
      "isPrincipal": true,
      "isType": false
    },
    {
      "name": "DatePickerProps",
      "isPrincipal": false,
      "isType": true
    }
  ],
  "importStatement": "import { DatePicker } from \"@magicblocksai/ui\";",
  "props": [
    {
      "name": "value",
      "optional": false,
      "type": "Date | null",
      "doc": "Currently selected date."
    },
    {
      "name": "onChange",
      "optional": false,
      "type": "(next: Date | null) => void",
      "doc": "Fires whenever the user picks a new date."
    },
    {
      "name": "minDate",
      "optional": true,
      "type": "Date",
      "doc": "Earliest selectable date."
    },
    {
      "name": "maxDate",
      "optional": true,
      "type": "Date",
      "doc": "Latest selectable date."
    },
    {
      "name": "locale",
      "optional": true,
      "type": "string",
      "doc": "Locale for the date format and the month/weekday labels."
    },
    {
      "name": "placeholder",
      "optional": true,
      "type": "string",
      "doc": "Trigger placeholder when no date is selected. Default `\"Pick a date\"`."
    },
    {
      "name": "align",
      "optional": true,
      "type": "\"start\" | \"end\"",
      "doc": "Where the popover aligns relative to the trigger. Default `\"start\"`."
    },
    {
      "name": "disabled",
      "optional": true,
      "type": "boolean",
      "doc": "Disable the trigger."
    },
    {
      "name": "ariaLabel",
      "optional": true,
      "type": "string",
      "doc": "Optional aria-label for the trigger button."
    }
  ],
  "classesUsed": [
    "date-picker",
    "date-picker-placeholder",
    "date-picker-popover",
    "date-picker-trigger",
    "date-picker-trigger-ic",
    "input",
    "popover"
  ],
  "examples": {
    "react": "const [date, setDate] = useState<Date | null>(null);\n  <DatePicker value={date} onChange={setDate} />",
    "html": "<div class=\"date-picker\">\n  <button type=\"button\" class=\"date-picker-trigger input\" aria-haspopup=\"dialog\" aria-expanded=\"false\">\n    <span class=\"date-picker-placeholder\">Pick a date</span>\n    <span aria-hidden=\"true\" class=\"date-picker-trigger-ic\">▾</span>\n  </button>\n</div>",
    "css": ".date-picker {\n  display: inline-flex;\n  flex-direction: column;\n  font-family: var(--f-body);\n}\n\n.date-picker-placeholder { color: var(--fg-faint); }\n\n.date-picker-popover {\n  padding: var(--s-3);\n  min-width: 280px;\n}\n\n.date-picker-trigger {\n  display: inline-flex;\n  align-items: center;\n  justify-content: space-between;\n  gap: var(--s-3);\n  cursor: pointer;\n  background: var(--bg-paper);\n  text-align: left;\n  min-width: 200px;\n}\n\n.date-picker-trigger-ic {\n  font-size: 10px;\n  color: var(--fg-faint);\n}\n\n.input {\n  display: block; width: 100%;\n  font: 400 14.5px/1.4 var(--f-body);\n  color: var(--fg);\n  background: var(--bg-paper);\n  border: 1px solid var(--hair);\n  border-radius: var(--r-sm);\n  padding: 10px 14px;\n  transition: border-color var(--dur-2) var(--ease),\n              box-shadow var(--dur-2) var(--ease);\n  appearance: none; -webkit-appearance: none; -moz-appearance: none;\n}\n\n.popover {\n  position: relative;\n  width: 320px;\n  background: var(--bg-paper);\n  border: 1px solid var(--hair);\n  border-radius: var(--r-md);\n  padding: var(--s-4);\n  box-shadow: var(--sh-3);\n}"
  }
}
