@chaibuilder/sdk 1.2.57 → 1.2.59

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.
Files changed (44) hide show
  1. package/dist/CanvasArea-NLbaLcFM.cjs +59 -0
  2. package/dist/{CanvasArea-8f_Ki3B7.js → CanvasArea-akw7npWW.js} +385 -366
  3. package/dist/{CurrentPage-nzo4lszx.js → CurrentPage-cOvRmEIZ.js} +2 -2
  4. package/dist/{CurrentPage-7aEIhzQ0.cjs → CurrentPage-pwDwQsWa.cjs} +1 -1
  5. package/dist/{ListTree-KUGhFsb_.js → ListTree-0iy8aBgI.js} +74 -53
  6. package/dist/{ListTree-A-097CZ-.cjs → ListTree-Njsk1AzL.cjs} +1 -1
  7. package/dist/{PagesPanel-hleqqZBo.js → PagesPanel-A3du_vDn.js} +3 -3
  8. package/dist/{PagesPanel-L1mI3y_6.cjs → PagesPanel-bfNUqq2a.cjs} +1 -1
  9. package/dist/{ProjectPanel-RXEhYr0a.js → ProjectPanel-92EtwSrh.js} +3 -3
  10. package/dist/{ProjectPanel-HTxa1kHv.cjs → ProjectPanel-QMaTK2Jx.cjs} +1 -1
  11. package/dist/{Settings-b1ZuIn4y.js → Settings-3ZuMFtd6.js} +2 -2
  12. package/dist/Settings-8_Twq9DO.cjs +1 -0
  13. package/dist/{SidePanels-_6WlMWq_.cjs → SidePanels-C8RdCe7y.cjs} +1 -1
  14. package/dist/{SidePanels-6hZeCR5Z.js → SidePanels-XUVc9jMH.js} +3 -3
  15. package/dist/{Topbar-WdGZIIZp.cjs → Topbar-EkBS5_nt.cjs} +1 -1
  16. package/dist/{Topbar-YfsC1DZ2.js → Topbar-VdVqOT-8.js} +1 -1
  17. package/dist/UILibrariesPanel-CaGLzB9c.cjs +1 -0
  18. package/dist/UILibrariesPanel-raxCToMd.js +216 -0
  19. package/dist/{add-page-modal-CtMwNEsW.js → add-page-modal-OH7DL-Yz.js} +2 -2
  20. package/dist/{add-page-modal-DA5P4pVu.cjs → add-page-modal-VmIvQ5ug.cjs} +1 -1
  21. package/dist/core.cjs +1 -1
  22. package/dist/core.js +1 -1
  23. package/dist/{delete-page-modal-TMpN1Dvm.js → delete-page-modal--g92Sj1h.js} +2 -2
  24. package/dist/{delete-page-modal-AvUZI9Tk.cjs → delete-page-modal-uSFaC2aS.cjs} +1 -1
  25. package/dist/email.cjs +1 -1
  26. package/dist/email.js +1 -1
  27. package/dist/{index-IgLSTkN6.js → index--t_K8Sw6.js} +1 -1
  28. package/dist/{index-zaKhyTQ6.cjs → index-4C2qT6ju.cjs} +1 -1
  29. package/dist/{index-sspgZwTk.cjs → index-Phf9F3An.cjs} +1 -1
  30. package/dist/{index--hN9ZQsP.js → index-yVCgnTlS.js} +2 -2
  31. package/dist/mockServiceWorker.js +18 -10
  32. package/dist/{page-viewer-D8nsi13f.js → page-viewer-hBsE440V.js} +3 -3
  33. package/dist/{page-viewer-2BMSxxfd.cjs → page-viewer-yIl2jRO8.cjs} +1 -1
  34. package/dist/{project-general-setting-HGjTNFRx.js → project-general-setting-9AGMKDNq.js} +2 -2
  35. package/dist/{project-general-setting--0hX9Otn.cjs → project-general-setting-NFCzMKqN.cjs} +1 -1
  36. package/dist/{single-page-detail-eMnjt_Ih.js → single-page-detail-5qDQmlL-.js} +3 -3
  37. package/dist/{single-page-detail-7BpYAyMO.cjs → single-page-detail-wwJYm5lF.cjs} +1 -1
  38. package/dist/studio.cjs +1 -1
  39. package/dist/studio.js +2 -2
  40. package/package.json +1 -1
  41. package/dist/CanvasArea-UisRL54b.cjs +0 -56
  42. package/dist/Settings-7EMwx6zL.cjs +0 -1
  43. package/dist/UILibrariesPanel-5QxxXYg2.js +0 -191
  44. package/dist/UILibrariesPanel-r8nQzXQ-.cjs +0 -1
@@ -1,191 +0,0 @@
1
- import { j as e } from "./jsx-runtime-WbnYoNE9.js";
2
- import { noop as N, has as w, first as j, isEmpty as I, get as b, values as A, groupBy as P, map as E, capitalize as T } from "lodash-es";
3
- import * as U from "react";
4
- import B, { useState as C, useCallback as _, useEffect as R, useRef as z } from "react";
5
- import { b8 as G, b9 as M, B as O, ba as F, bb as W, bc as $, bd as D, be as H, bf as J, bg as K, h as v, a2 as Y, r as q, o as Q, aJ as V, S as X, br as Z } from "./index-uLn8W3eR.js";
6
- import { syncBlocksWithDefaults as ee, useChaiBlocks as se } from "@chaibuilder/runtime";
7
- import { Loader as te } from "lucide-react";
8
- import { atom as oe, useAtom as k } from "jotai";
9
- import { c as y } from "./Functions-7jnEwJyw.js";
10
- import { CaretSortIcon as re, CheckIcon as ae, CaretRightIcon as ne } from "@radix-ui/react-icons";
11
- import { O as le } from "./MODIFIERS-fd5XOmum.js";
12
- import { useTranslation as L } from "react-i18next";
13
- import "./_commonjsHelpers-UyOWmZb0.js";
14
- import "@radix-ui/react-toggle";
15
- import "class-variance-authority";
16
- import "./utils-VpVqnC9m.js";
17
- import "clsx";
18
- import "tailwind-merge";
19
- import "@radix-ui/react-switch";
20
- import "@radix-ui/react-slot";
21
- import "@radix-ui/react-accordion";
22
- import "@radix-ui/react-alert-dialog";
23
- import "@radix-ui/react-dialog";
24
- import "@radix-ui/react-label";
25
- import "@radix-ui/react-scroll-area";
26
- import "@radix-ui/react-tabs";
27
- import "@radix-ui/react-tooltip";
28
- import "@radix-ui/react-popover";
29
- import "@radix-ui/react-menubar";
30
- import "@radix-ui/react-hover-card";
31
- import "@radix-ui/react-select";
32
- import "@radix-ui/react-dropdown-menu";
33
- import "@radix-ui/react-separator";
34
- import "@radix-ui/react-toast";
35
- import "cmdk";
36
- import "@radix-ui/react-context-menu";
37
- import "react-icons-picker";
38
- import "react-dom";
39
- import "react-quill";
40
- import "@react-hookz/web";
41
- import "tree-model";
42
- function ie({
43
- uiLibraries: s,
44
- library: r,
45
- setLibrary: a
46
- }) {
47
- var i;
48
- const [l, n] = U.useState(!1), { t } = L();
49
- return r ? /* @__PURE__ */ e.jsxs(G, { open: l, onOpenChange: n, children: [
50
- /* @__PURE__ */ e.jsx(M, { asChild: !0, children: /* @__PURE__ */ e.jsxs("div", { className: "flex items-center gap-x-2", children: [
51
- /* @__PURE__ */ e.jsx("span", { children: t("Choose Library") }),
52
- /* @__PURE__ */ e.jsxs(
53
- O,
54
- {
55
- variant: "outline",
56
- size: "sm",
57
- role: "combobox",
58
- "aria-expanded": l,
59
- className: "w-[200px] justify-between",
60
- children: [
61
- r ? (i = s.find((o) => o.uuid === r)) == null ? void 0 : i.name : t("Select library"),
62
- /* @__PURE__ */ e.jsx(re, { className: "ml-2 h-4 w-4 shrink-0 opacity-50" })
63
- ]
64
- }
65
- )
66
- ] }) }),
67
- /* @__PURE__ */ e.jsx(F, { className: "w-[200px] p-0", children: /* @__PURE__ */ e.jsxs(W, { children: [
68
- /* @__PURE__ */ e.jsx($, { placeholder: "Search library...", className: "h-9" }),
69
- /* @__PURE__ */ e.jsxs(D, { children: [
70
- /* @__PURE__ */ e.jsx(H, { children: "No library found." }),
71
- /* @__PURE__ */ e.jsx(J, { children: s.map((o) => /* @__PURE__ */ e.jsxs(
72
- K,
73
- {
74
- value: o.uuid,
75
- onSelect: (m) => {
76
- a(m), n(!1);
77
- },
78
- children: [
79
- o.name,
80
- /* @__PURE__ */ e.jsx(
81
- ae,
82
- {
83
- className: y("ml-auto h-4 w-4", r === o.uuid ? "opacity-100" : "opacity-0")
84
- }
85
- )
86
- ]
87
- },
88
- o.uuid
89
- )) })
90
- ] })
91
- ] }) })
92
- ] }) : null;
93
- }
94
- const ce = ({
95
- block: s,
96
- closePopover: r,
97
- library: a
98
- }) => {
99
- const [l, n] = C(!1), t = v("getUILibraryBlock", N), { addCoreBlock: i, addPredefinedBlock: o } = Y(), [m] = q(), f = (p) => {
100
- const u = w(p, "styles_attrs.data-page-section");
101
- return p._type === "Box" && u;
102
- }, h = _(
103
- async (p) => {
104
- if (p.stopPropagation(), w(s, "component")) {
105
- i(s, j(m)), r();
106
- return;
107
- }
108
- n(!0);
109
- const u = await t(a, s);
110
- let g = j(m);
111
- f(j(u)) && (g = null), I(u) || o(ee(u), g), r();
112
- },
113
- [s]
114
- );
115
- return /* @__PURE__ */ e.jsx(e.Fragment, { children: /* @__PURE__ */ e.jsxs(
116
- "div",
117
- {
118
- onClick: l ? () => {
119
- } : h,
120
- className: "relative mt-2 cursor-pointer overflow-hidden rounded-md border border-gray-300 bg-white duration-200 hover:border-blue-500 hover:shadow-xl",
121
- children: [
122
- l && /* @__PURE__ */ e.jsxs("div", { className: "absolute flex h-full w-full items-center justify-center bg-black/70", children: [
123
- /* @__PURE__ */ e.jsx(te, { className: "animate-spin", size: 15, color: "white" }),
124
- " ",
125
- /* @__PURE__ */ e.jsx("span", { className: "pl-2 text-sm text-white", children: "Adding..." })
126
- ] }),
127
- s.preview ? /* @__PURE__ */ e.jsx("img", { src: s.preview, className: "min-h-[25px] w-full rounded-md", alt: s.name }) : /* @__PURE__ */ e.jsx("div", { className: "flex h-20 items-center justify-center rounded-md border border-border border-gray-300 bg-gray-200", children: /* @__PURE__ */ e.jsx("p", { className: "max-w-xs text-center text-sm text-gray-700", children: s.name }) })
128
- ]
129
- }
130
- ) });
131
- }, de = oe({}), me = (s) => {
132
- const [r, a] = k(de), l = v("getUILibraryBlocks", N), n = b(r, `${s == null ? void 0 : s.uuid}.blocks`, []), t = b(r, `${s == null ? void 0 : s.uuid}.loading`, !1);
133
- return R(() => {
134
- (async () => {
135
- if (t || n.length > 0)
136
- return;
137
- a((o) => ({ ...o, [s == null ? void 0 : s.uuid]: { loading: !0, blocks: [] } }));
138
- const i = await l(s);
139
- a((o) => ({ ...o, [s == null ? void 0 : s.uuid]: { loading: !1, blocks: i || [] } }));
140
- })();
141
- }, [s, n, t]), { data: n, isLoading: t };
142
- }, ue = Q("_selectedLibrary", null), pe = () => {
143
- const [s, r] = k(ue), a = v("uiLibraries", []), l = se(), n = A(l).filter((d) => d.category === "custom"), t = a.find((d) => d.uuid === s) || j(a), { data: i, isLoading: o } = me(t), m = P([...i, ...n], "group"), [f, h] = C("Hero"), [, p] = k(V), u = b(m, f, []), { t: g } = L(), c = z(null), S = (d) => {
144
- c.current && (clearTimeout(c.current), c.current = null), c.current = setTimeout(() => {
145
- c.current && h(d);
146
- }, 300);
147
- };
148
- return o ? /* @__PURE__ */ e.jsx(X, { className: "h-full w-full" }) : /* @__PURE__ */ e.jsx(e.Fragment, { children: /* @__PURE__ */ e.jsxs("div", { className: "relative flex h-full max-h-full w-[460px] flex-col overflow-hidden bg-background", children: [
149
- t != null && t.uuid ? /* @__PURE__ */ e.jsx("div", { className: "sticky top-0 flex h-fit flex-col", children: /* @__PURE__ */ e.jsx("div", { className: "mb-2 flex flex-col justify-between rounded-md bg-background/30 p-1", children: /* @__PURE__ */ e.jsx("h1", { className: "flex w-full flex-col items-baseline truncate px-1 text-sm font-semibold xl:flex-col", children: /* @__PURE__ */ e.jsx(ie, { library: t == null ? void 0 : t.uuid, setLibrary: r, uiLibraries: a }) }) }) }) : null,
150
- /* @__PURE__ */ e.jsxs("div", { className: "flex h-[95%] border-t border-gray-300 pt-2", children: [
151
- /* @__PURE__ */ e.jsx("div", { className: "flex h-full w-40 flex-col gap-1 px-1", children: B.Children.toArray(
152
- E(m, (d, x) => /* @__PURE__ */ e.jsxs(
153
- "div",
154
- {
155
- onMouseEnter: () => S(x),
156
- onMouseLeave: () => clearTimeout(c.current),
157
- onClick: () => h(x),
158
- className: y(
159
- "flex w-full cursor-pointer items-center justify-between rounded-md p-1 text-sm transition-all ease-in-out hover:bg-gray-200",
160
- x === f ? "bg-blue-500 text-white hover:bg-blue-600" : ""
161
- ),
162
- children: [
163
- /* @__PURE__ */ e.jsx("span", { children: T(x) }),
164
- /* @__PURE__ */ e.jsx(ne, { className: "ml-2 h-5 w-5" })
165
- ]
166
- },
167
- x
168
- ))
169
- ) }),
170
- /* @__PURE__ */ e.jsxs(
171
- Z,
172
- {
173
- onMouseEnter: () => c.current ? clearTimeout(c.current) : null,
174
- className: "z-10 -mt-2 flex h-full max-h-full w-[300px] flex-col gap-2 border-l border-gray-300 transition-all ease-linear",
175
- children: [
176
- /* @__PURE__ */ e.jsx("div", { className: "sticky top-0 z-30 border-b border-gray-300 bg-gray-200 p-2 text-[9px] font-light leading-3 text-gray-500", children: g("Click on a block to add it to the page") }),
177
- /* @__PURE__ */ e.jsx("div", { className: "flex flex-col gap-2 px-2", children: B.Children.toArray(
178
- u.map((d) => /* @__PURE__ */ e.jsx(ce, { block: d, library: t, closePopover: () => p(le) }))
179
- ) }),
180
- /* @__PURE__ */ e.jsx("br", {}),
181
- /* @__PURE__ */ e.jsx("br", {}),
182
- /* @__PURE__ */ e.jsx("br", {})
183
- ]
184
- }
185
- )
186
- ] })
187
- ] }) });
188
- }, es = () => /* @__PURE__ */ e.jsx(pe, {});
189
- export {
190
- es as default
191
- };
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./jsx-runtime-Z_BpKhVy.cjs"),o=require("lodash-es"),m=require("react"),t=require("./index-0FIxW0gR.cjs"),v=require("@chaibuilder/runtime"),N=require("lucide-react"),b=require("jotai"),k=require("./Functions-N3yhPYKY.cjs"),q=require("@radix-ui/react-icons"),y=require("./MODIFIERS-mVmfEGgo.cjs"),w=require("react-i18next");require("./_commonjsHelpers-wDK0ZLPo.cjs");require("@radix-ui/react-toggle");require("class-variance-authority");require("./utils-D_vtk3zK.cjs");require("clsx");require("tailwind-merge");require("@radix-ui/react-switch");require("@radix-ui/react-slot");require("@radix-ui/react-accordion");require("@radix-ui/react-alert-dialog");require("@radix-ui/react-dialog");require("@radix-ui/react-label");require("@radix-ui/react-scroll-area");require("@radix-ui/react-tabs");require("@radix-ui/react-tooltip");require("@radix-ui/react-popover");require("@radix-ui/react-menubar");require("@radix-ui/react-hover-card");require("@radix-ui/react-select");require("@radix-ui/react-dropdown-menu");require("@radix-ui/react-separator");require("@radix-ui/react-toast");require("cmdk");require("@radix-ui/react-context-menu");require("react-icons-picker");require("react-dom");require("react-quill");require("@react-hookz/web");require("tree-model");function C(s){const n=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(s){for(const i in s)if(i!=="default"){const c=Object.getOwnPropertyDescriptor(s,i);Object.defineProperty(n,i,c.get?c:{enumerable:!0,get:()=>s[i]})}}return n.default=s,Object.freeze(n)}const S=C(m);function I({uiLibraries:s,library:n,setLibrary:i}){var a;const[c,l]=S.useState(!1),{t:r}=w.useTranslation();return n?e.jsxRuntimeExports.jsxs(t.Popover,{open:c,onOpenChange:l,children:[e.jsxRuntimeExports.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-x-2",children:[e.jsxRuntimeExports.jsx("span",{children:r("Choose Library")}),e.jsxRuntimeExports.jsxs(t.Button,{variant:"outline",size:"sm",role:"combobox","aria-expanded":c,className:"w-[200px] justify-between",children:[n?(a=s.find(u=>u.uuid===n))==null?void 0:a.name:r("Select library"),e.jsxRuntimeExports.jsx(q.CaretSortIcon,{className:"ml-2 h-4 w-4 shrink-0 opacity-50"})]})]})}),e.jsxRuntimeExports.jsx(t.PopoverContent,{className:"w-[200px] p-0",children:e.jsxRuntimeExports.jsxs(t.Command,{children:[e.jsxRuntimeExports.jsx(t.CommandInput,{placeholder:"Search library...",className:"h-9"}),e.jsxRuntimeExports.jsxs(t.CommandList,{children:[e.jsxRuntimeExports.jsx(t.CommandEmpty,{children:"No library found."}),e.jsxRuntimeExports.jsx(t.CommandGroup,{children:s.map(u=>e.jsxRuntimeExports.jsxs(t.CommandItem,{value:u.uuid,onSelect:p=>{i(p),l(!1)},children:[u.name,e.jsxRuntimeExports.jsx(q.CheckIcon,{className:k.cn("ml-auto h-4 w-4",n===u.uuid?"opacity-100":"opacity-0")})]},u.uuid))})]})]})})]}):null}const L=({block:s,closePopover:n,library:i})=>{const[c,l]=m.useState(!1),r=t.useBuilderProp("getUILibraryBlock",o.noop),{addCoreBlock:a,addPredefinedBlock:u}=t.useAddBlock(),[p]=t.useSelectedBlockIds(),g=f=>{const j=o.has(f,"styles_attrs.data-page-section");return f._type==="Box"&&j},E=m.useCallback(async f=>{if(f.stopPropagation(),o.has(s,"component")){a(s,o.first(p)),n();return}l(!0);const j=await r(i,s);let R=o.first(p);g(o.first(j))&&(R=null),o.isEmpty(j)||u(v.syncBlocksWithDefaults(j),R),n()},[s]);return e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:e.jsxRuntimeExports.jsxs("div",{onClick:c?()=>{}:E,className:"relative mt-2 cursor-pointer overflow-hidden rounded-md border border-gray-300 bg-white duration-200 hover:border-blue-500 hover:shadow-xl",children:[c&&e.jsxRuntimeExports.jsxs("div",{className:"absolute flex h-full w-full items-center justify-center bg-black/70",children:[e.jsxRuntimeExports.jsx(N.Loader,{className:"animate-spin",size:15,color:"white"})," ",e.jsxRuntimeExports.jsx("span",{className:"pl-2 text-sm text-white",children:"Adding..."})]}),s.preview?e.jsxRuntimeExports.jsx("img",{src:s.preview,className:"min-h-[25px] w-full rounded-md",alt:s.name}):e.jsxRuntimeExports.jsx("div",{className:"flex h-20 items-center justify-center rounded-md border border-border border-gray-300 bg-gray-200",children:e.jsxRuntimeExports.jsx("p",{className:"max-w-xs text-center text-sm text-gray-700",children:s.name})})]})})},P=b.atom({}),A=s=>{const[n,i]=b.useAtom(P),c=t.useBuilderProp("getUILibraryBlocks",o.noop),l=o.get(n,`${s==null?void 0:s.uuid}.blocks`,[]),r=o.get(n,`${s==null?void 0:s.uuid}.loading`,!1);return m.useEffect(()=>{(async()=>{if(r||l.length>0)return;i(u=>({...u,[s==null?void 0:s.uuid]:{loading:!0,blocks:[]}}));const a=await c(s);i(u=>({...u,[s==null?void 0:s.uuid]:{loading:!1,blocks:a||[]}}))})()},[s,l,r]),{data:l,isLoading:r}},T=t.atomWithStorage("_selectedLibrary",null),O=()=>{const[s,n]=b.useAtom(T),i=t.useBuilderProp("uiLibraries",[]),c=v.useChaiBlocks(),l=o.values(c).filter(d=>d.category==="custom"),r=i.find(d=>d.uuid===s)||o.first(i),{data:a,isLoading:u}=A(r),p=o.groupBy([...a,...l],"group"),[g,E]=m.useState("Hero"),[,f]=b.useAtom(t.activePanelAtom),j=o.get(p,g,[]),{t:R}=w.useTranslation(),x=m.useRef(null),B=d=>{x.current&&(clearTimeout(x.current),x.current=null),x.current=setTimeout(()=>{x.current&&E(d)},300)};return u?e.jsxRuntimeExports.jsx(t.Skeleton,{className:"h-full w-full"}):e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:e.jsxRuntimeExports.jsxs("div",{className:"relative flex h-full max-h-full w-[460px] flex-col overflow-hidden bg-background",children:[r!=null&&r.uuid?e.jsxRuntimeExports.jsx("div",{className:"sticky top-0 flex h-fit flex-col",children:e.jsxRuntimeExports.jsx("div",{className:"mb-2 flex flex-col justify-between rounded-md bg-background/30 p-1",children:e.jsxRuntimeExports.jsx("h1",{className:"flex w-full flex-col items-baseline truncate px-1 text-sm font-semibold xl:flex-col",children:e.jsxRuntimeExports.jsx(I,{library:r==null?void 0:r.uuid,setLibrary:n,uiLibraries:i})})})}):null,e.jsxRuntimeExports.jsxs("div",{className:"flex h-[95%] border-t border-gray-300 pt-2",children:[e.jsxRuntimeExports.jsx("div",{className:"flex h-full w-40 flex-col gap-1 px-1",children:m.Children.toArray(o.map(p,(d,h)=>e.jsxRuntimeExports.jsxs("div",{onMouseEnter:()=>B(h),onMouseLeave:()=>clearTimeout(x.current),onClick:()=>E(h),className:k.cn("flex w-full cursor-pointer items-center justify-between rounded-md p-1 text-sm transition-all ease-in-out hover:bg-gray-200",h===g?"bg-blue-500 text-white hover:bg-blue-600":""),children:[e.jsxRuntimeExports.jsx("span",{children:o.capitalize(h)}),e.jsxRuntimeExports.jsx(q.CaretRightIcon,{className:"ml-2 h-5 w-5"})]},h)))}),e.jsxRuntimeExports.jsxs(t.ScrollArea,{onMouseEnter:()=>x.current?clearTimeout(x.current):null,className:"z-10 -mt-2 flex h-full max-h-full w-[300px] flex-col gap-2 border-l border-gray-300 transition-all ease-linear",children:[e.jsxRuntimeExports.jsx("div",{className:"sticky top-0 z-30 border-b border-gray-300 bg-gray-200 p-2 text-[9px] font-light leading-3 text-gray-500",children:R("Click on a block to add it to the page")}),e.jsxRuntimeExports.jsx("div",{className:"flex flex-col gap-2 px-2",children:m.Children.toArray(j.map(d=>e.jsxRuntimeExports.jsx(L,{block:d,library:r,closePopover:()=>f(y.OUTLINE_KEY)})))}),e.jsxRuntimeExports.jsx("br",{}),e.jsxRuntimeExports.jsx("br",{}),e.jsxRuntimeExports.jsx("br",{})]})]})]})})},_=()=>e.jsxRuntimeExports.jsx(O,{});exports.default=_;