UNPKG

@kloudlite/design-system

Version:

A design system for building ambitious products.

141 lines (136 loc) 5.6 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/top-bar.tsx var top_bar_exports = {}; __export(top_bar_exports, { TopBar: () => TopBar, TopBarContext: () => TopBarContext }); module.exports = __toCommonJS(top_bar_exports); var import_react2 = require("react"); // 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/atoms/container.tsx var import_jsx_runtime = require("react/jsx-runtime"); var Container = ({ children, className = "" }) => { return /* @__PURE__ */ (0, import_jsx_runtime.jsx)( "div", { className: cn("kl-flex kl-flex-1 kl-justify-center kl-px-8xl", className), children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: cn("kl-flex-1 kl-w-full kl-max-w-8xl kl-min-w-[320px]"), children }) } ); }; var container_default = Container; // components/organisms/top-bar.tsx var import_jsx_runtime2 = require("react/jsx-runtime"); var TopBarContext = (0, import_react2.createContext)({}); var useSticky = (elementRef, topLimit = 0) => { const [isStickey, setIsSticky] = (0, import_react2.useState)(false); (0, import_react2.useEffect)(() => { const getScroll = () => { if (elementRef && elementRef.current) { const { top } = elementRef.current.getBoundingClientRect(); if (top < topLimit) { setIsSticky(true); } else { setIsSticky(false); } } }; document.addEventListener("scroll", getScroll); return () => { document.removeEventListener("scroll", getScroll); }; }, [elementRef, topLimit]); return isStickey; }; var TopBar = ({ tabs, actions, logo, fixed = true, breadcrum }) => { const tabBarRef = (0, import_react2.createRef)(); const isTabBarSticked = useSticky(tabBarRef, 0); const headingRef = (0, import_react2.createRef)(); const isHeadingSticked = useSticky(headingRef, 0); return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(import_jsx_runtime2.Fragment, { children: [ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)( "div", { ref: headingRef, className: cn( "kl-bg-surface-basic-default kl-z-40 kl-transition-all kl-overflow-hidden", { "kl-sticky -kl-top-xs kl-left-0 kl-right-0": !tabs && fixed, "kl-shadow-sm kl-pt-xs": !tabs && fixed && isHeadingSticked } ), children: /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(container_default, { children: /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { className: "kl-flex kl-flex-row kl-items-center kl-gap-3xl kl-py-xl", children: [ /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { className: "kl-flex kl-flex-row kl-gap-md kl-items-center", children: [ !!logo && logo, !!breadcrum && breadcrum ] }), /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { className: "kl-flex kl-flex-row kl-items-center kl-justify-end kl-flex-1", children: /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { className: "kl-flex kl-flex-row kl-items-center kl-justify-center", children: !!actions && actions }) }) ] }) }) } ), /* @__PURE__ */ (0, import_jsx_runtime2.jsx)( TopBarContext.Provider, { value: (0, import_react2.useMemo)( () => ({ isSticked: isTabBarSticked && fixed }), [isTabBarSticked] ), children: !!tabs && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)( "div", { ref: tabBarRef, className: cn( "kl-bg-surface-basic-default kl-z-40 kl-min-h-[40px]", { "kl-sticky -kl-top-xs kl-pt-xs kl-left-0 kl-right-0": fixed, "kl-shadow-sm": fixed && isTabBarSticked } ), children: /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(container_default, { children: tabs }) } ) } ), /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { className: "kl-border-b kl-border-border-default" }) ] }); };