UNPKG

@kloudlite/design-system

Version:

A design system for building ambitious products.

189 lines (185 loc) 6.37 kB
"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); // components/organisms/side-bar.tsx var side_bar_exports = {}; __export(side_bar_exports, { default: () => side_bar_default }); module.exports = __toCommonJS(side_bar_exports); var import_react2 = require("react"); var import_framer_motion = require("framer-motion"); // components/utils.tsx var import_classnames = __toESM(require("classnames"), 1); var import_react = require("react"); var import_uuid = require("uuid"); var cn = (...props) => { return (0, import_classnames.default)(...props); }; // components/organisms/side-bar.tsx var import_jsx_runtime = require("react/jsx-runtime"); var Item = ({ children, active, icon, to, ...props }) => { const { linkComponent: LinkComponent = "div", toLabel = "href" } = props; let p = {}; if (LinkComponent !== "div") { p = { [toLabel]: to }; } return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)( LinkComponent, { ...p, className: cn( "kl-cursor-pointer kl-px-3xl kl-py-[10px] kl-min-h-[40px] kl-bodyMd kl-text-text-default hover:kl-bg-surface-basic-hovered kl-flex kl-flex-row kl-items-center kl-gap-lg kl-flex-shrink-0", active ? "kl-bg-surface-basic-pressed" : "" ), children: [ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { children: icon && (0, import_react2.cloneElement)(icon, { size: 16 }) }), /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_framer_motion.motion.div, { className: "kl-overflow-hidden", children }) ] } ); }; var Separator = () => { return /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: "kl-bg-border-default kl-h-xs kl-w-full" }); }; var Header = ({ children }) => { return /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: "kl-h-[60px] kl-p-2xl kl-border-b kl-border-b-border-default kl-flex kl-flex-row kl-items-center kl-gap-lg", children }); }; var Root = ({ children, onCollapseChange, linkComponent = "div", toLabel = "href" }) => { const topIcon = { open: { rotate: 20, height: 9, marginBottom: -1 }, close: { rotate: -20, height: 9, marginBottom: -1 } }; const bottomIcon = { open: { rotate: -20, height: 9, marginTop: -1 }, close: { rotate: 20, height: 9, marginTop: -1 } }; const panelVariants = { open: { width: 260 }, close: { width: 57 } }; const [open, setOpen] = (0, import_react2.useState)(true); return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_framer_motion.AnimatePresence, { initial: false, children: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)( import_framer_motion.motion.div, { animate: open ? "open" : "close", variants: panelVariants, onAnimationComplete: (e) => { onCollapseChange?.({ type: "end", value: e }); }, onAnimationStart: (e) => { onCollapseChange?.({ type: "start", value: e }); }, className: cn( "kl-min-h-screen kl-max-h-screen kl-flex kl-flex-col kl-bg-surface-basic-active kl-border-r kl-border-r-border-default kl-sticky kl-top-0 kl-flex-shrink-0" ), children: [ import_react2.Children.map(children, (child) => { if (!(0, import_react2.isValidElement)(child)) return child; const c = child; return (0, import_react2.cloneElement)(c, { collapsed: open, linkComponent, toLabel }); }), /* @__PURE__ */ (0, import_jsx_runtime.jsx)( "div", { onClick: () => { setOpen((prev) => !prev); }, className: "kl-absolute -kl-right-4xl kl-top-1/2 kl-transform -kl-translate-y-1/2 kl-text-icon-soft kl-w-4xl kl-flex kl-items-center kl-justify-center kl-cursor-pointer", children: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)( import_framer_motion.motion.div, { whileHover: open ? "open" : "close", className: "kl-flex kl-flex-col kl-h-2xl kl-w-full kl-items-center", children: [ /* @__PURE__ */ (0, import_jsx_runtime.jsx)( import_framer_motion.motion.div, { variants: topIcon, className: "kl-w-sm kl-bg-icon-soft kl-h-lg kl-rounded-full !kl-rounded-b-none" } ), /* @__PURE__ */ (0, import_jsx_runtime.jsx)( import_framer_motion.motion.div, { variants: bottomIcon, className: "kl-w-sm kl-bg-icon-soft kl-h-lg kl-rounded-full !kl-rounded-t-none" } ) ] } ) } ) ] } ) }); }; var Sidebar = { Root, Item, Header, Separator }; var side_bar_default = Sidebar;