@still-ui/accordion
Version:
Highly customizable and accessible Accordion component.
270 lines (262 loc) • 9.15 kB
JavaScript
"use client";
"use strict";
var __create = Object.create;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getProtoOf = Object.getPrototypeOf;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
// If the importer is in node compatibility mode or this is not an ESM
// file that has been converted to a CommonJS file using a Babel-
// compatible transform (i.e. "__esModule" has not been set), then set
// "default" to the CommonJS "module.exports" for node compatibility.
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
mod
));
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
// src/index.ts
var src_exports = {};
__export(src_exports, {
AccordionContent: () => AccordionContent_default,
AccordionItem: () => AccordionItem_default,
AccordionRoot: () => AccordionRoot_default,
AccordionTrigger: () => AccordionTrigger_default
});
module.exports = __toCommonJS(src_exports);
// src/AccordionRoot.tsx
var import_react_accordion = require("@radix-ui/react-accordion");
// src/hooks/AccordionContext.ts
var import_react = require("react");
var AccordionContext = (0, import_react.createContext)({});
// src/AccordionRoot.tsx
var import_tailwind_variants = require("tailwind-variants");
var import_react2 = __toESM(require("react"), 1);
var import_jsx_runtime = require("react/jsx-runtime");
var root = (0, import_tailwind_variants.tv)({
variants: {
splitted: {
true: "flex flex-col gap-4 border-0 p-0 shadow-none"
},
bordered: {
true: "rounded-md border border-slate-200 p-3 shadow-md shadow-slate-100"
},
ui: {
brutal: "rounded-lg",
glassmorphic: "before:absolute before:-right-4 before:-top-4 before:-z-10 before:block before:h-36 before:w-36 before:rounded-full before:bg-sky-500 after:absolute after:-bottom-4 after:-left-4 after:-z-10 after:block after:h-36 after:w-36 after:rounded-full after:bg-sky-800",
neumorphic: "rounded-md bg-slate-100 shadow-[-20px_20px_41px_#9ca3af,20px_-20px_41px_#ffffff]"
}
},
compoundVariants: [
{
splitted: void 0,
ui: "brutal",
class: "z-10 bg-white outline outline-2 outline-black drop-shadow-[4px_6px_#000]"
},
{
splitted: true,
ui: "brutal",
class: "gap-6"
},
{
splitted: void 0,
bordered: true,
ui: "brutal",
class: "rounded-lg shadow-none"
},
{
splitted: true,
bordered: true,
ui: "brutal",
class: "rounded-2xl p-5"
},
{
splitted: void 0,
ui: "glassmorphic",
class: "rounded-md border border-white shadow-[0_4px_30px_rgba(0,0,0,0.1)]"
},
{
bordered: true,
ui: "glassmorphic",
class: "rounded-md border-white p-0 shadow-none"
},
{
splitted: true,
ui: "neumorphic",
class: "bg-initial shadow-none"
}
]
});
var AccordionRoot = import_react2.default.forwardRef(({ bordered, children, className, splitted, ui, ...props }, ref) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
import_react_accordion.Root,
{
ref,
...props,
className: root({
splitted,
bordered,
ui,
class: className
}),
children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(AccordionContext.Provider, { value: { splitted, bordered, ui }, children })
}
));
var AccordionRoot_default = AccordionRoot;
// src/AccordionItem.tsx
var import_react3 = require("react");
var import_tailwind_variants2 = require("tailwind-variants");
var import_react4 = __toESM(require("react"), 1);
var import_react_accordion2 = require("@radix-ui/react-accordion");
var import_jsx_runtime2 = require("react/jsx-runtime");
var item = (0, import_tailwind_variants2.tv)({
base: "group border-b border-b-slate-200 last:border-0",
variants: {
splitted: {
true: "rounded border border-slate-200 shadow-md last:border"
},
ui: {
brutal: "",
glassmorphic: "",
neumorphic: ""
}
},
compoundVariants: [
{
splitted: true,
ui: void 0,
class: "shadow-slate-100"
},
{
splitted: true,
ui: "brutal",
class: "rounded-2xl border-0 bg-white shadow-none outline outline-2 outline-black drop-shadow-[4px_6px_#000] last:border-0"
},
{
splitted: void 0,
ui: "brutal",
class: "border-black"
},
{
ui: "glassmorphic",
class: "border-slate-300 bg-white/50 backdrop-blur-md"
},
{
ui: "glassmorphic",
splitted: true,
class: "shadow-none"
},
{
splitted: true,
ui: "neumorphic",
class: "border-0 shadow-[-5px_5px_20px_#9ca3af,5px_-5px_20px_#ffffff]"
}
]
});
var AccordionItem = import_react4.default.forwardRef(({ className, ...props }, ref) => {
const { splitted, ui } = (0, import_react3.useContext)(AccordionContext);
return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
import_react_accordion2.Item,
{
ref,
className: item({ splitted, ui, class: className }),
...props
}
);
});
var AccordionItem_default = AccordionItem;
// src/AccordionTrigger.tsx
var import_react_accordion3 = require("@radix-ui/react-accordion");
var import_react5 = require("react");
var import_tailwind_variants3 = require("tailwind-variants");
var import_react_icons = require("@radix-ui/react-icons");
var import_react6 = __toESM(require("react"), 1);
var import_jsx_runtime3 = require("react/jsx-runtime");
var trigger = (0, import_tailwind_variants3.tv)({
slots: {
wrapper: "group flex w-full items-center justify-between gap-4 p-4 text-left",
innerWrapper: "flex flex-col gap-1",
tvTitle: "text-base",
tvSubtitle: "text-xs",
tvIcon: "transition-transform group-data-[state=open]:rotate-180"
},
variants: {
ui: {
brutal: "",
glassmorphic: {
wrapper: "bg-white/50 backdrop-blur-md"
},
neumorphic: ""
},
splitted: {
true: { wrapper: "p-6" }
}
}
});
var { wrapper, innerWrapper, tvTitle, tvSubtitle, tvIcon } = trigger();
var AccordionTrigger = import_react6.default.forwardRef(({ className, icon, subtitle, title, ...props }, ref) => {
const { splitted, ui } = (0, import_react5.useContext)(AccordionContext);
return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_react_accordion3.AccordionHeader, { children: /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(
import_react_accordion3.AccordionTrigger,
{
ref,
className: wrapper({ class: className, ui, splitted }),
...props,
children: [
/* @__PURE__ */ (0, import_jsx_runtime3.jsxs)("div", { className: innerWrapper(), children: [
/* @__PURE__ */ (0, import_jsx_runtime3.jsx)("span", { className: tvTitle(), children: title }),
/* @__PURE__ */ (0, import_jsx_runtime3.jsx)("span", { className: tvSubtitle(), children: subtitle })
] }),
icon ? icon : /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_react_icons.ChevronDownIcon, { className: tvIcon() })
]
}
) });
});
var AccordionTrigger_default = AccordionTrigger;
// src/AccordionContent.tsx
var import_react_accordion4 = require("@radix-ui/react-accordion");
var import_react7 = require("react");
var import_tailwind_variants4 = require("tailwind-variants");
var import_react8 = __toESM(require("react"), 1);
var import_jsx_runtime4 = require("react/jsx-runtime");
var content = (0, import_tailwind_variants4.tv)({
base: "data-[state=open]:animate-slideDown data-[state=closed]:animate-slideUp overflow-hidden px-4 pb-0 text-justify text-sm",
variants: {
ui: {
brutal: "",
glassmorphic: "bg-white/50 backdrop-blur-md",
neumorphic: ""
}
}
});
var AccordionContent = import_react8.default.forwardRef(({ children, className, ...props }, ref) => {
const options = (0, import_react7.useContext)(AccordionContext);
return /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
import_react_accordion4.Content,
{
className: content({ class: className, ui: options.ui }),
ref,
...props,
children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("p", { className: "pb-4", children })
}
);
});
var AccordionContent_default = AccordionContent;
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
AccordionContent,
AccordionItem,
AccordionRoot,
AccordionTrigger
});