@measured/puck 0.21.0-canary.16a3eee1 → 0.21.0-canary.17395b2c

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 (52) hide show
  1. package/dist/Editor-CYTATURR.mjs +204 -0
  2. package/dist/Editor-F2LSS6SE.css +403 -0
  3. package/dist/Render-OFE6QLI2.mjs +55 -0
  4. package/dist/Render-QEMDIDQC.css +101 -0
  5. package/dist/{walk-tree-Ctf3FZQI.d.mts → actions-tsxxcX1z.d.mts} +285 -82
  6. package/dist/{walk-tree-Ctf3FZQI.d.ts → actions-tsxxcX1z.d.ts} +285 -82
  7. package/dist/chunk-72SA22GI.mjs +134 -0
  8. package/dist/chunk-CSSRLPHM.mjs +11 -0
  9. package/dist/chunk-M4QBB3JM.mjs +111 -0
  10. package/dist/chunk-M6W7YEVX.mjs +95 -0
  11. package/dist/chunk-MLTVJA2A.mjs +63 -0
  12. package/dist/chunk-MVJKIFF6.mjs +419 -0
  13. package/dist/chunk-NLUHDYVR.mjs +416 -0
  14. package/dist/chunk-NOJQSXRU.mjs +33 -0
  15. package/dist/chunk-QBGM4ELA.mjs +528 -0
  16. package/dist/chunk-UNQOU2OI.mjs +53 -0
  17. package/dist/chunk-UUOBSXZR.mjs +1807 -0
  18. package/dist/chunk-V5I7CVLT.mjs +103 -0
  19. package/dist/chunk-V7333LON.mjs +708 -0
  20. package/dist/{chunk-JZ2BPCUI.mjs → chunk-V73FDFDB.mjs} +6032 -7351
  21. package/dist/chunk-Y2EFNT5P.mjs +108 -0
  22. package/dist/full-2GJTAAZE.css +301 -0
  23. package/dist/full-GZ4L3XCF.mjs +93 -0
  24. package/dist/index-Ca6V6NQD.d.ts +118 -0
  25. package/dist/index-mQvUCH3C.d.mts +118 -0
  26. package/dist/index.css +1032 -387
  27. package/dist/index.d.mts +116 -114
  28. package/dist/index.d.ts +116 -114
  29. package/dist/index.js +8758 -4944
  30. package/dist/index.mjs +34 -12
  31. package/dist/internal.d.mts +27 -0
  32. package/dist/internal.d.ts +27 -0
  33. package/dist/internal.js +908 -0
  34. package/dist/internal.mjs +13 -0
  35. package/dist/loaded-2MNXXPJP.mjs +57 -0
  36. package/dist/loaded-6QT4HD2O.mjs +57 -0
  37. package/dist/loaded-RVWBFK7L.css +87 -0
  38. package/dist/loaded-ZVPBQVNE.mjs +60 -0
  39. package/dist/no-external.css +1165 -516
  40. package/dist/no-external.d.mts +19 -2
  41. package/dist/no-external.d.ts +19 -2
  42. package/dist/no-external.js +8760 -4943
  43. package/dist/no-external.mjs +36 -9
  44. package/dist/rsc.css +101 -0
  45. package/dist/rsc.d.mts +17 -2
  46. package/dist/rsc.d.ts +17 -2
  47. package/dist/rsc.js +421 -32
  48. package/dist/rsc.mjs +18 -9
  49. package/dist/walk-tree-Bh85NMeo.d.ts +29 -0
  50. package/dist/walk-tree-CDA3K5S3.d.mts +29 -0
  51. package/package.json +31 -4
  52. package/dist/chunk-X7YZ3YE7.mjs +0 -964
package/dist/index.d.mts CHANGED
@@ -1,122 +1,37 @@
1
- import { H as History, P as Permissions, a as ComponentData, C as Config, U as UserGenerics, F as Fields, b as PuckAction, R as RootDataWithProps, c as ResolveDataTrigger, d as Plugin, O as Overrides, V as Viewports, I as IframeConfig, e as UiState, f as ComponentConfig, A as AppState, M as Metadata, g as FieldTransforms, h as Field, i as FieldProps, D as DropZoneProps, j as Data, k as OnAction, l as InitialHistory, n as ItemSelector } from './walk-tree-Ctf3FZQI.mjs';
2
- export { a7 as Adaptor, a5 as ArrayField, B as ArrayState, ak as AsFieldProps, N as BaseData, $ as BaseField, Z as ComponentDataMap, X as ComponentDataOptionalId, _ as Content, ab as CustomField, aa as CustomFieldRender, ah as DefaultComponentProps, K as DefaultComponents, ae as DefaultRootFieldProps, ag as DefaultRootProps, af as DefaultRootRenderProps, o as Direction, p as DragAxis, a9 as ExternalField, a8 as ExternalFieldWithAdaptor, L as ExtractConfigParams, am as ExtractField, y as FieldRenderFunctions, u as FieldTransformFn, s as FieldTransformFnParams, z as ItemWithId, Y as MappedItem, a1 as NumberField, a6 as ObjectField, x as OverrideKey, G as PuckComponent, ad as PuckContext, a4 as RadioField, J as RootConfig, T as RootData, Q as RootDataWithoutProps, a3 as SelectField, S as Slot, E as SlotComponent, ac as SlotField, a0 as TextField, a2 as TextareaField, q as Viewport, al as WithChildren, ai as WithId, aj as WithPuckProps, W as WithSlotProps, m as migrate, v as overrideKeys, r as resolveAllData, t as transformProps, w as walkTree } from './walk-tree-Ctf3FZQI.mjs';
1
+ import { p as Field, q as FieldProps, r as DropZoneProps, C as Config, U as UserGenerics, D as Data, l as UiState, O as OnAction, g as Permissions, j as Plugin, k as Overrides, n as FieldTransforms, a as PuckAction, V as Viewports, I as IframeConfig, s as InitialHistory, M as Metadata, t as ItemSelector, c as ComponentData, u as PluginInternal } from './actions-tsxxcX1z.mjs';
2
+ export { ag as Adaptor, A as AppState, ae as ArrayField, N as ArrayState, ar as AsFieldProps, a0 as BaseData, a8 as BaseField, ai as CacheOpts, m as ComponentConfig, X as ComponentConfigExtensions, $ as ComponentConfigParams, a4 as ComponentDataMap, a2 as ComponentDataOptionalId, a6 as ComponentMetadata, _ as ConfigParams, b as Content, al as CustomField, ak as CustomFieldRender, e as DefaultComponentProps, d as DefaultComponents, f as DefaultRootFieldProps, ap as DefaultRootProps, ao as DefaultRootRenderProps, x as Direction, y as DragAxis, aj as ExternalField, ah as ExternalFieldWithAdaptor, Z as ExtractConfigParams, at as ExtractField, a7 as FieldMetadata, K as FieldRenderFunctions, E as FieldTransformFn, B as FieldTransformFnParams, F as Fields, H as History, L as ItemWithId, a3 as MappedItem, aa as NumberField, af as ObjectField, J as OverrideKey, T as PuckComponent, an as PuckContext, a5 as PuckMetadata, ad as RadioField, i as ResolveDataTrigger, w as RichText, o as RichtextField, Y as RootConfig, R as RootData, h as RootDataWithProps, a1 as RootDataWithoutProps, ac as SelectField, S as Slot, Q as SlotComponent, am as SlotField, a9 as TextField, ab as TextareaField, z as Viewport, as as WithChildren, W as WithId, aq as WithPuckProps, v as WithSlotProps, G as overrideKeys } from './actions-tsxxcX1z.mjs';
3
+ export { m as migrate, r as resolveAllData, t as transformProps, w as walkTree } from './walk-tree-CDA3K5S3.mjs';
3
4
  import * as react_jsx_runtime from 'react/jsx-runtime';
4
5
  import * as react from 'react';
5
- import react__default, { ReactNode, SyntheticEvent, ReactElement } from 'react';
6
-
7
- type HistorySlice<D = any> = {
8
- index: number;
9
- hasPast: () => boolean;
10
- hasFuture: () => boolean;
11
- histories: History<D>[];
12
- record: (data: D) => void;
13
- back: VoidFunction;
14
- forward: VoidFunction;
15
- currentHistory: () => History;
16
- nextHistory: () => History<D> | null;
17
- prevHistory: () => History<D> | null;
18
- setHistories: (histories: History[]) => void;
19
- setHistoryIndex: (index: number) => void;
20
- initialAppState: D;
21
- };
22
-
23
- type NodeMethods = {
24
- sync: () => void;
25
- hideOverlay: () => void;
26
- showOverlay: () => void;
27
- };
28
- type PuckNodeInstance = {
29
- id: string;
30
- methods: NodeMethods;
31
- element: HTMLElement | null;
32
- };
33
- type NodesSlice = {
34
- nodes: Record<string, PuckNodeInstance | undefined>;
35
- registerNode: (id: string, node: Partial<PuckNodeInstance>) => void;
36
- unregisterNode: (id: string, node?: Partial<PuckNodeInstance>) => void;
37
- };
38
-
39
- type PermissionsArgs<UserConfig extends Config = Config, G extends UserGenerics<UserConfig> = UserGenerics<UserConfig>> = {
40
- item?: G["UserComponentData"] | null;
41
- type?: keyof G["UserProps"];
42
- root?: boolean;
43
- };
44
- type GetPermissions<UserConfig extends Config = Config> = (params?: PermissionsArgs<UserConfig>) => Permissions;
45
- type ResolvePermissions<UserConfig extends Config = Config> = (params?: PermissionsArgs<UserConfig>, force?: boolean) => void;
46
- type RefreshPermissions<UserConfig extends Config = Config> = (params?: PermissionsArgs<UserConfig>, force?: boolean) => void;
47
- type Cache = Record<string, {
48
- lastPermissions: Partial<Permissions>;
49
- lastData: ComponentData | null;
50
- }>;
51
- type PermissionsSlice = {
52
- cache: Cache;
53
- globalPermissions: Permissions;
54
- resolvedPermissions: Record<string, Partial<Permissions> | undefined>;
55
- getPermissions: GetPermissions<Config>;
56
- resolvePermissions: ResolvePermissions<Config>;
57
- refreshPermissions: RefreshPermissions<Config>;
58
- };
59
-
60
- type ComponentOrRootData = Omit<ComponentData<any>, "type">;
61
- type FieldsSlice = {
62
- fields: Fields | Partial<Fields>;
63
- loading: boolean;
64
- lastResolvedData: Partial<ComponentOrRootData>;
65
- id: string | undefined;
66
- };
67
-
68
- type Status = "LOADING" | "MOUNTED" | "READY";
69
- type ZoomConfig = {
70
- autoZoom: number;
71
- rootHeight: number;
72
- zoom: number;
73
- };
74
- type ComponentState = Record<string, {
75
- loadingCount: number;
76
- }>;
77
- type AppStore<UserConfig extends Config = Config, G extends UserGenerics<UserConfig> = UserGenerics<UserConfig>> = {
78
- state: G["UserAppState"];
79
- dispatch: (action: PuckAction) => void;
80
- config: UserConfig;
81
- componentState: ComponentState;
82
- setComponentState: (componentState: ComponentState) => void;
83
- setComponentLoading: (id: string, loading?: boolean, defer?: number) => () => void;
84
- unsetComponentLoading: (id: string) => void;
85
- pendingLoadTimeouts: Record<string, NodeJS.Timeout>;
86
- resolveComponentData: <T extends ComponentData | RootDataWithProps>(componentData: T, trigger: ResolveDataTrigger) => Promise<{
87
- node: T;
88
- didChange: boolean;
89
- }>;
90
- resolveAndCommitData: () => void;
91
- plugins: Plugin[];
92
- overrides: Partial<Overrides>;
93
- viewports: Viewports;
94
- zoomConfig: ZoomConfig;
95
- setZoomConfig: (zoomConfig: ZoomConfig) => void;
96
- status: Status;
97
- setStatus: (status: Status) => void;
98
- iframe: IframeConfig;
99
- selectedItem?: G["UserData"]["content"][0] | null;
100
- setUi: (ui: Partial<UiState>, recordHistory?: boolean) => void;
101
- getComponentConfig: (type?: string) => ComponentConfig | null | undefined;
102
- onAction?: (action: PuckAction, newState: AppState, state: AppState) => void;
103
- metadata: Metadata;
104
- fields: FieldsSlice;
105
- history: HistorySlice;
106
- nodes: NodesSlice;
107
- permissions: PermissionsSlice;
108
- fieldTransforms: FieldTransforms;
109
- };
6
+ import react__default, { ReactNode, SyntheticEvent, ReactElement, CSSProperties } from 'react';
7
+ import { A as AppStore, G as GetPermissions, R as RefreshPermissions, H as HistorySlice } from './index-mQvUCH3C.mjs';
8
+ import '@tiptap/react';
9
+ import '@tiptap/extension-blockquote';
10
+ import '@tiptap/extension-bold';
11
+ import '@tiptap/extension-code';
12
+ import '@tiptap/extension-code-block';
13
+ import '@tiptap/extension-hard-break';
14
+ import '@tiptap/extension-heading';
15
+ import '@tiptap/extension-horizontal-rule';
16
+ import '@tiptap/extension-italic';
17
+ import '@tiptap/extension-link';
18
+ import '@tiptap/extension-list';
19
+ import '@tiptap/extension-paragraph';
20
+ import '@tiptap/extension-strike';
21
+ import '@tiptap/extension-text-align';
22
+ import '@tiptap/extension-underline';
110
23
 
111
24
  declare const ActionBar: {
112
25
  ({ label, children, }: {
113
26
  label?: string;
114
27
  children?: ReactNode;
115
28
  }): react_jsx_runtime.JSX.Element;
116
- Action: ({ children, label, onClick, }: {
29
+ Action: ({ children, label, onClick, active, disabled, }: {
117
30
  children: ReactNode;
118
31
  label?: string;
119
32
  onClick: (e: SyntheticEvent) => void;
33
+ active?: boolean;
34
+ disabled?: boolean;
120
35
  }) => react_jsx_runtime.JSX.Element;
121
36
  Label: ({ label }: {
122
37
  label: string;
@@ -124,11 +39,14 @@ declare const ActionBar: {
124
39
  Group: ({ children }: {
125
40
  children: ReactNode;
126
41
  }) => react_jsx_runtime.JSX.Element;
42
+ Separator: () => react_jsx_runtime.JSX.Element;
127
43
  };
128
- declare const Action: ({ children, label, onClick, }: {
44
+ declare const Action: ({ children, label, onClick, active, disabled, }: {
129
45
  children: ReactNode;
130
46
  label?: string;
131
47
  onClick: (e: SyntheticEvent) => void;
48
+ active?: boolean;
49
+ disabled?: boolean;
132
50
  }) => react_jsx_runtime.JSX.Element;
133
51
  declare const Group: ({ children }: {
134
52
  children: ReactNode;
@@ -136,6 +54,7 @@ declare const Group: ({ children }: {
136
54
  declare const Label: ({ label }: {
137
55
  label: string;
138
56
  }) => react_jsx_runtime.JSX.Element;
57
+ declare const Separator: () => react_jsx_runtime.JSX.Element;
139
58
 
140
59
  declare const FieldLabel: ({ children, icon, label, el, readOnly, className, }: {
141
60
  children?: ReactNode;
@@ -145,8 +64,11 @@ declare const FieldLabel: ({ children, icon, label, el, readOnly, className, }:
145
64
  readOnly?: boolean;
146
65
  className?: string;
147
66
  }) => react_jsx_runtime.JSX.Element;
67
+
148
68
  type FieldNoLabel<Props extends any = any> = Omit<Field<Props>, "label">;
149
- declare function AutoField<ValueType = any, FieldType extends FieldNoLabel<ValueType> = FieldNoLabel<ValueType>>(props: FieldProps<FieldType, ValueType>): react_jsx_runtime.JSX.Element | null;
69
+ declare function AutoField<ValueType = any, FieldType extends FieldNoLabel<ValueType> = FieldNoLabel<ValueType>>(props: FieldProps<FieldType, ValueType> & {
70
+ value: any;
71
+ }): react_jsx_runtime.JSX.Element | null;
150
72
 
151
73
  declare const Button: ({ children, href, onClick, variant, type, disabled, tabIndex, newTab, fullWidth, icon, size, loading: loadingProp, ...props }: {
152
74
  children: ReactNode;
@@ -182,19 +104,20 @@ declare const Drawer: {
182
104
  }) => react_jsx_runtime.JSX.Element;
183
105
  };
184
106
 
185
- declare const DropZone: react.ForwardRefExoticComponent<DropZoneProps & react.RefAttributes<HTMLDivElement>>;
107
+ declare const DropZone: react.ForwardRefExoticComponent<Omit<DropZoneProps, "ref"> & react.RefAttributes<HTMLDivElement>>;
186
108
 
187
- declare const IconButton: ({ children, href, onClick, variant, type, disabled, tabIndex, newTab, fullWidth, title, }: {
109
+ declare const IconButton: ({ active, children, href, onClick, type, disabled, tabIndex, newTab, fullWidth, title, suppressHydrationWarning, }: {
110
+ active?: boolean;
188
111
  children: ReactNode;
189
112
  href?: string;
190
113
  onClick?: (e: SyntheticEvent) => void | Promise<void>;
191
- variant?: "primary" | "secondary";
192
114
  type?: "button" | "submit" | "reset";
193
115
  disabled?: boolean;
194
116
  tabIndex?: number;
195
117
  newTab?: boolean;
196
118
  fullWidth?: boolean;
197
119
  title: string;
120
+ suppressHydrationWarning?: boolean;
198
121
  }) => react_jsx_runtime.JSX.Element;
199
122
 
200
123
  type PuckProps<UserConfig extends Config = Config, G extends UserGenerics<UserConfig> = UserGenerics<UserConfig>> = {
@@ -227,6 +150,8 @@ type PuckProps<UserConfig extends Config = Config, G extends UserGenerics<UserCo
227
150
  };
228
151
  initialHistory?: InitialHistory;
229
152
  metadata?: Metadata;
153
+ height?: CSSProperties["height"];
154
+ _experimentalFullScreenCanvas?: boolean;
230
155
  };
231
156
  declare function Puck<UserConfig extends Config = Config, G extends UserGenerics<UserConfig> = UserGenerics<UserConfig>>(props: PuckProps<UserConfig>): react_jsx_runtime.JSX.Element;
232
157
  declare namespace Puck {
@@ -234,6 +159,9 @@ declare namespace Puck {
234
159
  var Fields: react.MemoExoticComponent<({ wrapFields }: {
235
160
  wrapFields?: boolean;
236
161
  }) => react_jsx_runtime.JSX.Element>;
162
+ var Layout: ({ children }: {
163
+ children?: ReactNode;
164
+ }) => react_jsx_runtime.JSX.Element;
237
165
  var Outline: () => react_jsx_runtime.JSX.Element;
238
166
  var Preview: ({ id }: {
239
167
  id?: string;
@@ -251,6 +179,69 @@ declare function Render<UserConfig extends Config = Config, G extends UserGeneri
251
179
  metadata?: Metadata;
252
180
  }): react_jsx_runtime.JSX.Element;
253
181
 
182
+ declare function AlignLeft(): react_jsx_runtime.JSX.Element;
183
+
184
+ declare function AlignCenter(): react_jsx_runtime.JSX.Element;
185
+
186
+ declare function AlignRight(): react_jsx_runtime.JSX.Element;
187
+
188
+ declare function AlignJustify(): react_jsx_runtime.JSX.Element;
189
+
190
+ declare function Bold(): react_jsx_runtime.JSX.Element;
191
+
192
+ declare function Italic(): react_jsx_runtime.JSX.Element;
193
+
194
+ declare function Underline(): react_jsx_runtime.JSX.Element;
195
+
196
+ declare function Strikethrough(): react_jsx_runtime.JSX.Element;
197
+
198
+ declare function InlineCode(): react_jsx_runtime.JSX.Element;
199
+
200
+ declare function BulletList(): react_jsx_runtime.JSX.Element;
201
+
202
+ declare function OrderedList(): react_jsx_runtime.JSX.Element;
203
+
204
+ declare function CodeBlock(): react_jsx_runtime.JSX.Element;
205
+
206
+ declare function Blockquote(): react_jsx_runtime.JSX.Element;
207
+
208
+ declare function HorizontalRule(): react_jsx_runtime.JSX.Element;
209
+
210
+ declare function Control({ icon, disabled, active, onClick, title, }: {
211
+ icon: ReactNode;
212
+ disabled?: boolean;
213
+ active?: boolean;
214
+ onClick: (e: SyntheticEvent) => any;
215
+ title: string;
216
+ }): react_jsx_runtime.JSX.Element;
217
+
218
+ declare const RichTextMenu: {
219
+ ({ children }: {
220
+ children: ReactNode;
221
+ }): react_jsx_runtime.JSX.Element;
222
+ Group: ({ children }: {
223
+ children: ReactNode;
224
+ }) => react_jsx_runtime.JSX.Element;
225
+ Control: typeof Control;
226
+ AlignCenter: typeof AlignCenter;
227
+ AlignJustify: typeof AlignJustify;
228
+ AlignLeft: typeof AlignLeft;
229
+ AlignRight: typeof AlignRight;
230
+ AlignSelect: () => react_jsx_runtime.JSX.Element;
231
+ Blockquote: typeof Blockquote;
232
+ Bold: typeof Bold;
233
+ BulletList: typeof BulletList;
234
+ CodeBlock: typeof CodeBlock;
235
+ HeadingSelect: () => react_jsx_runtime.JSX.Element;
236
+ HorizontalRule: typeof HorizontalRule;
237
+ InlineCode: typeof InlineCode;
238
+ Italic: typeof Italic;
239
+ ListSelect: () => react_jsx_runtime.JSX.Element;
240
+ OrderedList: typeof OrderedList;
241
+ Strikethrough: typeof Strikethrough;
242
+ Underline: typeof Underline;
243
+ };
244
+
254
245
  declare const registerOverlayPortal: (el: HTMLElement | null | undefined, opts?: {
255
246
  disableDrag?: boolean;
256
247
  disableDragOnFocus?: boolean;
@@ -271,6 +262,7 @@ type UsePuckData<UserConfig extends Config = Config, G extends UserGenerics<User
271
262
  getItemBySelector: (selector: ItemSelector) => G["UserComponentData"] | undefined;
272
263
  getItemById: (id: string) => G["UserComponentData"] | undefined;
273
264
  getSelectorForId: (id: string) => Required<ItemSelector> | undefined;
265
+ getParentById: (id: string) => ComponentData | undefined;
274
266
  history: {
275
267
  back: HistorySlice["back"];
276
268
  forward: HistorySlice["forward"];
@@ -302,4 +294,14 @@ declare function usePuck<UserConfig extends Config = Config>(): UsePuckStore<Use
302
294
  */
303
295
  declare function useGetPuck(): () => UsePuckStore<Config>;
304
296
 
305
- export { Action, ActionBar, AppState, AutoField, Button, ComponentConfig, ComponentData, Config, Data, Drawer, DropZone, Field, FieldLabel, FieldProps, FieldTransforms, Fields, Group, History, IconButton, IframeConfig, InitialHistory, Label, Metadata, OnAction, Overrides, Permissions, Plugin, Puck, PuckAction, type PuckApi, Render, ResolveDataTrigger, RootDataWithProps, UiState, type UsePuckData, UserGenerics, Viewports, createUsePuck, registerOverlayPortal, renderContext, setDeep, useGetPuck, usePuck };
297
+ declare const blocksPlugin: () => Plugin;
298
+
299
+ declare const fieldsPlugin: (params?: {
300
+ mobileOnly?: boolean;
301
+ }) => PluginInternal;
302
+
303
+ declare const outlinePlugin: () => Plugin;
304
+
305
+ declare const legacySideBarPlugin: () => Plugin;
306
+
307
+ export { Action, ActionBar, AutoField, Button, ComponentData, Config, Data, Drawer, DropZone, Field, FieldLabel, FieldProps, FieldTransforms, Group, IconButton, IframeConfig, InitialHistory, Label, Metadata, OnAction, Overrides, Permissions, Plugin, Puck, PuckAction, type PuckApi, Render, RichTextMenu, Separator, UiState, type UsePuckData, UserGenerics, Viewports, blocksPlugin, createUsePuck, fieldsPlugin, legacySideBarPlugin, outlinePlugin, registerOverlayPortal, renderContext, setDeep, useGetPuck, usePuck };
package/dist/index.d.ts CHANGED
@@ -1,122 +1,37 @@
1
- import { H as History, P as Permissions, a as ComponentData, C as Config, U as UserGenerics, F as Fields, b as PuckAction, R as RootDataWithProps, c as ResolveDataTrigger, d as Plugin, O as Overrides, V as Viewports, I as IframeConfig, e as UiState, f as ComponentConfig, A as AppState, M as Metadata, g as FieldTransforms, h as Field, i as FieldProps, D as DropZoneProps, j as Data, k as OnAction, l as InitialHistory, n as ItemSelector } from './walk-tree-Ctf3FZQI.js';
2
- export { a7 as Adaptor, a5 as ArrayField, B as ArrayState, ak as AsFieldProps, N as BaseData, $ as BaseField, Z as ComponentDataMap, X as ComponentDataOptionalId, _ as Content, ab as CustomField, aa as CustomFieldRender, ah as DefaultComponentProps, K as DefaultComponents, ae as DefaultRootFieldProps, ag as DefaultRootProps, af as DefaultRootRenderProps, o as Direction, p as DragAxis, a9 as ExternalField, a8 as ExternalFieldWithAdaptor, L as ExtractConfigParams, am as ExtractField, y as FieldRenderFunctions, u as FieldTransformFn, s as FieldTransformFnParams, z as ItemWithId, Y as MappedItem, a1 as NumberField, a6 as ObjectField, x as OverrideKey, G as PuckComponent, ad as PuckContext, a4 as RadioField, J as RootConfig, T as RootData, Q as RootDataWithoutProps, a3 as SelectField, S as Slot, E as SlotComponent, ac as SlotField, a0 as TextField, a2 as TextareaField, q as Viewport, al as WithChildren, ai as WithId, aj as WithPuckProps, W as WithSlotProps, m as migrate, v as overrideKeys, r as resolveAllData, t as transformProps, w as walkTree } from './walk-tree-Ctf3FZQI.js';
1
+ import { p as Field, q as FieldProps, r as DropZoneProps, C as Config, U as UserGenerics, D as Data, l as UiState, O as OnAction, g as Permissions, j as Plugin, k as Overrides, n as FieldTransforms, a as PuckAction, V as Viewports, I as IframeConfig, s as InitialHistory, M as Metadata, t as ItemSelector, c as ComponentData, u as PluginInternal } from './actions-tsxxcX1z.js';
2
+ export { ag as Adaptor, A as AppState, ae as ArrayField, N as ArrayState, ar as AsFieldProps, a0 as BaseData, a8 as BaseField, ai as CacheOpts, m as ComponentConfig, X as ComponentConfigExtensions, $ as ComponentConfigParams, a4 as ComponentDataMap, a2 as ComponentDataOptionalId, a6 as ComponentMetadata, _ as ConfigParams, b as Content, al as CustomField, ak as CustomFieldRender, e as DefaultComponentProps, d as DefaultComponents, f as DefaultRootFieldProps, ap as DefaultRootProps, ao as DefaultRootRenderProps, x as Direction, y as DragAxis, aj as ExternalField, ah as ExternalFieldWithAdaptor, Z as ExtractConfigParams, at as ExtractField, a7 as FieldMetadata, K as FieldRenderFunctions, E as FieldTransformFn, B as FieldTransformFnParams, F as Fields, H as History, L as ItemWithId, a3 as MappedItem, aa as NumberField, af as ObjectField, J as OverrideKey, T as PuckComponent, an as PuckContext, a5 as PuckMetadata, ad as RadioField, i as ResolveDataTrigger, w as RichText, o as RichtextField, Y as RootConfig, R as RootData, h as RootDataWithProps, a1 as RootDataWithoutProps, ac as SelectField, S as Slot, Q as SlotComponent, am as SlotField, a9 as TextField, ab as TextareaField, z as Viewport, as as WithChildren, W as WithId, aq as WithPuckProps, v as WithSlotProps, G as overrideKeys } from './actions-tsxxcX1z.js';
3
+ export { m as migrate, r as resolveAllData, t as transformProps, w as walkTree } from './walk-tree-Bh85NMeo.js';
3
4
  import * as react_jsx_runtime from 'react/jsx-runtime';
4
5
  import * as react from 'react';
5
- import react__default, { ReactNode, SyntheticEvent, ReactElement } from 'react';
6
-
7
- type HistorySlice<D = any> = {
8
- index: number;
9
- hasPast: () => boolean;
10
- hasFuture: () => boolean;
11
- histories: History<D>[];
12
- record: (data: D) => void;
13
- back: VoidFunction;
14
- forward: VoidFunction;
15
- currentHistory: () => History;
16
- nextHistory: () => History<D> | null;
17
- prevHistory: () => History<D> | null;
18
- setHistories: (histories: History[]) => void;
19
- setHistoryIndex: (index: number) => void;
20
- initialAppState: D;
21
- };
22
-
23
- type NodeMethods = {
24
- sync: () => void;
25
- hideOverlay: () => void;
26
- showOverlay: () => void;
27
- };
28
- type PuckNodeInstance = {
29
- id: string;
30
- methods: NodeMethods;
31
- element: HTMLElement | null;
32
- };
33
- type NodesSlice = {
34
- nodes: Record<string, PuckNodeInstance | undefined>;
35
- registerNode: (id: string, node: Partial<PuckNodeInstance>) => void;
36
- unregisterNode: (id: string, node?: Partial<PuckNodeInstance>) => void;
37
- };
38
-
39
- type PermissionsArgs<UserConfig extends Config = Config, G extends UserGenerics<UserConfig> = UserGenerics<UserConfig>> = {
40
- item?: G["UserComponentData"] | null;
41
- type?: keyof G["UserProps"];
42
- root?: boolean;
43
- };
44
- type GetPermissions<UserConfig extends Config = Config> = (params?: PermissionsArgs<UserConfig>) => Permissions;
45
- type ResolvePermissions<UserConfig extends Config = Config> = (params?: PermissionsArgs<UserConfig>, force?: boolean) => void;
46
- type RefreshPermissions<UserConfig extends Config = Config> = (params?: PermissionsArgs<UserConfig>, force?: boolean) => void;
47
- type Cache = Record<string, {
48
- lastPermissions: Partial<Permissions>;
49
- lastData: ComponentData | null;
50
- }>;
51
- type PermissionsSlice = {
52
- cache: Cache;
53
- globalPermissions: Permissions;
54
- resolvedPermissions: Record<string, Partial<Permissions> | undefined>;
55
- getPermissions: GetPermissions<Config>;
56
- resolvePermissions: ResolvePermissions<Config>;
57
- refreshPermissions: RefreshPermissions<Config>;
58
- };
59
-
60
- type ComponentOrRootData = Omit<ComponentData<any>, "type">;
61
- type FieldsSlice = {
62
- fields: Fields | Partial<Fields>;
63
- loading: boolean;
64
- lastResolvedData: Partial<ComponentOrRootData>;
65
- id: string | undefined;
66
- };
67
-
68
- type Status = "LOADING" | "MOUNTED" | "READY";
69
- type ZoomConfig = {
70
- autoZoom: number;
71
- rootHeight: number;
72
- zoom: number;
73
- };
74
- type ComponentState = Record<string, {
75
- loadingCount: number;
76
- }>;
77
- type AppStore<UserConfig extends Config = Config, G extends UserGenerics<UserConfig> = UserGenerics<UserConfig>> = {
78
- state: G["UserAppState"];
79
- dispatch: (action: PuckAction) => void;
80
- config: UserConfig;
81
- componentState: ComponentState;
82
- setComponentState: (componentState: ComponentState) => void;
83
- setComponentLoading: (id: string, loading?: boolean, defer?: number) => () => void;
84
- unsetComponentLoading: (id: string) => void;
85
- pendingLoadTimeouts: Record<string, NodeJS.Timeout>;
86
- resolveComponentData: <T extends ComponentData | RootDataWithProps>(componentData: T, trigger: ResolveDataTrigger) => Promise<{
87
- node: T;
88
- didChange: boolean;
89
- }>;
90
- resolveAndCommitData: () => void;
91
- plugins: Plugin[];
92
- overrides: Partial<Overrides>;
93
- viewports: Viewports;
94
- zoomConfig: ZoomConfig;
95
- setZoomConfig: (zoomConfig: ZoomConfig) => void;
96
- status: Status;
97
- setStatus: (status: Status) => void;
98
- iframe: IframeConfig;
99
- selectedItem?: G["UserData"]["content"][0] | null;
100
- setUi: (ui: Partial<UiState>, recordHistory?: boolean) => void;
101
- getComponentConfig: (type?: string) => ComponentConfig | null | undefined;
102
- onAction?: (action: PuckAction, newState: AppState, state: AppState) => void;
103
- metadata: Metadata;
104
- fields: FieldsSlice;
105
- history: HistorySlice;
106
- nodes: NodesSlice;
107
- permissions: PermissionsSlice;
108
- fieldTransforms: FieldTransforms;
109
- };
6
+ import react__default, { ReactNode, SyntheticEvent, ReactElement, CSSProperties } from 'react';
7
+ import { A as AppStore, G as GetPermissions, R as RefreshPermissions, H as HistorySlice } from './index-Ca6V6NQD.js';
8
+ import '@tiptap/react';
9
+ import '@tiptap/extension-blockquote';
10
+ import '@tiptap/extension-bold';
11
+ import '@tiptap/extension-code';
12
+ import '@tiptap/extension-code-block';
13
+ import '@tiptap/extension-hard-break';
14
+ import '@tiptap/extension-heading';
15
+ import '@tiptap/extension-horizontal-rule';
16
+ import '@tiptap/extension-italic';
17
+ import '@tiptap/extension-link';
18
+ import '@tiptap/extension-list';
19
+ import '@tiptap/extension-paragraph';
20
+ import '@tiptap/extension-strike';
21
+ import '@tiptap/extension-text-align';
22
+ import '@tiptap/extension-underline';
110
23
 
111
24
  declare const ActionBar: {
112
25
  ({ label, children, }: {
113
26
  label?: string;
114
27
  children?: ReactNode;
115
28
  }): react_jsx_runtime.JSX.Element;
116
- Action: ({ children, label, onClick, }: {
29
+ Action: ({ children, label, onClick, active, disabled, }: {
117
30
  children: ReactNode;
118
31
  label?: string;
119
32
  onClick: (e: SyntheticEvent) => void;
33
+ active?: boolean;
34
+ disabled?: boolean;
120
35
  }) => react_jsx_runtime.JSX.Element;
121
36
  Label: ({ label }: {
122
37
  label: string;
@@ -124,11 +39,14 @@ declare const ActionBar: {
124
39
  Group: ({ children }: {
125
40
  children: ReactNode;
126
41
  }) => react_jsx_runtime.JSX.Element;
42
+ Separator: () => react_jsx_runtime.JSX.Element;
127
43
  };
128
- declare const Action: ({ children, label, onClick, }: {
44
+ declare const Action: ({ children, label, onClick, active, disabled, }: {
129
45
  children: ReactNode;
130
46
  label?: string;
131
47
  onClick: (e: SyntheticEvent) => void;
48
+ active?: boolean;
49
+ disabled?: boolean;
132
50
  }) => react_jsx_runtime.JSX.Element;
133
51
  declare const Group: ({ children }: {
134
52
  children: ReactNode;
@@ -136,6 +54,7 @@ declare const Group: ({ children }: {
136
54
  declare const Label: ({ label }: {
137
55
  label: string;
138
56
  }) => react_jsx_runtime.JSX.Element;
57
+ declare const Separator: () => react_jsx_runtime.JSX.Element;
139
58
 
140
59
  declare const FieldLabel: ({ children, icon, label, el, readOnly, className, }: {
141
60
  children?: ReactNode;
@@ -145,8 +64,11 @@ declare const FieldLabel: ({ children, icon, label, el, readOnly, className, }:
145
64
  readOnly?: boolean;
146
65
  className?: string;
147
66
  }) => react_jsx_runtime.JSX.Element;
67
+
148
68
  type FieldNoLabel<Props extends any = any> = Omit<Field<Props>, "label">;
149
- declare function AutoField<ValueType = any, FieldType extends FieldNoLabel<ValueType> = FieldNoLabel<ValueType>>(props: FieldProps<FieldType, ValueType>): react_jsx_runtime.JSX.Element | null;
69
+ declare function AutoField<ValueType = any, FieldType extends FieldNoLabel<ValueType> = FieldNoLabel<ValueType>>(props: FieldProps<FieldType, ValueType> & {
70
+ value: any;
71
+ }): react_jsx_runtime.JSX.Element | null;
150
72
 
151
73
  declare const Button: ({ children, href, onClick, variant, type, disabled, tabIndex, newTab, fullWidth, icon, size, loading: loadingProp, ...props }: {
152
74
  children: ReactNode;
@@ -182,19 +104,20 @@ declare const Drawer: {
182
104
  }) => react_jsx_runtime.JSX.Element;
183
105
  };
184
106
 
185
- declare const DropZone: react.ForwardRefExoticComponent<DropZoneProps & react.RefAttributes<HTMLDivElement>>;
107
+ declare const DropZone: react.ForwardRefExoticComponent<Omit<DropZoneProps, "ref"> & react.RefAttributes<HTMLDivElement>>;
186
108
 
187
- declare const IconButton: ({ children, href, onClick, variant, type, disabled, tabIndex, newTab, fullWidth, title, }: {
109
+ declare const IconButton: ({ active, children, href, onClick, type, disabled, tabIndex, newTab, fullWidth, title, suppressHydrationWarning, }: {
110
+ active?: boolean;
188
111
  children: ReactNode;
189
112
  href?: string;
190
113
  onClick?: (e: SyntheticEvent) => void | Promise<void>;
191
- variant?: "primary" | "secondary";
192
114
  type?: "button" | "submit" | "reset";
193
115
  disabled?: boolean;
194
116
  tabIndex?: number;
195
117
  newTab?: boolean;
196
118
  fullWidth?: boolean;
197
119
  title: string;
120
+ suppressHydrationWarning?: boolean;
198
121
  }) => react_jsx_runtime.JSX.Element;
199
122
 
200
123
  type PuckProps<UserConfig extends Config = Config, G extends UserGenerics<UserConfig> = UserGenerics<UserConfig>> = {
@@ -227,6 +150,8 @@ type PuckProps<UserConfig extends Config = Config, G extends UserGenerics<UserCo
227
150
  };
228
151
  initialHistory?: InitialHistory;
229
152
  metadata?: Metadata;
153
+ height?: CSSProperties["height"];
154
+ _experimentalFullScreenCanvas?: boolean;
230
155
  };
231
156
  declare function Puck<UserConfig extends Config = Config, G extends UserGenerics<UserConfig> = UserGenerics<UserConfig>>(props: PuckProps<UserConfig>): react_jsx_runtime.JSX.Element;
232
157
  declare namespace Puck {
@@ -234,6 +159,9 @@ declare namespace Puck {
234
159
  var Fields: react.MemoExoticComponent<({ wrapFields }: {
235
160
  wrapFields?: boolean;
236
161
  }) => react_jsx_runtime.JSX.Element>;
162
+ var Layout: ({ children }: {
163
+ children?: ReactNode;
164
+ }) => react_jsx_runtime.JSX.Element;
237
165
  var Outline: () => react_jsx_runtime.JSX.Element;
238
166
  var Preview: ({ id }: {
239
167
  id?: string;
@@ -251,6 +179,69 @@ declare function Render<UserConfig extends Config = Config, G extends UserGeneri
251
179
  metadata?: Metadata;
252
180
  }): react_jsx_runtime.JSX.Element;
253
181
 
182
+ declare function AlignLeft(): react_jsx_runtime.JSX.Element;
183
+
184
+ declare function AlignCenter(): react_jsx_runtime.JSX.Element;
185
+
186
+ declare function AlignRight(): react_jsx_runtime.JSX.Element;
187
+
188
+ declare function AlignJustify(): react_jsx_runtime.JSX.Element;
189
+
190
+ declare function Bold(): react_jsx_runtime.JSX.Element;
191
+
192
+ declare function Italic(): react_jsx_runtime.JSX.Element;
193
+
194
+ declare function Underline(): react_jsx_runtime.JSX.Element;
195
+
196
+ declare function Strikethrough(): react_jsx_runtime.JSX.Element;
197
+
198
+ declare function InlineCode(): react_jsx_runtime.JSX.Element;
199
+
200
+ declare function BulletList(): react_jsx_runtime.JSX.Element;
201
+
202
+ declare function OrderedList(): react_jsx_runtime.JSX.Element;
203
+
204
+ declare function CodeBlock(): react_jsx_runtime.JSX.Element;
205
+
206
+ declare function Blockquote(): react_jsx_runtime.JSX.Element;
207
+
208
+ declare function HorizontalRule(): react_jsx_runtime.JSX.Element;
209
+
210
+ declare function Control({ icon, disabled, active, onClick, title, }: {
211
+ icon: ReactNode;
212
+ disabled?: boolean;
213
+ active?: boolean;
214
+ onClick: (e: SyntheticEvent) => any;
215
+ title: string;
216
+ }): react_jsx_runtime.JSX.Element;
217
+
218
+ declare const RichTextMenu: {
219
+ ({ children }: {
220
+ children: ReactNode;
221
+ }): react_jsx_runtime.JSX.Element;
222
+ Group: ({ children }: {
223
+ children: ReactNode;
224
+ }) => react_jsx_runtime.JSX.Element;
225
+ Control: typeof Control;
226
+ AlignCenter: typeof AlignCenter;
227
+ AlignJustify: typeof AlignJustify;
228
+ AlignLeft: typeof AlignLeft;
229
+ AlignRight: typeof AlignRight;
230
+ AlignSelect: () => react_jsx_runtime.JSX.Element;
231
+ Blockquote: typeof Blockquote;
232
+ Bold: typeof Bold;
233
+ BulletList: typeof BulletList;
234
+ CodeBlock: typeof CodeBlock;
235
+ HeadingSelect: () => react_jsx_runtime.JSX.Element;
236
+ HorizontalRule: typeof HorizontalRule;
237
+ InlineCode: typeof InlineCode;
238
+ Italic: typeof Italic;
239
+ ListSelect: () => react_jsx_runtime.JSX.Element;
240
+ OrderedList: typeof OrderedList;
241
+ Strikethrough: typeof Strikethrough;
242
+ Underline: typeof Underline;
243
+ };
244
+
254
245
  declare const registerOverlayPortal: (el: HTMLElement | null | undefined, opts?: {
255
246
  disableDrag?: boolean;
256
247
  disableDragOnFocus?: boolean;
@@ -271,6 +262,7 @@ type UsePuckData<UserConfig extends Config = Config, G extends UserGenerics<User
271
262
  getItemBySelector: (selector: ItemSelector) => G["UserComponentData"] | undefined;
272
263
  getItemById: (id: string) => G["UserComponentData"] | undefined;
273
264
  getSelectorForId: (id: string) => Required<ItemSelector> | undefined;
265
+ getParentById: (id: string) => ComponentData | undefined;
274
266
  history: {
275
267
  back: HistorySlice["back"];
276
268
  forward: HistorySlice["forward"];
@@ -302,4 +294,14 @@ declare function usePuck<UserConfig extends Config = Config>(): UsePuckStore<Use
302
294
  */
303
295
  declare function useGetPuck(): () => UsePuckStore<Config>;
304
296
 
305
- export { Action, ActionBar, AppState, AutoField, Button, ComponentConfig, ComponentData, Config, Data, Drawer, DropZone, Field, FieldLabel, FieldProps, FieldTransforms, Fields, Group, History, IconButton, IframeConfig, InitialHistory, Label, Metadata, OnAction, Overrides, Permissions, Plugin, Puck, PuckAction, type PuckApi, Render, ResolveDataTrigger, RootDataWithProps, UiState, type UsePuckData, UserGenerics, Viewports, createUsePuck, registerOverlayPortal, renderContext, setDeep, useGetPuck, usePuck };
297
+ declare const blocksPlugin: () => Plugin;
298
+
299
+ declare const fieldsPlugin: (params?: {
300
+ mobileOnly?: boolean;
301
+ }) => PluginInternal;
302
+
303
+ declare const outlinePlugin: () => Plugin;
304
+
305
+ declare const legacySideBarPlugin: () => Plugin;
306
+
307
+ export { Action, ActionBar, AutoField, Button, ComponentData, Config, Data, Drawer, DropZone, Field, FieldLabel, FieldProps, FieldTransforms, Group, IconButton, IframeConfig, InitialHistory, Label, Metadata, OnAction, Overrides, Permissions, Plugin, Puck, PuckAction, type PuckApi, Render, RichTextMenu, Separator, UiState, type UsePuckData, UserGenerics, Viewports, blocksPlugin, createUsePuck, fieldsPlugin, legacySideBarPlugin, outlinePlugin, registerOverlayPortal, renderContext, setDeep, useGetPuck, usePuck };