@logickernel/frame 0.5.0 → 0.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.mts +57 -1
- package/dist/index.d.ts +57 -1
- package/dist/index.js +52 -1
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +52 -2
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
package/dist/index.mjs
CHANGED
|
@@ -43,6 +43,7 @@ var SIDEBAR_COOKIE_MAX_AGE = 60 * 60 * 24 * 7;
|
|
|
43
43
|
var SIDEBAR_WIDTH = "16rem";
|
|
44
44
|
var SIDEBAR_WIDTH_MOBILE = "18rem";
|
|
45
45
|
var SIDEBAR_WIDTH_ICON = "3rem";
|
|
46
|
+
var SIDEBAR_TRANSITION_DURATION = "200ms";
|
|
46
47
|
var SIDEBAR_KEYBOARD_SHORTCUT = "b";
|
|
47
48
|
var SidebarContext = React2.createContext(null);
|
|
48
49
|
function useSidebar() {
|
|
@@ -121,6 +122,7 @@ var SidebarProvider = React2.forwardRef(
|
|
|
121
122
|
style: {
|
|
122
123
|
"--sidebar-width": SIDEBAR_WIDTH,
|
|
123
124
|
"--sidebar-width-icon": SIDEBAR_WIDTH_ICON,
|
|
125
|
+
"--sidebar-transition-duration": SIDEBAR_TRANSITION_DURATION,
|
|
124
126
|
...style
|
|
125
127
|
},
|
|
126
128
|
className: cn(
|
|
@@ -284,16 +286,28 @@ var SidebarRail = React2.forwardRef(({ className, ...props }, ref) => {
|
|
|
284
286
|
);
|
|
285
287
|
});
|
|
286
288
|
SidebarRail.displayName = "SidebarRail";
|
|
287
|
-
var SidebarInset = React2.forwardRef(({ className, ...props }, ref) => {
|
|
289
|
+
var SidebarInset = React2.forwardRef(({ className, style, ...props }, ref) => {
|
|
290
|
+
const { state, isMobile } = useSidebar();
|
|
288
291
|
return /* @__PURE__ */ jsx(
|
|
289
292
|
"main",
|
|
290
293
|
{
|
|
291
294
|
ref,
|
|
292
295
|
className: cn(
|
|
293
296
|
"relative flex min-h-svh flex-1 flex-col bg-background",
|
|
297
|
+
// Auto-adjust margin based on sidebar state
|
|
298
|
+
// Transition duration uses CSS variable for consistency
|
|
299
|
+
"transition-[margin-left] duration-200 ease-linear",
|
|
300
|
+
// On mobile, no margin needed (sidebar is overlay)
|
|
301
|
+
// On desktop, margin-left based on sidebar state:
|
|
302
|
+
// - Expanded: ml-64 (256px / 16rem)
|
|
303
|
+
// - Collapsed: ml-12 (48px / 3rem)
|
|
304
|
+
!isMobile && state === "expanded" && "md:ml-64",
|
|
305
|
+
!isMobile && state === "collapsed" && "md:ml-12",
|
|
306
|
+
// Keep peer-based styles for inset variant
|
|
294
307
|
"peer-data-[variant=inset]:min-h-[calc(100svh-theme(spacing.4))] md:peer-data-[variant=inset]:m-2 md:peer-data-[state=collapsed]:peer-data-[variant=inset]:ml-2 md:peer-data-[variant=inset]:ml-0 md:peer-data-[variant=inset]:rounded-xl md:peer-data-[variant=inset]:shadow",
|
|
295
308
|
className
|
|
296
309
|
),
|
|
310
|
+
style,
|
|
297
311
|
...props
|
|
298
312
|
}
|
|
299
313
|
);
|
|
@@ -1216,6 +1230,42 @@ function AppSidebar({
|
|
|
1216
1230
|
/* @__PURE__ */ jsx(SidebarRail, {})
|
|
1217
1231
|
] });
|
|
1218
1232
|
}
|
|
1233
|
+
function AppLayout({
|
|
1234
|
+
user,
|
|
1235
|
+
adapter,
|
|
1236
|
+
data,
|
|
1237
|
+
organizationId,
|
|
1238
|
+
apiBaseUrl,
|
|
1239
|
+
useApiNavigation,
|
|
1240
|
+
headerContent,
|
|
1241
|
+
showHeader = true,
|
|
1242
|
+
children
|
|
1243
|
+
}) {
|
|
1244
|
+
const isApiMode = useApiNavigation === true;
|
|
1245
|
+
const navigationApiBaseUrl = apiBaseUrl;
|
|
1246
|
+
return /* @__PURE__ */ jsxs(SidebarProvider, { children: [
|
|
1247
|
+
/* @__PURE__ */ jsx(
|
|
1248
|
+
AppSidebar,
|
|
1249
|
+
{
|
|
1250
|
+
user,
|
|
1251
|
+
adapter,
|
|
1252
|
+
data: isApiMode ? void 0 : data,
|
|
1253
|
+
organizationId,
|
|
1254
|
+
apiBaseUrl: navigationApiBaseUrl
|
|
1255
|
+
}
|
|
1256
|
+
),
|
|
1257
|
+
/* @__PURE__ */ jsxs(SidebarInset, { children: [
|
|
1258
|
+
showHeader && /* @__PURE__ */ jsxs("header", { className: "flex h-16 shrink-0 items-center gap-2 border-b px-4", children: [
|
|
1259
|
+
/* @__PURE__ */ jsx(SidebarTrigger, {}),
|
|
1260
|
+
headerContent && /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
1261
|
+
/* @__PURE__ */ jsx("div", { className: "h-4 w-px bg-border" }),
|
|
1262
|
+
headerContent
|
|
1263
|
+
] })
|
|
1264
|
+
] }),
|
|
1265
|
+
/* @__PURE__ */ jsx("main", { className: "flex flex-1 flex-col gap-4 p-4 md:p-6", children })
|
|
1266
|
+
] })
|
|
1267
|
+
] });
|
|
1268
|
+
}
|
|
1219
1269
|
function createNextJSAdapter() {
|
|
1220
1270
|
const NextJSLink2 = ({ href, children, className }) => /* @__PURE__ */ jsx(Link, { href, className, children });
|
|
1221
1271
|
return {
|
|
@@ -1232,6 +1282,6 @@ function createNextJSAdapter() {
|
|
|
1232
1282
|
};
|
|
1233
1283
|
}
|
|
1234
1284
|
|
|
1235
|
-
export { AppSidebar, NavMain, NavUser, SidebarInset, SidebarProvider, SidebarTrigger, TeamSwitcher, createNextJSAdapter, getIconComponent, useNavigation, useSidebar };
|
|
1285
|
+
export { AppLayout, AppSidebar, NavMain, NavUser, SidebarInset, SidebarProvider, SidebarTrigger, TeamSwitcher, createNextJSAdapter, getIconComponent, useNavigation, useSidebar };
|
|
1236
1286
|
//# sourceMappingURL=index.mjs.map
|
|
1237
1287
|
//# sourceMappingURL=index.mjs.map
|