@riverbankcms/sdk 0.7.2 → 0.7.3
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/README.md +54 -0
- package/dist/client/bookings.d.mts +2 -0
- package/dist/client/bookings.d.ts +2 -0
- package/dist/client/bookings.js +2956 -104
- package/dist/client/bookings.js.map +1 -1
- package/dist/client/bookings.mjs +2929 -70
- package/dist/client/bookings.mjs.map +1 -1
- package/dist/client/client.d.mts +2 -2
- package/dist/client/client.d.ts +2 -2
- package/dist/client/client.js +80 -11
- package/dist/client/client.js.map +1 -1
- package/dist/client/client.mjs +87 -11
- package/dist/client/client.mjs.map +1 -1
- package/dist/client/hooks.d.mts +2 -2
- package/dist/client/hooks.d.ts +2 -2
- package/dist/client/rendering/client.js +3070 -259
- package/dist/client/rendering/client.js.map +1 -1
- package/dist/client/rendering/client.mjs +3212 -395
- package/dist/client/rendering/client.mjs.map +1 -1
- package/dist/client/spam-protection.d.mts +55 -0
- package/dist/client/spam-protection.d.ts +55 -0
- package/dist/client/spam-protection.js +2915 -0
- package/dist/client/spam-protection.js.map +1 -0
- package/dist/client/spam-protection.mjs +2893 -0
- package/dist/client/spam-protection.mjs.map +1 -0
- package/dist/client/{usePage-Db9kzA41.d.ts → usePage-BYmJCCm1.d.ts} +14 -2
- package/dist/client/{usePage-C9tJpuKa.d.mts → usePage-DZtrWajy.d.mts} +14 -2
- package/dist/server/{Layout-Ce7PU9I5.d.ts → Layout-Yluyb6sK.d.ts} +1 -1
- package/dist/server/{Layout-WllR8Zug.d.mts → Layout-qWLdVm5-.d.mts} +1 -1
- package/dist/server/chunk-2IZ6S225.js +122 -0
- package/dist/server/chunk-2IZ6S225.js.map +1 -0
- package/dist/server/chunk-4CV4JOE5.js +27 -0
- package/dist/server/chunk-4CV4JOE5.js.map +1 -0
- package/dist/server/{chunk-AET56TQX.mjs → chunk-5LRR64Y6.mjs} +32 -5
- package/dist/server/chunk-5LRR64Y6.mjs.map +1 -0
- package/dist/server/{chunk-VODFQMUW.js → chunk-NBTRDLCM.js} +32 -5
- package/dist/server/chunk-NBTRDLCM.js.map +1 -0
- package/dist/server/chunk-NFEGQTCC.mjs +27 -0
- package/dist/server/{chunk-5JT452F2.mjs → chunk-NFQLH5IA.mjs} +340 -19
- package/dist/server/chunk-NFQLH5IA.mjs.map +1 -0
- package/dist/server/chunk-PPHZV6YD.mjs +122 -0
- package/dist/server/chunk-PPHZV6YD.mjs.map +1 -0
- package/dist/server/{chunk-HMENX4Y7.js → chunk-VLXTNB2C.js} +370 -49
- package/dist/server/chunk-VLXTNB2C.js.map +1 -0
- package/dist/server/{components-RPzRQve6.d.mts → components-DNHfSCML.d.mts} +3 -3
- package/dist/server/{components--LT61IKp.d.ts → components-Di5ME6He.d.ts} +3 -3
- package/dist/server/components.d.mts +5 -5
- package/dist/server/components.d.ts +5 -5
- package/dist/server/components.js +1 -0
- package/dist/server/components.js.map +1 -1
- package/dist/server/components.mjs +1 -0
- package/dist/server/config-validation.js +1 -0
- package/dist/server/config-validation.js.map +1 -1
- package/dist/server/config-validation.mjs +1 -0
- package/dist/server/config.js +1 -0
- package/dist/server/config.js.map +1 -1
- package/dist/server/config.mjs +1 -0
- package/dist/server/config.mjs.map +1 -1
- package/dist/server/data.d.mts +2 -2
- package/dist/server/data.d.ts +2 -2
- package/dist/server/data.js +1 -0
- package/dist/server/data.js.map +1 -1
- package/dist/server/data.mjs +1 -0
- package/dist/server/env.d.mts +91 -5
- package/dist/server/env.d.ts +91 -5
- package/dist/server/env.js +9 -2
- package/dist/server/env.js.map +1 -1
- package/dist/server/env.mjs +8 -1
- package/dist/server/{index-BL66CU6d.d.mts → index--Oyunk_B.d.mts} +2 -2
- package/dist/server/{index-CJk9iQQW.d.ts → index-C9Ra8dza.d.ts} +2 -2
- package/dist/server/{index-Bkva0WAj.d.mts → index-Clm3skz_.d.mts} +1 -1
- package/dist/server/{index-CSBWKA3r.d.ts → index-DLvNddi-.d.ts} +1 -1
- package/dist/server/index.d.mts +215 -4
- package/dist/server/index.d.ts +215 -4
- package/dist/server/index.js +301 -3
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.mjs +301 -3
- package/dist/server/index.mjs.map +1 -1
- package/dist/server/{loadContent-CXUWMuzY.d.ts → loadContent-D7LQwI0o.d.ts} +3 -3
- package/dist/server/{loadContent-F_tAS0Nl.d.mts → loadContent-DVfuBLiZ.d.mts} +3 -3
- package/dist/server/{loadPage-6I7F6GRF.js → loadPage-AXNAERDS.js} +2 -1
- package/dist/server/loadPage-AXNAERDS.js.map +1 -0
- package/dist/server/{loadPage-i2r-X5b9.d.ts → loadPage-BmYJCe_V.d.ts} +2 -2
- package/dist/server/{loadPage-CxlYLe5K.d.mts → loadPage-BucnLHmE.d.mts} +2 -2
- package/dist/server/{loadPage-JI2SML4M.mjs → loadPage-XR7ORQ2E.mjs} +2 -1
- package/dist/server/loadPage-XR7ORQ2E.mjs.map +1 -0
- package/dist/server/metadata.d.mts +4 -4
- package/dist/server/metadata.d.ts +4 -4
- package/dist/server/metadata.js +1 -0
- package/dist/server/metadata.js.map +1 -1
- package/dist/server/metadata.mjs +1 -0
- package/dist/server/navigation.d.mts +2 -2
- package/dist/server/navigation.d.ts +2 -2
- package/dist/server/navigation.js +1 -0
- package/dist/server/navigation.js.map +1 -1
- package/dist/server/navigation.mjs +1 -0
- package/dist/server/next/revalidate.js +5 -4
- package/dist/server/next/revalidate.js.map +1 -1
- package/dist/server/next/revalidate.mjs +3 -2
- package/dist/server/next/revalidate.mjs.map +1 -1
- package/dist/server/next/tags.d.mts +3 -0
- package/dist/server/next/tags.d.ts +3 -0
- package/dist/server/next/tags.js +3 -1
- package/dist/server/next/tags.js.map +1 -1
- package/dist/server/next/tags.mjs +2 -0
- package/dist/server/next/tags.mjs.map +1 -1
- package/dist/server/next.d.mts +5 -5
- package/dist/server/next.d.ts +5 -5
- package/dist/server/next.js +5 -4
- package/dist/server/next.js.map +1 -1
- package/dist/server/next.mjs +3 -2
- package/dist/server/next.mjs.map +1 -1
- package/dist/server/rendering/server.d.mts +4 -4
- package/dist/server/rendering/server.d.ts +4 -4
- package/dist/server/rendering/server.js +1 -0
- package/dist/server/rendering/server.js.map +1 -1
- package/dist/server/rendering/server.mjs +1 -0
- package/dist/server/rendering.d.mts +7 -7
- package/dist/server/rendering.d.ts +7 -7
- package/dist/server/rendering.js +1 -0
- package/dist/server/rendering.js.map +1 -1
- package/dist/server/rendering.mjs +1 -0
- package/dist/server/routing.d.mts +3 -3
- package/dist/server/routing.d.ts +3 -3
- package/dist/server/routing.js +4 -2
- package/dist/server/routing.js.map +1 -1
- package/dist/server/routing.mjs +3 -1
- package/dist/server/routing.mjs.map +1 -1
- package/dist/server/server.d.mts +5 -5
- package/dist/server/server.d.ts +5 -5
- package/dist/server/server.js +3 -2
- package/dist/server/server.js.map +1 -1
- package/dist/server/server.mjs +2 -1
- package/dist/server/theme-bridge.js +1 -0
- package/dist/server/theme-bridge.js.map +1 -1
- package/dist/server/theme-bridge.mjs +1 -0
- package/dist/server/theme-bridge.mjs.map +1 -1
- package/dist/server/theme.js +3 -1
- package/dist/server/theme.js.map +1 -1
- package/dist/server/theme.mjs +2 -0
- package/dist/server/theme.mjs.map +1 -1
- package/dist/server/{types-DnkRh0UL.d.ts → types-BRQyLrQU.d.ts} +14 -2
- package/dist/server/{types-Dsu9wsUh.d.mts → types-BSV6Vc-P.d.mts} +2 -2
- package/dist/server/{types-MF2AWoKv.d.mts → types-C-LShyIg.d.mts} +14 -2
- package/dist/server/{types-CVykEqXN.d.ts → types-Dt98DeYa.d.ts} +2 -2
- package/dist/server/webhooks.d.mts +8 -2
- package/dist/server/webhooks.d.ts +8 -2
- package/dist/server/webhooks.js +3 -2
- package/dist/server/webhooks.js.map +1 -1
- package/dist/server/webhooks.mjs +2 -1
- package/package.json +7 -1
- package/dist/client/resolver-BhueZVxZ.d.mts +0 -61
- package/dist/client/resolver-BhueZVxZ.d.ts +0 -61
- package/dist/client/usePage--fGlyrgj.d.mts +0 -6439
- package/dist/client/usePage-BBcFCxOU.d.ts +0 -6297
- package/dist/client/usePage-BC8Q2E3t.d.mts +0 -6431
- package/dist/client/usePage-BTPnCuWC.d.mts +0 -6511
- package/dist/client/usePage-BXjk8BhD.d.mts +0 -6704
- package/dist/client/usePage-BafOS9UT.d.mts +0 -6512
- package/dist/client/usePage-BcjWPXvh.d.mts +0 -6388
- package/dist/client/usePage-BiOReg0_.d.ts +0 -6704
- package/dist/client/usePage-Bnx-kA6x.d.mts +0 -6670
- package/dist/client/usePage-BvKAa3Zw.d.mts +0 -366
- package/dist/client/usePage-BvKAa3Zw.d.ts +0 -366
- package/dist/client/usePage-BydHcMYB.d.mts +0 -6297
- package/dist/client/usePage-C3ZKNwY7.d.mts +0 -6393
- package/dist/client/usePage-CE7X5NcN.d.ts +0 -6439
- package/dist/client/usePage-CHEybPMD.d.ts +0 -6429
- package/dist/client/usePage-CrKw1H6Y.d.ts +0 -6338
- package/dist/client/usePage-CyYpOJud.d.ts +0 -6388
- package/dist/client/usePage-D4fxZbRR.d.mts +0 -6429
- package/dist/client/usePage-DMI8ImsU.d.mts +0 -6338
- package/dist/client/usePage-DoPI6b8V.d.ts +0 -6511
- package/dist/client/usePage-DpRNZUtP.d.ts +0 -6431
- package/dist/client/usePage-QNWArrVO.d.ts +0 -6670
- package/dist/client/usePage-fBgPB6Oq.d.ts +0 -6512
- package/dist/client/usePage-gpVaeWDy.d.ts +0 -6393
- package/dist/server/chunk-5JT452F2.mjs.map +0 -1
- package/dist/server/chunk-AET56TQX.mjs.map +0 -1
- package/dist/server/chunk-HMENX4Y7.js.map +0 -1
- package/dist/server/chunk-LQUKXIW7.mjs +0 -13
- package/dist/server/chunk-LQUKXIW7.mjs.map +0 -1
- package/dist/server/chunk-VODFQMUW.js.map +0 -1
- package/dist/server/chunk-WYNEYDXO.js +0 -13
- package/dist/server/chunk-WYNEYDXO.js.map +0 -1
- package/dist/server/loadPage-6I7F6GRF.js.map +0 -1
- /package/dist/server/{loadPage-JI2SML4M.mjs.map → chunk-NFEGQTCC.mjs.map} +0 -0
|
@@ -1,366 +0,0 @@
|
|
|
1
|
-
import { APIEndpoints } from '@riverbankcms/api';
|
|
2
|
-
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
3
|
-
import { PageOutline, Theme, ThemeTokens, RouteMap, OccurrenceContextData, PageRenderer, BlockOverrides } from '@riverbankcms/blocks';
|
|
4
|
-
import { ResolvedBlockData } from '@riverbankcms/blocks/system/data';
|
|
5
|
-
|
|
6
|
-
type SiteResponse = NonNullable<APIEndpoints['getSite']['response']>;
|
|
7
|
-
type PageResponse = NonNullable<APIEndpoints['getContentByPath']['response']>;
|
|
8
|
-
type EntriesResponse = NonNullable<APIEndpoints['listPublishedEntries']['response']>;
|
|
9
|
-
type EntryResponse = NonNullable<APIEndpoints['getPublishedEntryPreview']['response']>;
|
|
10
|
-
type PublicFormResponse = NonNullable<APIEndpoints['getPublicFormById']['response']>;
|
|
11
|
-
type PublicBookingServicesResponse = NonNullable<APIEndpoints['getPublicBookingServices']['response']>;
|
|
12
|
-
type PublicEventsResponse = NonNullable<APIEndpoints['listPublicEvents']['response']>;
|
|
13
|
-
/**
|
|
14
|
-
* Configuration for creating a Riverbank CMS client
|
|
15
|
-
*/
|
|
16
|
-
interface RiverbankClientConfig {
|
|
17
|
-
/**
|
|
18
|
-
* API key for authentication (format: bld_live_... or bld_test_...)
|
|
19
|
-
*/
|
|
20
|
-
apiKey: string;
|
|
21
|
-
/**
|
|
22
|
-
* Base URL for the Riverbank CMS API (required; e.g. https://dashboard.example.com/api)
|
|
23
|
-
*/
|
|
24
|
-
baseUrl: string;
|
|
25
|
-
/**
|
|
26
|
-
* Cache configuration
|
|
27
|
-
*/
|
|
28
|
-
cache?: {
|
|
29
|
-
/**
|
|
30
|
-
* Enable caching (default: true)
|
|
31
|
-
*/
|
|
32
|
-
enabled?: boolean;
|
|
33
|
-
/**
|
|
34
|
-
* Time-to-live for cached responses in seconds
|
|
35
|
-
* @default 300 (5 minutes)
|
|
36
|
-
*/
|
|
37
|
-
ttl?: number;
|
|
38
|
-
/**
|
|
39
|
-
* Maximum number of cached responses
|
|
40
|
-
* @default 100
|
|
41
|
-
*/
|
|
42
|
-
maxSize?: number;
|
|
43
|
-
};
|
|
44
|
-
}
|
|
45
|
-
/**
|
|
46
|
-
* Riverbank CMS client interface
|
|
47
|
-
*/
|
|
48
|
-
interface RiverbankClient {
|
|
49
|
-
/**
|
|
50
|
-
* Fetch site data by slug, domain, or ID
|
|
51
|
-
*/
|
|
52
|
-
getSite(params: {
|
|
53
|
-
slug?: string;
|
|
54
|
-
domain?: string;
|
|
55
|
-
id?: string;
|
|
56
|
-
}): Promise<SiteResponse>;
|
|
57
|
-
/**
|
|
58
|
-
* Fetch a specific page by path
|
|
59
|
-
*
|
|
60
|
-
* @param params.preview - If true, returns draft content instead of published content (requires API key with site access)
|
|
61
|
-
*/
|
|
62
|
-
getPage(params: {
|
|
63
|
-
siteId: string;
|
|
64
|
-
path: string;
|
|
65
|
-
preview?: boolean;
|
|
66
|
-
}): Promise<PageResponse>;
|
|
67
|
-
/**
|
|
68
|
-
* Fetch published content entries with optional pagination, sorting, and preview mode
|
|
69
|
-
*
|
|
70
|
-
* @param params.siteId - The site ID
|
|
71
|
-
* @param params.contentType - The content type key (e.g., 'blog-post', 'product')
|
|
72
|
-
* @param params.limit - Maximum number of entries to return
|
|
73
|
-
* @param params.order - Sort order: 'newest' (published_at desc) or 'oldest' (published_at asc)
|
|
74
|
-
* @param params.preview - If true, includes draft entries (requires API key with site access)
|
|
75
|
-
* @param params.mode - 'query' for automatic fetching, 'manual' for specific entry IDs
|
|
76
|
-
* @param params.entryIds - Array of entry IDs to fetch (only used when mode is 'manual')
|
|
77
|
-
*
|
|
78
|
-
* @example
|
|
79
|
-
* ```ts
|
|
80
|
-
* // Fetch latest 10 blog posts
|
|
81
|
-
* const entries = await client.getEntries({
|
|
82
|
-
* siteId: 'site-id',
|
|
83
|
-
* contentType: 'blog-post',
|
|
84
|
-
* limit: 10,
|
|
85
|
-
* order: 'newest',
|
|
86
|
-
* });
|
|
87
|
-
*
|
|
88
|
-
* // Fetch draft entries for preview
|
|
89
|
-
* const drafts = await client.getEntries({
|
|
90
|
-
* siteId: 'site-id',
|
|
91
|
-
* contentType: 'blog-post',
|
|
92
|
-
* preview: true,
|
|
93
|
-
* });
|
|
94
|
-
*
|
|
95
|
-
* // Fetch specific entries by ID (manual mode)
|
|
96
|
-
* const specific = await client.getEntries({
|
|
97
|
-
* siteId: 'site-id',
|
|
98
|
-
* contentType: 'blog-post',
|
|
99
|
-
* mode: 'manual',
|
|
100
|
-
* entryIds: ['uuid-1', 'uuid-2'],
|
|
101
|
-
* });
|
|
102
|
-
* ```
|
|
103
|
-
*/
|
|
104
|
-
getEntries(params: {
|
|
105
|
-
siteId: string;
|
|
106
|
-
contentType: string;
|
|
107
|
-
limit?: number;
|
|
108
|
-
/** Sort order for entries. 'order' uses custom ordering (default behavior). */
|
|
109
|
-
order?: 'newest' | 'oldest' | 'title' | 'order';
|
|
110
|
-
preview?: boolean;
|
|
111
|
-
/** Selection mode: 'query' for automatic, 'manual' for specific entry IDs */
|
|
112
|
-
mode?: 'query' | 'manual';
|
|
113
|
-
/** Entry IDs to fetch when mode is 'manual' */
|
|
114
|
-
entryIds?: string[];
|
|
115
|
-
}): Promise<EntriesResponse>;
|
|
116
|
-
/**
|
|
117
|
-
* Fetch a specific content entry by slug
|
|
118
|
-
*/
|
|
119
|
-
getEntry(params: {
|
|
120
|
-
siteId: string;
|
|
121
|
-
contentType: string;
|
|
122
|
-
slug: string;
|
|
123
|
-
}): Promise<EntryResponse>;
|
|
124
|
-
/**
|
|
125
|
-
* Fetch a public form definition by ID
|
|
126
|
-
*/
|
|
127
|
-
getPublicFormById(params: {
|
|
128
|
-
formId: string;
|
|
129
|
-
}): Promise<PublicFormResponse>;
|
|
130
|
-
/**
|
|
131
|
-
* Fetch public booking services for a site
|
|
132
|
-
*/
|
|
133
|
-
getPublicBookingServices(params: {
|
|
134
|
-
siteId: string;
|
|
135
|
-
ids?: string;
|
|
136
|
-
}): Promise<PublicBookingServicesResponse>;
|
|
137
|
-
/**
|
|
138
|
-
* List public events for a site (optionally time-filtered)
|
|
139
|
-
*/
|
|
140
|
-
listPublicEvents(params: {
|
|
141
|
-
siteId: string;
|
|
142
|
-
limit?: number;
|
|
143
|
-
from?: string;
|
|
144
|
-
to?: string;
|
|
145
|
-
stage?: string;
|
|
146
|
-
}): Promise<PublicEventsResponse>;
|
|
147
|
-
/**
|
|
148
|
-
* Force clear the cache
|
|
149
|
-
*/
|
|
150
|
-
clearCache(): void;
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
/**
|
|
154
|
-
* Server-side helper to fetch all data needed for <Page> component.
|
|
155
|
-
*
|
|
156
|
-
* Use this in server components, getServerSideProps, or API routes.
|
|
157
|
-
*/
|
|
158
|
-
|
|
159
|
-
/**
|
|
160
|
-
* SDK config from API response (without siteId which is stripped at storage).
|
|
161
|
-
* This is the runtime representation - for defining configs, use RiverbankSiteConfig.
|
|
162
|
-
*/
|
|
163
|
-
type RuntimeSdkConfig = NonNullable<SiteResponse['sdkConfig']>;
|
|
164
|
-
|
|
165
|
-
type PageProps = {
|
|
166
|
-
page: PageOutline;
|
|
167
|
-
theme: Theme;
|
|
168
|
-
siteId: string;
|
|
169
|
-
themeTokens?: ThemeTokens;
|
|
170
|
-
resolvedData?: ResolvedBlockData;
|
|
171
|
-
routeMap?: RouteMap;
|
|
172
|
-
/**
|
|
173
|
-
* SDK site configuration containing theme palette overrides.
|
|
174
|
-
* When provided, the SDK palette tokens are merged into the theme tokens,
|
|
175
|
-
* allowing blocks to use SDK-defined color tokens for section backgrounds.
|
|
176
|
-
*/
|
|
177
|
-
sdkConfig?: RuntimeSdkConfig | null;
|
|
178
|
-
/**
|
|
179
|
-
* Additional context data for content entry pages.
|
|
180
|
-
* Used to pass occurrence context and content entry data to blocks.
|
|
181
|
-
*/
|
|
182
|
-
dataContext?: {
|
|
183
|
-
/** Occurrence context for event pages (from URL like /events/yoga/2025-01-15) */
|
|
184
|
-
occurrenceContext?: OccurrenceContextData | null;
|
|
185
|
-
/** Content entry data for template pages */
|
|
186
|
-
contentEntry?: Record<string, unknown> | null;
|
|
187
|
-
};
|
|
188
|
-
wrapBlock?: (blockId: string, rendered: React.ReactNode) => React.ReactNode;
|
|
189
|
-
registry?: Parameters<typeof PageRenderer>[0]['registry'];
|
|
190
|
-
usePlaceholders?: boolean;
|
|
191
|
-
/**
|
|
192
|
-
* Custom components to override default block rendering.
|
|
193
|
-
* Keys can be full block kind ("block.hero") or short form ("hero").
|
|
194
|
-
*
|
|
195
|
-
* This is SSR-safe - no context or hooks required.
|
|
196
|
-
*
|
|
197
|
-
* @example
|
|
198
|
-
* ```tsx
|
|
199
|
-
* <Page
|
|
200
|
-
* {...pageData}
|
|
201
|
-
* blockOverrides={{
|
|
202
|
-
* 'hero': MyCustomHero,
|
|
203
|
-
* 'block.testimonials': MyCustomTestimonials,
|
|
204
|
-
* }}
|
|
205
|
-
* />
|
|
206
|
-
* ```
|
|
207
|
-
*/
|
|
208
|
-
blockOverrides?: BlockOverrides;
|
|
209
|
-
};
|
|
210
|
-
/**
|
|
211
|
-
* Pure renderer for Riverbank CMS pages.
|
|
212
|
-
*
|
|
213
|
-
* This component expects all data to be provided via props.
|
|
214
|
-
* For data fetching, use:
|
|
215
|
-
* - Server-side: `await loadPage({ client, siteId, path })`
|
|
216
|
-
* - Client-side: `usePage({ client, siteId, path })`
|
|
217
|
-
*
|
|
218
|
-
* @example Server-side (Next.js App Router)
|
|
219
|
-
* ```tsx
|
|
220
|
-
* import { createRiverbankClient } from '@riverbankcms/sdk';
|
|
221
|
-
* import { loadPage, Page } from '@riverbankcms/sdk/rendering';
|
|
222
|
-
*
|
|
223
|
-
* const client = createRiverbankClient({ apiKey, baseUrl });
|
|
224
|
-
*
|
|
225
|
-
* export default async function PageRoute({ params }) {
|
|
226
|
-
* const pageData = await loadPage({
|
|
227
|
-
* client,
|
|
228
|
-
* siteId: 'site-id',
|
|
229
|
-
* path: `/${params.slug}`,
|
|
230
|
-
* });
|
|
231
|
-
*
|
|
232
|
-
* return <Page {...pageData} />;
|
|
233
|
-
* }
|
|
234
|
-
* ```
|
|
235
|
-
*
|
|
236
|
-
* @example Client-side
|
|
237
|
-
* ```tsx
|
|
238
|
-
* import { createRiverbankClient } from '@riverbankcms/sdk';
|
|
239
|
-
* import { usePage, Page } from '@riverbankcms/sdk/rendering';
|
|
240
|
-
*
|
|
241
|
-
* const client = createRiverbankClient({ apiKey, baseUrl });
|
|
242
|
-
*
|
|
243
|
-
* function MyPage({ path }) {
|
|
244
|
-
* const pageData = usePage({ client, siteId: 'site-id', path });
|
|
245
|
-
*
|
|
246
|
-
* if (pageData.loading) return <LoadingState />;
|
|
247
|
-
* if (pageData.error) return <ErrorState error={pageData.error} />;
|
|
248
|
-
* if (!pageData.page) return <NotFound />;
|
|
249
|
-
*
|
|
250
|
-
* return <Page {...pageData} />;
|
|
251
|
-
* }
|
|
252
|
-
* ```
|
|
253
|
-
*/
|
|
254
|
-
declare function Page({ page, theme, themeTokens: providedTokens, siteId, resolvedData, routeMap, wrapBlock, registry, usePlaceholders, blockOverrides, sdkConfig, dataContext, }: PageProps): react_jsx_runtime.JSX.Element;
|
|
255
|
-
|
|
256
|
-
/**
|
|
257
|
-
* Client-side React hook to fetch page data.
|
|
258
|
-
*
|
|
259
|
-
* Use this in client components for dynamic page loading.
|
|
260
|
-
*/
|
|
261
|
-
|
|
262
|
-
type UsePageParams = {
|
|
263
|
-
client: RiverbankClient;
|
|
264
|
-
siteId: string;
|
|
265
|
-
path: string;
|
|
266
|
-
pageId?: string;
|
|
267
|
-
/**
|
|
268
|
-
* If true, fetches draft/unpublished content instead of published content.
|
|
269
|
-
* This affects both the page structure and block data loaders.
|
|
270
|
-
* Requires API key with site access.
|
|
271
|
-
*
|
|
272
|
-
* @default false
|
|
273
|
-
*/
|
|
274
|
-
preview?: boolean;
|
|
275
|
-
};
|
|
276
|
-
type UsePageResult = {
|
|
277
|
-
loading: true;
|
|
278
|
-
error: null;
|
|
279
|
-
page: null;
|
|
280
|
-
theme: null;
|
|
281
|
-
siteId: string;
|
|
282
|
-
resolvedData: null;
|
|
283
|
-
sdkConfig: null;
|
|
284
|
-
} | {
|
|
285
|
-
loading: false;
|
|
286
|
-
error: Error;
|
|
287
|
-
page: null;
|
|
288
|
-
theme: null;
|
|
289
|
-
siteId: string;
|
|
290
|
-
resolvedData: null;
|
|
291
|
-
sdkConfig: null;
|
|
292
|
-
} | {
|
|
293
|
-
loading: false;
|
|
294
|
-
error: null;
|
|
295
|
-
sdkConfig: RuntimeSdkConfig | null;
|
|
296
|
-
} & Omit<PageProps, 'registry' | 'wrapBlock' | 'usePlaceholders' | 'sdkConfig'>;
|
|
297
|
-
/**
|
|
298
|
-
* Client-side React hook to fetch all data needed for <Page> component.
|
|
299
|
-
*
|
|
300
|
-
* Fetches site data, page data, and prefetches block data loaders.
|
|
301
|
-
* Returns loading and error states for proper UI handling.
|
|
302
|
-
*
|
|
303
|
-
* IMPORTANT: The client object should be stable across renders to avoid
|
|
304
|
-
* unnecessary re-fetches. Create it outside your component or use useMemo:
|
|
305
|
-
*
|
|
306
|
-
* ```tsx
|
|
307
|
-
* // ✅ Good - stable reference
|
|
308
|
-
* const client = useMemo(
|
|
309
|
-
* () => createRiverbankClient({ apiKey, baseUrl }),
|
|
310
|
-
* [apiKey, baseUrl]
|
|
311
|
-
* );
|
|
312
|
-
*
|
|
313
|
-
* // ❌ Bad - new client on every render (causes infinite loops)
|
|
314
|
-
* const client = createRiverbankClient({ apiKey, baseUrl });
|
|
315
|
-
* ```
|
|
316
|
-
*
|
|
317
|
-
* @example Basic usage
|
|
318
|
-
* ```tsx
|
|
319
|
-
* import { createRiverbankClient } from '@riverbankcms/sdk';
|
|
320
|
-
* import { usePage, Page } from '@riverbankcms/sdk/rendering';
|
|
321
|
-
*
|
|
322
|
-
* const client = createRiverbankClient({
|
|
323
|
-
* apiKey: process.env.NEXT_PUBLIC_RIVERBANK_API_KEY!,
|
|
324
|
-
* baseUrl: process.env.NEXT_PUBLIC_DASHBOARD_URL + '/api',
|
|
325
|
-
* });
|
|
326
|
-
*
|
|
327
|
-
* function MyPage({ path }: { path: string }) {
|
|
328
|
-
* const pageData = usePage({ client, siteId: 'site-123', path });
|
|
329
|
-
*
|
|
330
|
-
* if (pageData.loading) {
|
|
331
|
-
* return <div>Loading...</div>;
|
|
332
|
-
* }
|
|
333
|
-
*
|
|
334
|
-
* if (pageData.error) {
|
|
335
|
-
* return <div>Error: {pageData.error.message}</div>;
|
|
336
|
-
* }
|
|
337
|
-
*
|
|
338
|
-
* return <Page {...pageData} />;
|
|
339
|
-
* }
|
|
340
|
-
* ```
|
|
341
|
-
*
|
|
342
|
-
* @example With custom loading/error states
|
|
343
|
-
* ```tsx
|
|
344
|
-
* function MyPage({ path }: { path: string }) {
|
|
345
|
-
* const pageData = usePage({ client, siteId: 'site-123', path });
|
|
346
|
-
*
|
|
347
|
-
* if (pageData.loading) {
|
|
348
|
-
* return <Skeleton />;
|
|
349
|
-
* }
|
|
350
|
-
*
|
|
351
|
-
* if (pageData.error) {
|
|
352
|
-
* return (
|
|
353
|
-
* <ErrorBoundary
|
|
354
|
-
* error={pageData.error}
|
|
355
|
-
* onRetry={() => window.location.reload()}
|
|
356
|
-
* />
|
|
357
|
-
* );
|
|
358
|
-
* }
|
|
359
|
-
*
|
|
360
|
-
* return <Page {...pageData} />;
|
|
361
|
-
* }
|
|
362
|
-
* ```
|
|
363
|
-
*/
|
|
364
|
-
declare function usePage(params: UsePageParams): UsePageResult;
|
|
365
|
-
|
|
366
|
-
export { type PageResponse as P, type RiverbankClient as R, type SiteResponse as S, type UsePageParams as U, type UsePageResult as a, type PageProps as b, type RiverbankClientConfig as c, Page as d, usePage as u };
|