sanity-plugin-documents-pane 1.1.0 → 2.0.0-v3-studio.2

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.
@@ -0,0 +1,353 @@
1
+ import {jsxs as $gGrEF$jsxs, jsx as $gGrEF$jsx, Fragment as $gGrEF$Fragment} from "react/jsx-runtime";
2
+ import {useCallback as $gGrEF$useCallback, useState as $gGrEF$useState, useRef as $gGrEF$useRef, useEffect as $gGrEF$useEffect} from "react";
3
+ import {Stack as $gGrEF$Stack, Box as $gGrEF$Box, Flex as $gGrEF$Flex, Spinner as $gGrEF$Spinner, Button as $gGrEF$Button, Label as $gGrEF$Label, Code as $gGrEF$Code, Card as $gGrEF$Card, Text as $gGrEF$Text} from "@sanity/ui";
4
+ import {fromString as $gGrEF$fromString} from "@sanity/util/paths";
5
+ import {useSchema as $gGrEF$useSchema, SanityPreview as $gGrEF$SanityPreview, useDocumentStore as $gGrEF$useDocumentStore} from "sanity";
6
+ import {usePaneRouter as $gGrEF$usePaneRouter} from "sanity/desk";
7
+ import {distinctUntilChanged as $gGrEF$distinctUntilChanged, catchError as $gGrEF$catchError} from "rxjs/operators";
8
+ import $gGrEF$reactfastcompare from "react-fast-compare";
9
+ import {ComposeIcon as $gGrEF$ComposeIcon} from "@sanity/icons";
10
+ import {uuid as $gGrEF$uuid} from "@sanity/uuid";
11
+ import $gGrEF$dlv from "dlv";
12
+
13
+
14
+
15
+
16
+
17
+
18
+
19
+
20
+
21
+
22
+
23
+
24
+
25
+ function $7a4dd2fc2cc8e1f5$export$2e2bcd8739ae039({ query: query , params: params }) {
26
+ return /*#__PURE__*/ (0, $gGrEF$jsxs)((0, $gGrEF$Fragment), {
27
+ children: [
28
+ /*#__PURE__*/ (0, $gGrEF$jsxs)((0, $gGrEF$Stack), {
29
+ space: 4,
30
+ children: [
31
+ /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Box), {
32
+ children: /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Label), {
33
+ children: "Query"
34
+ })
35
+ }),
36
+ /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Box), {
37
+ children: /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Code), {
38
+ children: query
39
+ })
40
+ })
41
+ ]
42
+ }),
43
+ params && /*#__PURE__*/ (0, $gGrEF$jsxs)((0, $gGrEF$Stack), {
44
+ space: 4,
45
+ children: [
46
+ /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Box), {
47
+ children: /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Label), {
48
+ children: "Params"
49
+ })
50
+ }),
51
+ /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Box), {
52
+ children: /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Code), {
53
+ children: JSON.stringify(params)
54
+ })
55
+ })
56
+ ]
57
+ })
58
+ ]
59
+ });
60
+ }
61
+
62
+
63
+
64
+
65
+
66
+ function $60d135b0057fb272$export$2e2bcd8739ae039(props) {
67
+ const { children: children , tone: tone = `caution` } = props;
68
+ return /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Card), {
69
+ padding: 3,
70
+ radius: 2,
71
+ shadow: 1,
72
+ tone: tone,
73
+ children: /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Text), {
74
+ size: 1,
75
+ children: children
76
+ })
77
+ });
78
+ }
79
+
80
+
81
+
82
+
83
+
84
+
85
+ const $85ac1a186196bda6$var$DEFAULT_PARAMS = {};
86
+ const $85ac1a186196bda6$var$DEFAULT_OPTIONS = {
87
+ apiVersion: `v2022-05-09`
88
+ };
89
+ function $85ac1a186196bda6$export$2e2bcd8739ae039(query, params = $85ac1a186196bda6$var$DEFAULT_PARAMS, options = $85ac1a186196bda6$var$DEFAULT_OPTIONS) {
90
+ const [loading, setLoading] = (0, $gGrEF$useState)(true);
91
+ const [error, setError] = (0, $gGrEF$useState)(false);
92
+ const [data, setData] = (0, $gGrEF$useState)(null);
93
+ const subscription = (0, $gGrEF$useRef)(null);
94
+ const documentStore = (0, $gGrEF$useDocumentStore)();
95
+ (0, $gGrEF$useEffect)(()=>{
96
+ if (query) subscription.current = documentStore.listenQuery(query, params, options).pipe((0, $gGrEF$distinctUntilChanged)((0, $gGrEF$reactfastcompare)), (0, $gGrEF$catchError)((err)=>{
97
+ console.error(err);
98
+ setError(err);
99
+ setLoading(false);
100
+ setData(null);
101
+ return err;
102
+ })).subscribe((documents)=>{
103
+ setData((current)=>(0, $gGrEF$reactfastcompare)(current, documents) ? current : documents);
104
+ setLoading(false);
105
+ setError(false);
106
+ });
107
+ return ()=>{
108
+ return subscription.current ? subscription.current.unsubscribe() : undefined;
109
+ };
110
+ }, [
111
+ query,
112
+ params,
113
+ options
114
+ ]);
115
+ return {
116
+ loading: loading,
117
+ error: error,
118
+ data: data
119
+ };
120
+ }
121
+
122
+
123
+
124
+
125
+
126
+
127
+
128
+
129
+ function $a08add133c8ba4bc$export$2e2bcd8739ae039(props) {
130
+ const { initialValueTemplates: initialValueTemplates = [] } = props;
131
+ const { ReferenceChildLink: ReferenceChildLink } = (0, $gGrEF$usePaneRouter)();
132
+ if (!initialValueTemplates.length) return null;
133
+ return /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Card), {
134
+ borderBottom: true,
135
+ padding: 2,
136
+ children: /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Flex), {
137
+ justify: "flex-end",
138
+ gap: 1,
139
+ children: initialValueTemplates.map((template)=>{
140
+ if (!template.template) return null;
141
+ return /*#__PURE__*/ (0, $gGrEF$jsx)(ReferenceChildLink, {
142
+ documentId: (0, $gGrEF$uuid)(),
143
+ documentType: template.schemaType,
144
+ template: {
145
+ id: template.template,
146
+ params: template.parameters
147
+ },
148
+ parentRefPath: [],
149
+ children: /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Button), {
150
+ icon: /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$ComposeIcon), {}),
151
+ text: template.title,
152
+ mode: "bleed",
153
+ as: "span"
154
+ })
155
+ }, `${template.schemaType}-${template.template}`);
156
+ })
157
+ })
158
+ });
159
+ }
160
+
161
+
162
+ function $1026ba2eafe19170$export$2e2bcd8739ae039(props) {
163
+ const { query: query , params: params , debug: debug , initialValueTemplates: initialValueTemplates } = props;
164
+ const { routerPanesState: routerPanesState , groupIndex: groupIndex , handleEditReference: handleEditReference } = (0, $gGrEF$usePaneRouter)();
165
+ const schema = (0, $gGrEF$useSchema)();
166
+ const { loading: loading , error: error , data: data } = (0, $85ac1a186196bda6$export$2e2bcd8739ae039)(query, params);
167
+ const handleClick = (0, $gGrEF$useCallback)((id, type)=>{
168
+ const childParams = routerPanesState[groupIndex + 1]?.[0].params || {};
169
+ const { parentRefPath: parentRefPath } = childParams;
170
+ handleEditReference({
171
+ id: id,
172
+ type: type,
173
+ // Uncertain that this works as intended
174
+ parentRefPath: parentRefPath ? (0, $gGrEF$fromString)(parentRefPath) : [
175
+ ``
176
+ ],
177
+ // Added this to satisfy TS
178
+ template: type
179
+ });
180
+ }, [
181
+ routerPanesState,
182
+ groupIndex,
183
+ handleEditReference
184
+ ]);
185
+ if (loading) return /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Box), {
186
+ padding: 4,
187
+ children: /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Flex), {
188
+ justify: "center",
189
+ align: "center",
190
+ children: /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Spinner), {
191
+ muted: true
192
+ })
193
+ })
194
+ });
195
+ if (error) return /*#__PURE__*/ (0, $gGrEF$jsxs)((0, $gGrEF$Stack), {
196
+ padding: 4,
197
+ space: 5,
198
+ children: [
199
+ /*#__PURE__*/ (0, $gGrEF$jsx)((0, $60d135b0057fb272$export$2e2bcd8739ae039), {
200
+ children: "There was en error performing this query"
201
+ }),
202
+ debug && /*#__PURE__*/ (0, $gGrEF$jsx)((0, $7a4dd2fc2cc8e1f5$export$2e2bcd8739ae039), {
203
+ query: query,
204
+ params: params
205
+ })
206
+ ]
207
+ });
208
+ if (!data?.length) return /*#__PURE__*/ (0, $gGrEF$jsxs)((0, $gGrEF$Fragment), {
209
+ children: [
210
+ /*#__PURE__*/ (0, $gGrEF$jsx)((0, $a08add133c8ba4bc$export$2e2bcd8739ae039), {
211
+ initialValueTemplates: initialValueTemplates
212
+ }),
213
+ /*#__PURE__*/ (0, $gGrEF$jsxs)((0, $gGrEF$Stack), {
214
+ padding: 4,
215
+ space: 5,
216
+ children: [
217
+ /*#__PURE__*/ (0, $gGrEF$jsx)((0, $60d135b0057fb272$export$2e2bcd8739ae039), {
218
+ children: "No Documents found"
219
+ }),
220
+ debug && /*#__PURE__*/ (0, $gGrEF$jsx)((0, $7a4dd2fc2cc8e1f5$export$2e2bcd8739ae039), {
221
+ query: query,
222
+ params: params
223
+ })
224
+ ]
225
+ })
226
+ ]
227
+ });
228
+ return /*#__PURE__*/ (0, $gGrEF$jsxs)((0, $gGrEF$Fragment), {
229
+ children: [
230
+ /*#__PURE__*/ (0, $gGrEF$jsx)((0, $a08add133c8ba4bc$export$2e2bcd8739ae039), {
231
+ initialValueTemplates: initialValueTemplates
232
+ }),
233
+ /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Stack), {
234
+ padding: 2,
235
+ space: 1,
236
+ children: data.map((doc)=>{
237
+ const schemaType = schema.get(doc._type);
238
+ if (!schemaType) return null;
239
+ return /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$Button), {
240
+ onClick: ()=>handleClick(doc._id, doc._type),
241
+ padding: 2,
242
+ mode: "bleed",
243
+ children: /*#__PURE__*/ (0, $gGrEF$jsx)((0, $gGrEF$SanityPreview), {
244
+ value: doc,
245
+ schemaType: schemaType
246
+ })
247
+ }, doc._id);
248
+ })
249
+ })
250
+ ]
251
+ });
252
+ }
253
+
254
+
255
+
256
+
257
+
258
+ function $27973bbf590df0c3$var$defaultResolver(options) {
259
+ const { params: params , document: document , useDraft: useDraft } = options;
260
+ // params is optional
261
+ if (!params) return {};
262
+ // legacy useDraft behaviour
263
+ const doc = useDraft ? document.displayed : document.published;
264
+ return Object.keys(params).reduce((acc, key)=>({
265
+ ...acc,
266
+ [key]: (0, $gGrEF$dlv)(doc, params[key])
267
+ }), {});
268
+ }
269
+ function $27973bbf590df0c3$export$2e2bcd8739ae039(options) {
270
+ const { params: params , document: document } = options;
271
+ const resolvedParams = typeof params == "function" ? params({
272
+ document: document
273
+ }) : $27973bbf590df0c3$var$defaultResolver(options);
274
+ // if any of the parameters are undefined, the query will error
275
+ // so return undefined so the UI can show a more appropriate message
276
+ if (Object.values(resolvedParams).includes(undefined)) return undefined;
277
+ // Typescript can't tell that we've guarded against any value being undefined,
278
+ // so forcing the type
279
+ return resolvedParams;
280
+ }
281
+
282
+
283
+ function $a1930928ca1dda36$export$2e2bcd8739ae039(options) {
284
+ const { resolver: resolver , document: document } = options || {};
285
+ if (!resolver) return [];
286
+ return resolver({
287
+ document: document
288
+ });
289
+ }
290
+
291
+
292
+ function $d69d7dc34affefb4$export$2e2bcd8739ae039(props) {
293
+ const { document: document , options: options } = props;
294
+ const { query: query , params: params , useDraft: useDraft = false , debug: debug = false , initialValueTemplates: initialValueTemplatesResolver , } = options;
295
+ if (useDraft && typeof params === "function") return /*#__PURE__*/ (0, $gGrEF$jsxs)((0, $gGrEF$Stack), {
296
+ padding: 4,
297
+ space: 5,
298
+ children: [
299
+ /*#__PURE__*/ (0, $gGrEF$jsxs)((0, $60d135b0057fb272$export$2e2bcd8739ae039), {
300
+ children: [
301
+ /*#__PURE__*/ (0, $gGrEF$jsx)("code", {
302
+ children: "useDraft"
303
+ }),
304
+ " should not be ",
305
+ /*#__PURE__*/ (0, $gGrEF$jsx)("code", {
306
+ children: "true"
307
+ }),
308
+ " when supplying a function for",
309
+ /*#__PURE__*/ (0, $gGrEF$jsx)("code", {
310
+ children: "params"
311
+ })
312
+ ]
313
+ }),
314
+ debug && /*#__PURE__*/ (0, $gGrEF$jsx)((0, $7a4dd2fc2cc8e1f5$export$2e2bcd8739ae039), {
315
+ query: query
316
+ })
317
+ ]
318
+ });
319
+ const paramValues = (0, $27973bbf590df0c3$export$2e2bcd8739ae039)({
320
+ document: document,
321
+ params: params,
322
+ useDraft: useDraft
323
+ });
324
+ const initialValueTemplates = (0, $a1930928ca1dda36$export$2e2bcd8739ae039)({
325
+ resolver: initialValueTemplatesResolver,
326
+ document: document
327
+ });
328
+ if (!paramValues) return /*#__PURE__*/ (0, $gGrEF$jsxs)((0, $gGrEF$Stack), {
329
+ padding: 4,
330
+ space: 5,
331
+ children: [
332
+ /*#__PURE__*/ (0, $gGrEF$jsx)((0, $60d135b0057fb272$export$2e2bcd8739ae039), {
333
+ children: "Parameters for this query could not be resolved. This may mean the document does not yet exist or is incomplete."
334
+ }),
335
+ debug && /*#__PURE__*/ (0, $gGrEF$jsx)((0, $7a4dd2fc2cc8e1f5$export$2e2bcd8739ae039), {
336
+ query: query
337
+ })
338
+ ]
339
+ });
340
+ return /*#__PURE__*/ (0, $gGrEF$jsx)((0, $1026ba2eafe19170$export$2e2bcd8739ae039), {
341
+ query: query,
342
+ params: paramValues,
343
+ debug: debug,
344
+ initialValueTemplates: initialValueTemplates
345
+ });
346
+ }
347
+
348
+
349
+ var $df9eabe9bda49ea8$export$2e2bcd8739ae039 = (0, $d69d7dc34affefb4$export$2e2bcd8739ae039);
350
+
351
+
352
+ export {$df9eabe9bda49ea8$export$2e2bcd8739ae039 as default};
353
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"mappings":"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","sources":["src/index.ts","src/DocumentsPane.tsx","src/Documents.tsx","src/Debug.tsx","src/Feedback.tsx","src/hooks/useListeningQuery.ts","src/NewDocument.tsx","src/resolveParams.ts","src/resolveInitialValueTemplates.ts"],"sourcesContent":["import DocumentsPane from './DocumentsPane'\n\nexport default DocumentsPane\n","import React from 'react'\nimport {Stack} from '@sanity/ui'\n\nimport Documents from './Documents'\nimport Feedback from './Feedback'\nimport Debug from './Debug'\nimport {DocumentsPaneProps} from './types'\nimport resolveParams from './resolveParams'\nimport resolveInitialValueTemplates from './resolveInitialValueTemplates'\n\nexport default function DocumentsPane(props: DocumentsPaneProps) {\n const {document, options} = props\n const {\n query,\n params,\n useDraft = false,\n debug = false,\n initialValueTemplates: initialValueTemplatesResolver,\n } = options\n\n if (useDraft && typeof params === 'function') {\n return (\n <Stack padding={4} space={5}>\n <Feedback>\n <code>useDraft</code> should not be <code>true</code> when supplying a function for\n <code>params</code>\n </Feedback>\n {debug && <Debug query={query} />}\n </Stack>\n )\n }\n\n const paramValues = resolveParams({document, params, useDraft})\n\n const initialValueTemplates = resolveInitialValueTemplates({\n resolver: initialValueTemplatesResolver,\n document,\n })\n\n if (!paramValues) {\n return (\n <Stack padding={4} space={5}>\n <Feedback>\n Parameters for this query could not be resolved. This may mean the document does not yet\n exist or is incomplete.\n </Feedback>\n {debug && <Debug query={query} />}\n </Stack>\n )\n }\n\n return (\n <Documents\n query={query}\n params={paramValues}\n debug={debug}\n initialValueTemplates={initialValueTemplates}\n />\n )\n}\n","import React, {useCallback} from 'react'\nimport {Box, Button, Stack, Flex, Spinner} from '@sanity/ui'\nimport {fromString as pathFromString} from '@sanity/util/paths'\nimport {SanityPreview, useSchema} from 'sanity'\nimport {usePaneRouter} from 'sanity/desk'\n\nimport Debug from './Debug'\nimport Feedback from './Feedback'\nimport useListeningQuery from './hooks/useListeningQuery'\nimport {DocumentsPaneInitialValueTemplate} from './types'\nimport NewDocument from './NewDocument'\n\ntype DocumentsProps = {\n query: string\n params: {[key: string]: string}\n debug: boolean\n initialValueTemplates: DocumentsPaneInitialValueTemplate[]\n}\n\nexport default function Documents(props: DocumentsProps) {\n const {query, params, debug, initialValueTemplates} = props\n const {routerPanesState, groupIndex, handleEditReference} = usePaneRouter()\n const schema = useSchema()\n\n const {loading, error, data} = useListeningQuery(query, params)\n\n const handleClick = useCallback(\n (id, type) => {\n const childParams = routerPanesState[groupIndex + 1]?.[0].params || {}\n const {parentRefPath} = childParams\n\n handleEditReference({\n id,\n type,\n // Uncertain that this works as intended\n parentRefPath: parentRefPath ? pathFromString(parentRefPath) : [``],\n // Added this to satisfy TS\n template: type,\n })\n },\n [routerPanesState, groupIndex, handleEditReference]\n )\n\n if (loading) {\n return (\n <Box padding={4}>\n <Flex justify=\"center\" align=\"center\">\n <Spinner muted />\n </Flex>\n </Box>\n )\n }\n\n if (error) {\n return (\n <Stack padding={4} space={5}>\n <Feedback>There was en error performing this query</Feedback>\n {debug && <Debug query={query} params={params} />}\n </Stack>\n )\n }\n\n if (!data?.length) {\n return (\n <>\n <NewDocument initialValueTemplates={initialValueTemplates} />\n <Stack padding={4} space={5}>\n <Feedback>No Documents found</Feedback>\n {debug && <Debug query={query} params={params} />}\n </Stack>\n </>\n )\n }\n\n return (\n <>\n <NewDocument initialValueTemplates={initialValueTemplates} />\n <Stack padding={2} space={1}>\n {data.map((doc) => {\n const schemaType = schema.get(doc._type)\n if (!schemaType) {\n return null\n }\n return (\n <Button\n key={doc._id}\n onClick={() => handleClick(doc._id, doc._type)}\n padding={2}\n mode=\"bleed\"\n >\n <SanityPreview value={doc} schemaType={schemaType} />\n </Button>\n )\n })}\n </Stack>\n </>\n )\n}\n","import React from 'react'\nimport {Code, Box, Label, Stack} from '@sanity/ui'\n\nexport default function Debug({query, params}: {query: string; params?: {[key: string]: string}}) {\n return (\n <>\n <Stack space={4}>\n <Box>\n <Label>Query</Label>\n </Box>\n <Box>\n <Code>{query}</Code>\n </Box>\n </Stack>\n {params && (\n <Stack space={4}>\n <Box>\n <Label>Params</Label>\n </Box>\n <Box>\n <Code>{JSON.stringify(params)}</Code>\n </Box>\n </Stack>\n )}\n </>\n )\n}\n","import React from 'react'\nimport {Card, Text} from '@sanity/ui'\nimport type {BadgeTone} from '@sanity/ui'\n\ntype FeedbackProps = {\n children?: React.ReactNode\n tone?: BadgeTone\n}\n\nexport default function Feedback(props: FeedbackProps) {\n const {children, tone = `caution`} = props\n\n return (\n <Card padding={3} radius={2} shadow={1} tone={tone}>\n <Text size={1}>{children}</Text>\n </Card>\n )\n}\n","import {useEffect, useState, useRef} from 'react'\nimport {catchError, distinctUntilChanged} from 'rxjs/operators'\nimport isEqual from 'react-fast-compare'\nimport {SanityDocument, useDocumentStore} from 'sanity'\n\ntype Params = Record<string, string | number | boolean | string[]>\n\ninterface ListenQueryOptions {\n tag?: string\n apiVersion?: string\n}\n\ntype ReturnShape = {\n loading: boolean\n error: boolean\n data: SanityDocument[] | null\n}\n\ntype Observable = {\n unsubscribe: () => void\n}\n\nconst DEFAULT_PARAMS = {}\nconst DEFAULT_OPTIONS = {apiVersion: `v2022-05-09`}\n\nexport default function useListeningQuery(\n query: string,\n params: Params = DEFAULT_PARAMS,\n options: ListenQueryOptions = DEFAULT_OPTIONS\n): ReturnShape {\n const [loading, setLoading] = useState(true)\n const [error, setError] = useState(false)\n const [data, setData] = useState<SanityDocument[] | null>(null)\n const subscription = useRef<null | Observable>(null)\n const documentStore = useDocumentStore()\n\n useEffect(() => {\n if (query) {\n subscription.current = documentStore\n .listenQuery(query, params, options)\n .pipe(\n distinctUntilChanged(isEqual),\n catchError((err) => {\n console.error(err)\n setError(err)\n setLoading(false)\n setData(null)\n\n return err\n })\n )\n .subscribe((documents: SanityDocument[]) => {\n setData((current) => (isEqual(current, documents) ? current : documents))\n setLoading(false)\n setError(false)\n })\n }\n\n return () => {\n return subscription.current ? subscription.current.unsubscribe() : undefined\n }\n }, [query, params, options])\n\n return {loading, error, data}\n}\n","import {Button, Card, Flex} from '@sanity/ui'\nimport React from 'react'\nimport {DocumentsPaneInitialValueTemplate} from './types'\nimport {ComposeIcon} from '@sanity/icons'\nimport {usePaneRouter} from 'sanity/desk'\nimport {uuid} from '@sanity/uuid'\n\ninterface NewDocumentProps {\n initialValueTemplates: DocumentsPaneInitialValueTemplate[]\n}\n\nexport default function NewDocument(props: NewDocumentProps) {\n const {initialValueTemplates = []} = props\n const {ReferenceChildLink} = usePaneRouter()\n\n if (!initialValueTemplates.length) return null\n\n return (\n <Card borderBottom={true} padding={2}>\n <Flex justify=\"flex-end\" gap={1}>\n {initialValueTemplates.map((template) => {\n if (!template.template) {\n return null\n }\n return (\n <ReferenceChildLink\n documentId={uuid()}\n documentType={template.schemaType}\n template={{id: template.template, params: template.parameters}}\n parentRefPath={[]}\n key={`${template.schemaType}-${template.template}`}\n >\n <Button icon={<ComposeIcon />} text={template.title} mode=\"bleed\" as=\"span\" />\n </ReferenceChildLink>\n )\n })}\n </Flex>\n </Card>\n )\n}\n","import {DocumentsPaneQueryParams, DocumentVersionsCollection} from './types'\nimport delve from 'dlv'\n\ninterface ResolveParamsOptions {\n params?: DocumentsPaneQueryParams\n document: DocumentVersionsCollection\n useDraft: boolean\n}\n\ntype ResolveParamsReturn = undefined | {[key: string]: string}\n\nfunction defaultResolver(options: ResolveParamsOptions): {\n [key: string]: string | undefined\n} {\n const {params, document, useDraft} = options\n\n // params is optional\n if (!params) return {}\n\n // legacy useDraft behaviour\n const doc = useDraft ? document.displayed : document.published\n\n return Object.keys(params).reduce(\n (acc, key) => ({\n ...acc,\n [key]: delve(doc, params[key as keyof DocumentsPaneQueryParams]),\n }),\n {}\n )\n}\n\nexport default function resolveParams(options: ResolveParamsOptions): ResolveParamsReturn {\n const {params, document} = options\n\n const resolvedParams = typeof params == 'function' ? params({document}) : defaultResolver(options)\n\n // if any of the parameters are undefined, the query will error\n // so return undefined so the UI can show a more appropriate message\n if (Object.values(resolvedParams).includes(undefined)) return undefined\n\n // Typescript can't tell that we've guarded against any value being undefined,\n // so forcing the type\n return resolvedParams as {[key: string]: string}\n}\n","import {\n DocumentsPaneInitialValueTemplate,\n DocumentsPaneInitialValueTemplateResolver,\n DocumentVersionsCollection,\n} from './types'\n\ninterface ResolveInitialValueTemplatesOptions {\n resolver: DocumentsPaneInitialValueTemplateResolver | undefined\n document: DocumentVersionsCollection\n}\n\nexport default function resolveInitialValueTemplates(\n options: ResolveInitialValueTemplatesOptions\n): DocumentsPaneInitialValueTemplate[] {\n const {resolver, document} = options || {}\n\n if (!resolver) return []\n\n return resolver({document})\n}\n"],"names":[],"version":3,"file":"index.js.map","sourceRoot":"../../"}
@@ -0,0 +1,40 @@
1
+ import { SanityDocument } from "@sanity/client";
2
+ interface DocumentVersionsCollection {
3
+ displayed: SanityDocument;
4
+ published: SanityDocument;
5
+ draft: SanityDocument;
6
+ historical: SanityDocument;
7
+ }
8
+ type DocumentsPaneQueryParams = (params: {
9
+ document: DocumentVersionsCollection;
10
+ }) => ({
11
+ [key: string]: string;
12
+ }) | {
13
+ [key: string]: string;
14
+ };
15
+ interface DocumentsPaneInitialValueTemplate {
16
+ schemaType: string;
17
+ template?: string;
18
+ parameters?: {
19
+ [key: string]: any;
20
+ };
21
+ title: string;
22
+ }
23
+ type DocumentsPaneInitialValueTemplateResolver = (params: {
24
+ document: DocumentVersionsCollection;
25
+ }) => DocumentsPaneInitialValueTemplate[];
26
+ type DocumentsPaneOptions = {
27
+ query: string;
28
+ params?: DocumentsPaneQueryParams;
29
+ debug?: boolean;
30
+ useDraft?: boolean;
31
+ initialValueTemplates?: DocumentsPaneInitialValueTemplateResolver;
32
+ };
33
+ type DocumentsPaneProps = {
34
+ document: DocumentVersionsCollection;
35
+ options: DocumentsPaneOptions;
36
+ };
37
+ declare function DocumentsPane(props: DocumentsPaneProps): JSX.Element;
38
+ export default DocumentsPane;
39
+
40
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"mappings":";AGEA;IACE,SAAS,EAAE,cAAc,CAAA;IACzB,SAAS,EAAE,cAAc,CAAA;IACzB,KAAK,EAAE,cAAc,CAAA;IACrB,UAAU,EAAE,cAAc,CAAA;CAC3B;AAGD,gCAAuC,CAAC,MAAM,EAAE;IAAC,QAAQ,EAAE,0BAA0B,CAAA;CAAC,KAAK,CAAC;IAAC,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;CAAC,CAAC,GAAG;IAAC,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;CAAC,CAAA;AAE9I;IACE,UAAU,EAAE,MAAM,CAAA;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE;QAAC,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;KAAC,CAAA;IACjC,KAAK,EAAE,MAAM,CAAA;CACd;AAGD,iDAAwD,CAAC,MAAM,EAAE;IAAC,QAAQ,EAAE,0BAA0B,CAAA;CAAC,KAAK,iCAAiC,EAAE,CAAA;AAE/I,4BAAmC;IACjC,KAAK,EAAE,MAAM,CAAA;IACb,MAAM,CAAC,EAAE,wBAAwB,CAAA;IACjC,KAAK,CAAC,EAAE,OAAO,CAAA;IACf,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,qBAAqB,CAAC,EAAE,yCAAyC,CAAA;CAClE,CAAA;AAED,0BAAiC;IAC/B,QAAQ,EAAE,0BAA0B,CAAA;IACpC,OAAO,EAAE,oBAAoB,CAAA;CAC9B,CAAA;AKvBD,+BAAsC,KAAK,EAAE,kBAAkB,eAiD9D;ACzDD,eAAe,aAAa,CAAA","sources":["src/src/Debug.tsx","src/src/Feedback.tsx","src/src/hooks/useListeningQuery.ts","src/src/types.ts","src/src/NewDocument.tsx","src/src/Documents.tsx","src/src/resolveParams.ts","src/src/resolveInitialValueTemplates.ts","src/src/DocumentsPane.tsx","src/src/index.ts","src/index.ts"],"sourcesContent":[null,null,null,null,null,null,null,null,null,null,"import DocumentsPane from './DocumentsPane'\n\nexport default DocumentsPane\n"],"names":[],"version":3,"file":"index.d.ts.map","sourceRoot":"../../"}
package/package.json CHANGED
@@ -1,17 +1,34 @@
1
1
  {
2
2
  "name": "sanity-plugin-documents-pane",
3
- "version": "1.1.0",
3
+ "version": "2.0.0-v3-studio.2",
4
4
  "description": "Displays the results of a GROQ query in a View Pane",
5
- "main": "lib/index.js",
5
+ "source": "./src/index.ts",
6
+ "exports": {
7
+ ".": {
8
+ "require": "./lib/cjs/index.js",
9
+ "default": "./lib/esm/index.js"
10
+ }
11
+ },
12
+ "main": "./lib/cjs/index.js",
13
+ "module": "./lib/esm/index.js",
14
+ "types": "./lib/types/index.d.ts",
15
+ "files": [
16
+ "src",
17
+ "lib",
18
+ "v2-incompatible.js",
19
+ "sanity.json"
20
+ ],
6
21
  "scripts": {
7
- "build": "sanipack build",
8
- "verify": "sanipack verify",
9
- "watch": "sanipack build --watch",
10
- "_postinstall": "husky install",
11
- "prepublishOnly": "pinst --disable && sanipack build && sanipack verify",
12
- "postpublish": "pinst --enable",
22
+ "prebuild": "plugin-kit verify-package --silent",
23
+ "build": "parcel build --no-cache",
24
+ "watch": "parcel watch",
25
+ "link-watch": "plugin-kit link-watch",
13
26
  "lint": "eslint .",
14
- "lint:fix": "eslint . --fix"
27
+ "prepublishOnly": "npm run compile && npm run build",
28
+ "compile": "tsc --noEmit"
29
+ },
30
+ "engines": {
31
+ "node": ">=14.0.0"
15
32
  },
16
33
  "husky": {
17
34
  "hooks": {
@@ -30,30 +47,48 @@
30
47
  "license": "MIT",
31
48
  "dependencies": {
32
49
  "@sanity/icons": "^1.3.4",
33
- "@sanity/ui": "^0.38.0",
50
+ "@sanity/incompatible-plugin": "^1.0.4",
51
+ "@sanity/ui": "^0.38.2",
34
52
  "dlv": "^1.1.3",
35
53
  "react-fast-compare": "^3.2.0",
36
54
  "rxjs": "^6.5.6"
37
55
  },
38
56
  "peerDependencies": {
39
- "@sanity/base": "^2.30.1",
40
- "@sanity/desk-tool": "^2.30.1",
41
- "@sanity/uuid": "^3.0.1",
42
57
  "@sanity/util": "^2.29.5",
43
- "react": "^16.0.0 || ^17.0.0"
58
+ "@sanity/uuid": "^3.0.1",
59
+ "react": "^18.0.0",
60
+ "react-dom": "^18.0.0",
61
+ "sanity": "dev-preview"
44
62
  },
45
63
  "devDependencies": {
46
- "@sanity/eslint-config-studio": "^2.0.0",
47
- "eslint": "8.19.0",
64
+ "@commitlint/cli": "^17.1.2",
65
+ "@commitlint/config-conventional": "^17.1.0",
66
+ "@parcel/packager-ts": "^2.7.0",
67
+ "@parcel/transformer-typescript-types": "^2.7.0",
68
+ "@sanity/eslint-config-no-v2-imports": "^0.0.1-studio-v3.3",
69
+ "@sanity/plugin-kit": "^1.0.2",
70
+ "@sanity/semantic-release-preset": "^2.0.1",
71
+ "@sanity/util": "^2.29.5",
72
+ "@sanity/uuid": "^3.0.1",
73
+ "@types/dlv": "^1.1.2",
74
+ "@types/react": "^17.0.0",
75
+ "@types/react-dom": "^17.0.0",
76
+ "@typescript-eslint/eslint-plugin": "^5.38.1",
77
+ "@typescript-eslint/parser": "^5.38.1",
78
+ "eslint": "^8.24.0",
48
79
  "eslint-config-prettier": "^8.5.0",
49
- "eslint-config-sanity": "6.0.0",
80
+ "eslint-config-sanity": "^6.0.0",
50
81
  "eslint-plugin-prettier": "^4.2.1",
51
- "eslint-plugin-react": "^7.30.1",
52
82
  "husky": "^8.0.1",
83
+ "lint-staged": "^13.0.3",
84
+ "parcel": "^2.7.0",
53
85
  "pinst": "^3.0.0",
54
86
  "prettier": "^2.7.1",
87
+ "react": "^18.0.0",
88
+ "react-dom": "^18.0.0",
55
89
  "sanipack": "^2.1.0",
56
- "typescript": "^4.7.4"
90
+ "sanity": "3.0.0-dev-preview.21",
91
+ "typescript": "4.7.3"
57
92
  },
58
93
  "bugs": {
59
94
  "url": "https://github.com/sanity-io/sanity-plugin-document-pane/issues"
package/sanity.json CHANGED
@@ -1,7 +1,8 @@
1
1
  {
2
- "paths": {
3
- "source": "./src",
4
- "compiled": "./lib"
5
- },
6
- "parts": []
7
- }
2
+ "parts": [
3
+ {
4
+ "implements": "part:@sanity/base/sanity-root",
5
+ "path": "./v2-incompatible.js"
6
+ }
7
+ ]
8
+ }
package/src/Documents.tsx CHANGED
@@ -1,9 +1,8 @@
1
1
  import React, {useCallback} from 'react'
2
2
  import {Box, Button, Stack, Flex, Spinner} from '@sanity/ui'
3
3
  import {fromString as pathFromString} from '@sanity/util/paths'
4
- import {usePaneRouter} from '@sanity/desk-tool'
5
- import Preview from 'part:@sanity/base/preview'
6
- import schema from 'part:@sanity/base/schema'
4
+ import {SanityPreview, useSchema} from 'sanity'
5
+ import {usePaneRouter} from 'sanity/desk'
7
6
 
8
7
  import Debug from './Debug'
9
8
  import Feedback from './Feedback'
@@ -21,6 +20,7 @@ type DocumentsProps = {
21
20
  export default function Documents(props: DocumentsProps) {
22
21
  const {query, params, debug, initialValueTemplates} = props
23
22
  const {routerPanesState, groupIndex, handleEditReference} = usePaneRouter()
23
+ const schema = useSchema()
24
24
 
25
25
  const {loading, error, data} = useListeningQuery(query, params)
26
26
 
@@ -76,16 +76,22 @@ export default function Documents(props: DocumentsProps) {
76
76
  <>
77
77
  <NewDocument initialValueTemplates={initialValueTemplates} />
78
78
  <Stack padding={2} space={1}>
79
- {data.map((doc) => (
80
- <Button
81
- key={doc._id}
82
- onClick={() => handleClick(doc._id, doc._type)}
83
- padding={2}
84
- mode="bleed"
85
- >
86
- <Preview value={doc} type={schema.get(doc._type)} />
87
- </Button>
88
- ))}
79
+ {data.map((doc) => {
80
+ const schemaType = schema.get(doc._type)
81
+ if (!schemaType) {
82
+ return null
83
+ }
84
+ return (
85
+ <Button
86
+ key={doc._id}
87
+ onClick={() => handleClick(doc._id, doc._type)}
88
+ padding={2}
89
+ mode="bleed"
90
+ >
91
+ <SanityPreview value={doc} schemaType={schemaType} />
92
+ </Button>
93
+ )
94
+ })}
89
95
  </Stack>
90
96
  </>
91
97
  )
@@ -2,8 +2,8 @@ import {Button, Card, Flex} from '@sanity/ui'
2
2
  import React from 'react'
3
3
  import {DocumentsPaneInitialValueTemplate} from './types'
4
4
  import {ComposeIcon} from '@sanity/icons'
5
- import {usePaneRouter} from '@sanity/desk-tool'
6
- import {uuid} from "@sanity/uuid"
5
+ import {usePaneRouter} from 'sanity/desk'
6
+ import {uuid} from '@sanity/uuid'
7
7
 
8
8
  interface NewDocumentProps {
9
9
  initialValueTemplates: DocumentsPaneInitialValueTemplate[]
@@ -19,6 +19,9 @@ export default function NewDocument(props: NewDocumentProps) {
19
19
  <Card borderBottom={true} padding={2}>
20
20
  <Flex justify="flex-end" gap={1}>
21
21
  {initialValueTemplates.map((template) => {
22
+ if (!template.template) {
23
+ return null
24
+ }
22
25
  return (
23
26
  <ReferenceChildLink
24
27
  documentId={uuid()}
@@ -26,7 +29,6 @@ export default function NewDocument(props: NewDocumentProps) {
26
29
  template={{id: template.template, params: template.parameters}}
27
30
  parentRefPath={[]}
28
31
  key={`${template.schemaType}-${template.template}`}
29
- style={{textDecoration: 'none'}}
30
32
  >
31
33
  <Button icon={<ComposeIcon />} text={template.title} mode="bleed" as="span" />
32
34
  </ReferenceChildLink>