UNPKG

@llamaindex/ui

Version:

A comprehensive UI component library built with React, TypeScript, and Tailwind CSS for LlamaIndex applications

219 lines (213 loc) 9.72 kB
'use strict'; var chunk64FRNQ3S_js = require('./chunk-64FRNQ3S.js'); var chunkHK7TFVDA_js = require('./chunk-HK7TFVDA.js'); var chunkORMEWXMH_js = require('./chunk-ORMEWXMH.js'); var React = require('react'); var lucideReact = require('lucide-react'); var reactDayPicker = require('react-day-picker'); var jsxRuntime = require('react/jsx-runtime'); function _interopNamespace(e) { if (e && e.__esModule) return e; var n = Object.create(null); if (e) { Object.keys(e).forEach(function (k) { if (k !== 'default') { var d = Object.getOwnPropertyDescriptor(e, k); Object.defineProperty(n, k, d.get ? d : { enumerable: true, get: function () { return e[k]; } }); } }); } n.default = e; return Object.freeze(n); } var React__namespace = /*#__PURE__*/_interopNamespace(React); function Calendar(_a) { var _b = _a, { className, classNames, showOutsideDays = true, captionLayout = "label", buttonVariant = "ghost", formatters, components } = _b, props = chunkORMEWXMH_js.__objRest(_b, [ "className", "classNames", "showOutsideDays", "captionLayout", "buttonVariant", "formatters", "components" ]); const defaultClassNames = reactDayPicker.getDefaultClassNames(); return /* @__PURE__ */ jsxRuntime.jsx( reactDayPicker.DayPicker, chunkORMEWXMH_js.__spreadValues({ showOutsideDays, className: chunkHK7TFVDA_js.cn( "bg-background group/calendar p-3 [--cell-size:--spacing(8)] [[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent", String.raw`rtl:**:[.rdp-button\_next>svg]:rotate-180`, String.raw`rtl:**:[.rdp-button\_previous>svg]:rotate-180`, className ), captionLayout, formatters: chunkORMEWXMH_js.__spreadValues({ formatMonthDropdown: (date) => date.toLocaleString("default", { month: "short" }) }, formatters), classNames: chunkORMEWXMH_js.__spreadValues({ root: chunkHK7TFVDA_js.cn("w-fit", defaultClassNames.root), months: chunkHK7TFVDA_js.cn( "flex gap-4 flex-col md:flex-row relative", defaultClassNames.months ), month: chunkHK7TFVDA_js.cn("flex flex-col w-full gap-4", defaultClassNames.month), nav: chunkHK7TFVDA_js.cn( "flex items-center gap-1 w-full absolute top-0 inset-x-0 justify-between", defaultClassNames.nav ), button_previous: chunkHK7TFVDA_js.cn( chunk64FRNQ3S_js.buttonVariants({ variant: buttonVariant }), "size-(--cell-size) aria-disabled:opacity-50 p-0 select-none", defaultClassNames.button_previous ), button_next: chunkHK7TFVDA_js.cn( chunk64FRNQ3S_js.buttonVariants({ variant: buttonVariant }), "size-(--cell-size) aria-disabled:opacity-50 p-0 select-none", defaultClassNames.button_next ), month_caption: chunkHK7TFVDA_js.cn( "flex items-center justify-center h-(--cell-size) w-full px-(--cell-size)", defaultClassNames.month_caption ), dropdowns: chunkHK7TFVDA_js.cn( "w-full flex items-center text-sm font-medium justify-center h-(--cell-size) gap-1.5", defaultClassNames.dropdowns ), dropdown_root: chunkHK7TFVDA_js.cn( "relative has-focus:border-ring border border-input shadow-xs has-focus:ring-ring/50 has-focus:ring-[3px] rounded-md", defaultClassNames.dropdown_root ), dropdown: chunkHK7TFVDA_js.cn( "absolute bg-popover inset-0 opacity-0", defaultClassNames.dropdown ), caption_label: chunkHK7TFVDA_js.cn( "select-none font-medium", captionLayout === "label" ? "text-sm" : "rounded-md pl-2 pr-1 flex items-center gap-1 text-sm h-8 [&>svg]:text-muted-foreground [&>svg]:size-3.5", defaultClassNames.caption_label ), table: "w-full border-collapse", weekdays: chunkHK7TFVDA_js.cn("flex", defaultClassNames.weekdays), weekday: chunkHK7TFVDA_js.cn( "text-muted-foreground rounded-md flex-1 font-normal text-[0.8rem] select-none", defaultClassNames.weekday ), week: chunkHK7TFVDA_js.cn("flex w-full mt-2", defaultClassNames.week), week_number_header: chunkHK7TFVDA_js.cn( "select-none w-(--cell-size)", defaultClassNames.week_number_header ), week_number: chunkHK7TFVDA_js.cn( "text-[0.8rem] select-none text-muted-foreground", defaultClassNames.week_number ), day: chunkHK7TFVDA_js.cn( "relative w-full h-full p-0 text-center [&:first-child[data-selected=true]_button]:rounded-l-md [&:last-child[data-selected=true]_button]:rounded-r-md group/day aspect-square select-none", defaultClassNames.day ), range_start: chunkHK7TFVDA_js.cn( "rounded-l-md bg-accent", defaultClassNames.range_start ), range_middle: chunkHK7TFVDA_js.cn("rounded-none", defaultClassNames.range_middle), range_end: chunkHK7TFVDA_js.cn("rounded-r-md bg-accent", defaultClassNames.range_end), today: chunkHK7TFVDA_js.cn( "bg-accent text-accent-foreground rounded-md data-[selected=true]:rounded-none", defaultClassNames.today ), outside: chunkHK7TFVDA_js.cn( "text-muted-foreground aria-selected:text-muted-foreground", defaultClassNames.outside ), disabled: chunkHK7TFVDA_js.cn( "text-muted-foreground opacity-50", defaultClassNames.disabled ), hidden: chunkHK7TFVDA_js.cn("invisible", defaultClassNames.hidden) }, classNames), components: chunkORMEWXMH_js.__spreadValues({ Root: (_a2) => { var _b2 = _a2, { className: className2, rootRef } = _b2, props2 = chunkORMEWXMH_js.__objRest(_b2, ["className", "rootRef"]); return /* @__PURE__ */ jsxRuntime.jsx( "div", chunkORMEWXMH_js.__spreadValues({ "data-slot": "calendar", ref: rootRef, className: chunkHK7TFVDA_js.cn(className2) }, props2) ); }, Chevron: (_c) => { var _d = _c, { className: className2, orientation } = _d, props2 = chunkORMEWXMH_js.__objRest(_d, ["className", "orientation"]); if (orientation === "left") { return /* @__PURE__ */ jsxRuntime.jsx(lucideReact.ChevronLeftIcon, chunkORMEWXMH_js.__spreadValues({ className: chunkHK7TFVDA_js.cn("size-4", className2) }, props2)); } if (orientation === "right") { return /* @__PURE__ */ jsxRuntime.jsx( lucideReact.ChevronRightIcon, chunkORMEWXMH_js.__spreadValues({ className: chunkHK7TFVDA_js.cn("size-4", className2) }, props2) ); } return /* @__PURE__ */ jsxRuntime.jsx(lucideReact.ChevronDownIcon, chunkORMEWXMH_js.__spreadValues({ className: chunkHK7TFVDA_js.cn("size-4", className2) }, props2)); }, DayButton: CalendarDayButton, WeekNumber: (_e) => { var _f = _e, { children } = _f, props2 = chunkORMEWXMH_js.__objRest(_f, ["children"]); return /* @__PURE__ */ jsxRuntime.jsx("td", chunkORMEWXMH_js.__spreadProps(chunkORMEWXMH_js.__spreadValues({}, props2), { children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: "flex size-(--cell-size) items-center justify-center text-center", children }) })); } }, components) }, props) ); } function CalendarDayButton(_a) { var _b = _a, { className, day, modifiers } = _b, props = chunkORMEWXMH_js.__objRest(_b, [ "className", "day", "modifiers" ]); const defaultClassNames = reactDayPicker.getDefaultClassNames(); const ref = React__namespace.useRef(null); React__namespace.useEffect(() => { var _a2; if (modifiers.focused) (_a2 = ref.current) == null ? void 0 : _a2.focus(); }, [modifiers.focused]); return /* @__PURE__ */ jsxRuntime.jsx( chunk64FRNQ3S_js.Button, chunkORMEWXMH_js.__spreadValues({ ref, variant: "ghost", size: "icon", "data-day": day.date.toLocaleDateString(), "data-selected-single": modifiers.selected && !modifiers.range_start && !modifiers.range_end && !modifiers.range_middle, "data-range-start": modifiers.range_start, "data-range-end": modifiers.range_end, "data-range-middle": modifiers.range_middle, className: chunkHK7TFVDA_js.cn( "data-[selected-single=true]:bg-primary data-[selected-single=true]:text-primary-foreground data-[range-middle=true]:bg-accent data-[range-middle=true]:text-accent-foreground data-[range-start=true]:bg-primary data-[range-start=true]:text-primary-foreground data-[range-end=true]:bg-primary data-[range-end=true]:text-primary-foreground group-data-[focused=true]/day:border-ring group-data-[focused=true]/day:ring-ring/50 dark:hover:text-accent-foreground flex aspect-square size-auto w-full min-w-(--cell-size) flex-col gap-1 leading-none font-normal group-data-[focused=true]/day:relative group-data-[focused=true]/day:z-10 group-data-[focused=true]/day:ring-[3px] data-[range-end=true]:rounded-md data-[range-end=true]:rounded-r-md data-[range-middle=true]:rounded-none data-[range-start=true]:rounded-md data-[range-start=true]:rounded-l-md [&>span]:text-xs [&>span]:opacity-70", defaultClassNames.day, className ) }, props) ); } exports.Calendar = Calendar; exports.CalendarDayButton = CalendarDayButton;