@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
JavaScript
'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;