@depup/sanity 5.17.1-depup.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (116) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +57 -0
  3. package/bin/sanity +209 -0
  4. package/changes.json +114 -0
  5. package/lib/_chunks-dts/ActiveWorkspaceMatcherContext.d.ts +16164 -0
  6. package/lib/_chunks-dts/index.d.ts +780 -0
  7. package/lib/_chunks-dts/types.d.ts +2765 -0
  8. package/lib/_chunks-dts/types2.d.ts +656 -0
  9. package/lib/_chunks-dts/types3.d.ts +303 -0
  10. package/lib/_chunks-es/BroadcastDisplayedDocument.js +20 -0
  11. package/lib/_chunks-es/BroadcastDisplayedDocument.js.map +1 -0
  12. package/lib/_chunks-es/DisplayedDocumentBroadcaster.js +32 -0
  13. package/lib/_chunks-es/DisplayedDocumentBroadcaster.js.map +1 -0
  14. package/lib/_chunks-es/LiveQueries.js +339 -0
  15. package/lib/_chunks-es/LiveQueries.js.map +1 -0
  16. package/lib/_chunks-es/MenuGroup.js +106 -0
  17. package/lib/_chunks-es/MenuGroup.js.map +1 -0
  18. package/lib/_chunks-es/PostMessageDocuments.js +72 -0
  19. package/lib/_chunks-es/PostMessageDocuments.js.map +1 -0
  20. package/lib/_chunks-es/PostMessagePerspective.js +23 -0
  21. package/lib/_chunks-es/PostMessagePerspective.js.map +1 -0
  22. package/lib/_chunks-es/PostMessagePreviewSnapshots.js +69 -0
  23. package/lib/_chunks-es/PostMessagePreviewSnapshots.js.map +1 -0
  24. package/lib/_chunks-es/PostMessageRefreshMutations.js +74 -0
  25. package/lib/_chunks-es/PostMessageRefreshMutations.js.map +1 -0
  26. package/lib/_chunks-es/PostMessageSchema.js +502 -0
  27. package/lib/_chunks-es/PostMessageSchema.js.map +1 -0
  28. package/lib/_chunks-es/PostMessageTelemetry.js +21 -0
  29. package/lib/_chunks-es/PostMessageTelemetry.js.map +1 -0
  30. package/lib/_chunks-es/PresentationToolGrantsCheck.js +3848 -0
  31. package/lib/_chunks-es/PresentationToolGrantsCheck.js.map +1 -0
  32. package/lib/_chunks-es/QRCodeSVG.js +692 -0
  33. package/lib/_chunks-es/QRCodeSVG.js.map +1 -0
  34. package/lib/_chunks-es/StructureToolProvider.js +2360 -0
  35. package/lib/_chunks-es/StructureToolProvider.js.map +1 -0
  36. package/lib/_chunks-es/VideoPlayer.js +22 -0
  37. package/lib/_chunks-es/VideoPlayer.js.map +1 -0
  38. package/lib/_chunks-es/ViteDevServerStopped.js +52 -0
  39. package/lib/_chunks-es/ViteDevServerStopped.js.map +1 -0
  40. package/lib/_chunks-es/index.js +285 -0
  41. package/lib/_chunks-es/index.js.map +1 -0
  42. package/lib/_chunks-es/index2.js +105 -0
  43. package/lib/_chunks-es/index2.js.map +1 -0
  44. package/lib/_chunks-es/index3.js +139 -0
  45. package/lib/_chunks-es/index3.js.map +1 -0
  46. package/lib/_chunks-es/index4.js +1020 -0
  47. package/lib/_chunks-es/index4.js.map +1 -0
  48. package/lib/_chunks-es/pane.js +5 -0
  49. package/lib/_chunks-es/pane.js.map +1 -0
  50. package/lib/_chunks-es/pane2.js +5 -0
  51. package/lib/_chunks-es/pane2.js.map +1 -0
  52. package/lib/_chunks-es/presentation.js +549 -0
  53. package/lib/_chunks-es/presentation.js.map +1 -0
  54. package/lib/_chunks-es/resources.js +303 -0
  55. package/lib/_chunks-es/resources.js.map +1 -0
  56. package/lib/_chunks-es/resources2.js +459 -0
  57. package/lib/_chunks-es/resources2.js.map +1 -0
  58. package/lib/_chunks-es/resources3.js +281 -0
  59. package/lib/_chunks-es/resources3.js.map +1 -0
  60. package/lib/_chunks-es/resources4.js +184 -0
  61. package/lib/_chunks-es/resources4.js.map +1 -0
  62. package/lib/_chunks-es/resources5.js +161 -0
  63. package/lib/_chunks-es/resources5.js.map +1 -0
  64. package/lib/_chunks-es/resources6.js +141 -0
  65. package/lib/_chunks-es/resources6.js.map +1 -0
  66. package/lib/_chunks-es/resources7.js +24 -0
  67. package/lib/_chunks-es/resources7.js.map +1 -0
  68. package/lib/_chunks-es/resources8.js +603 -0
  69. package/lib/_chunks-es/resources8.js.map +1 -0
  70. package/lib/_chunks-es/resources9.js +126 -0
  71. package/lib/_chunks-es/resources9.js.map +1 -0
  72. package/lib/_chunks-es/structureTool.js +13673 -0
  73. package/lib/_chunks-es/structureTool.js.map +1 -0
  74. package/lib/_chunks-es/version.js +17 -0
  75. package/lib/_chunks-es/version.js.map +1 -0
  76. package/lib/_createContext.d.ts +12 -0
  77. package/lib/_createContext.js +38 -0
  78. package/lib/_createContext.js.map +1 -0
  79. package/lib/_internal.d.ts +9 -0
  80. package/lib/_internal.js +12 -0
  81. package/lib/_internal.js.map +1 -0
  82. package/lib/_singletons.d.ts +951 -0
  83. package/lib/_singletons.js +284 -0
  84. package/lib/_singletons.js.map +1 -0
  85. package/lib/cli.d.ts +3 -0
  86. package/lib/cli.js +9 -0
  87. package/lib/cli.js.map +1 -0
  88. package/lib/desk.d.ts +910 -0
  89. package/lib/desk.js +71 -0
  90. package/lib/desk.js.map +1 -0
  91. package/lib/index.d.ts +4 -0
  92. package/lib/index.js +92934 -0
  93. package/lib/index.js.map +1 -0
  94. package/lib/media-library.d.ts +85 -0
  95. package/lib/media-library.js +11 -0
  96. package/lib/media-library.js.map +1 -0
  97. package/lib/migrate.d.ts +1 -0
  98. package/lib/migrate.js +2 -0
  99. package/lib/migrate.js.map +1 -0
  100. package/lib/presentation.d.ts +28 -0
  101. package/lib/presentation.js +10 -0
  102. package/lib/presentation.js.map +1 -0
  103. package/lib/router.d.ts +560 -0
  104. package/lib/router.js +777 -0
  105. package/lib/router.js.map +1 -0
  106. package/lib/structure.d.ts +3 -0
  107. package/lib/structure.js +639 -0
  108. package/lib/structure.js.map +1 -0
  109. package/mock-browser-env-stub-loader.mjs +27 -0
  110. package/package.json +383 -0
  111. package/static/favicons/apple-touch-icon.png +0 -0
  112. package/static/favicons/favicon-192.png +0 -0
  113. package/static/favicons/favicon-512.png +0 -0
  114. package/static/favicons/favicon-96.png +0 -0
  115. package/static/favicons/favicon.ico +0 -0
  116. package/static/favicons/favicon.svg +12 -0
@@ -0,0 +1,339 @@
1
+ import { jsx, Fragment } from "react/jsx-runtime";
2
+ import { c } from "react/compiler-runtime";
3
+ import { applySourceDocuments, getPublishedId } from "@sanity/client/csm";
4
+ import { createConnectionMachine } from "@sanity/comlink";
5
+ import { createCompatibilityActors } from "@sanity/presentation-comlink";
6
+ import isEqual from "fast-deep-equal";
7
+ import { useReducer, useState, useEffect, useDeferredValue, memo, useEffectEvent, startTransition } from "react";
8
+ import { useProjectId, useDataset, RELEASES_STUDIO_CLIENT_OPTIONS, isReleasePerspective, useClient } from "sanity";
9
+ import { LOADER_QUERY_GC_INTERVAL, API_VERSION, MIN_LOADER_QUERY_LISTEN_HEARTBEAT_INTERVAL } from "./presentation.js";
10
+ import { toPlainText } from "@portabletext/react";
11
+ import { isPortableTextBlock } from "@portabletext/toolkit";
12
+ function reducer$1(state, event) {
13
+ switch (event.type) {
14
+ case "message":
15
+ return {
16
+ ...state,
17
+ messages: [...state.messages, event]
18
+ };
19
+ case "reconnect":
20
+ case "restart":
21
+ return {
22
+ ...state,
23
+ messages: [],
24
+ resets: state.resets + 1
25
+ };
26
+ case "welcome":
27
+ return state;
28
+ default:
29
+ throw Error(`Unknown event: ${// oxlint-disable-next-line no-explicit-any
30
+ event.type}`, {
31
+ cause: event
32
+ });
33
+ }
34
+ }
35
+ const initialState$1 = {
36
+ messages: [],
37
+ resets: 0
38
+ };
39
+ function useLiveEvents(client) {
40
+ const $ = c(3), [state, dispatch] = useReducer(reducer$1, initialState$1), [error, setError] = useState(null);
41
+ if (error !== null)
42
+ throw error;
43
+ let t0, t1;
44
+ return $[0] !== client.live ? (t0 = () => {
45
+ const subscription = client.live.events({
46
+ includeDrafts: !0,
47
+ tag: "presentation-loader"
48
+ }).subscribe({
49
+ next: dispatch,
50
+ error: (err) => setError(err instanceof Error ? err : new Error("Unexpected error in useLiveEvents", {
51
+ cause: err
52
+ }))
53
+ });
54
+ return () => subscription.unsubscribe();
55
+ }, t1 = [client.live], $[0] = client.live, $[1] = t0, $[2] = t1) : (t0 = $[1], t1 = $[2]), useEffect(t0, t1), useDeferredValue(state);
56
+ }
57
+ const mapChangedValue = (changedValue, {
58
+ previousValue
59
+ }) => {
60
+ if (typeof previousValue == "string") {
61
+ if (typeof changedValue == "number")
62
+ return `${changedValue}`;
63
+ if (Array.isArray(changedValue)) {
64
+ if (changedValue.length === 0)
65
+ return "";
66
+ if (changedValue.some((node) => typeof node == "object" && isPortableTextBlock(node)))
67
+ return toPlainText(changedValue);
68
+ }
69
+ }
70
+ return changedValue;
71
+ };
72
+ function getQueryCacheKey(perspective, query, params) {
73
+ return `${perspective}:${query}:${JSON.stringify(params)}`;
74
+ }
75
+ function gc(state) {
76
+ if (state.queries.size < 1)
77
+ return state;
78
+ const now = Date.now();
79
+ if (!Array.from(state.heartbeats.values()).some((entry) => entry.heartbeat !== !1 && now > entry.receivedAt + entry.heartbeat))
80
+ return state;
81
+ const nextHeartbeats = /* @__PURE__ */ new Map(), nextQueries = /* @__PURE__ */ new Map();
82
+ for (const [key, entry] of state.heartbeats.entries())
83
+ entry.heartbeat !== !1 && now > entry.receivedAt + entry.heartbeat || (nextHeartbeats.set(key, entry), nextQueries.set(key, state.queries.get(key)));
84
+ return {
85
+ ...state,
86
+ queries: nextQueries,
87
+ heartbeats: nextHeartbeats
88
+ };
89
+ }
90
+ function queryListen(state, {
91
+ payload
92
+ }) {
93
+ const key = getQueryCacheKey(payload.perspective, payload.query, payload.params), data = {
94
+ query: payload.query,
95
+ params: payload.params,
96
+ perspective: payload.perspective
97
+ }, nextHeartbeats = new Map(state.heartbeats);
98
+ nextHeartbeats.set(key, {
99
+ receivedAt: Date.now(),
100
+ heartbeat: payload.heartbeat
101
+ });
102
+ let nextQueries = state.queries;
103
+ return (!state.queries.has(key) || !isEqual(state.queries.get(key), data)) && (nextQueries = new Map(state.queries), nextQueries.set(key, data)), {
104
+ heartbeats: nextHeartbeats,
105
+ queries: nextQueries
106
+ };
107
+ }
108
+ function reducer(state, action) {
109
+ switch (action.type) {
110
+ case "query-listen":
111
+ return queryListen(state, action);
112
+ case "gc":
113
+ return gc(state);
114
+ default:
115
+ throw Error(`Unknown action: ${// oxlint-disable-next-line no-explicit-any
116
+ action.type}`, {
117
+ cause: action
118
+ });
119
+ }
120
+ }
121
+ const initialState = {
122
+ queries: /* @__PURE__ */ new Map(),
123
+ heartbeats: /* @__PURE__ */ new Map()
124
+ };
125
+ function useLiveQueries() {
126
+ const $ = c(4), [state, dispatch] = useReducer(reducer, initialState);
127
+ let t0, t1;
128
+ $[0] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t0 = () => {
129
+ const interval = setInterval(() => dispatch({
130
+ type: "gc"
131
+ }), LOADER_QUERY_GC_INTERVAL);
132
+ return () => clearInterval(interval);
133
+ }, t1 = [], $[0] = t0, $[1] = t1) : (t0 = $[0], t1 = $[1]), useEffect(t0, t1);
134
+ const queries = useDeferredValue(state.queries);
135
+ let t2;
136
+ return $[2] !== queries ? (t2 = [queries, dispatch], $[2] = queries, $[3] = t2) : t2 = $[3], t2;
137
+ }
138
+ function LiveQueries(props) {
139
+ const $ = c(28), {
140
+ controller,
141
+ perspective: activePerspective,
142
+ onLoadersConnection,
143
+ onDocumentsOnPage
144
+ } = props, [comlink, setComlink] = useState(), [liveQueries, liveQueriesDispatch] = useLiveQueries(), projectId = useProjectId(), dataset = useDataset();
145
+ let t0, t1;
146
+ $[0] !== controller || $[1] !== dataset || $[2] !== liveQueriesDispatch || $[3] !== onDocumentsOnPage || $[4] !== onLoadersConnection || $[5] !== projectId ? (t0 = () => {
147
+ if (controller) {
148
+ const nextComlink = controller.createChannel({
149
+ name: "presentation",
150
+ connectTo: "loaders",
151
+ heartbeat: !0
152
+ }, createConnectionMachine().provide({
153
+ actors: createCompatibilityActors()
154
+ }));
155
+ return setComlink(nextComlink), nextComlink.onStatus(onLoadersConnection), nextComlink.on("loader/documents", (data) => {
156
+ data.projectId === projectId && data.dataset === dataset && onDocumentsOnPage("loaders", data.perspective, data.documents);
157
+ }), nextComlink.on("loader/query-listen", (data_0) => {
158
+ if (data_0.projectId === projectId && data_0.dataset === dataset) {
159
+ if (typeof data_0.heartbeat == "number" && data_0.heartbeat < MIN_LOADER_QUERY_LISTEN_HEARTBEAT_INTERVAL)
160
+ throw new Error(`Loader query listen heartbeat interval must be at least ${MIN_LOADER_QUERY_LISTEN_HEARTBEAT_INTERVAL}ms`);
161
+ liveQueriesDispatch({
162
+ type: "query-listen",
163
+ payload: {
164
+ perspective: data_0.perspective,
165
+ query: data_0.query,
166
+ params: data_0.params,
167
+ heartbeat: data_0.heartbeat ?? !1
168
+ }
169
+ });
170
+ }
171
+ }), nextComlink.start();
172
+ }
173
+ return _temp;
174
+ }, t1 = [controller, dataset, liveQueriesDispatch, onDocumentsOnPage, onLoadersConnection, projectId], $[0] = controller, $[1] = dataset, $[2] = liveQueriesDispatch, $[3] = onDocumentsOnPage, $[4] = onLoadersConnection, $[5] = projectId, $[6] = t0, $[7] = t1) : (t0 = $[6], t1 = $[7]), useEffect(t0, t1);
175
+ let t2;
176
+ $[8] !== activePerspective ? (t2 = isReleasePerspective(activePerspective) ? RELEASES_STUDIO_CLIENT_OPTIONS : {
177
+ apiVersion: API_VERSION
178
+ }, $[8] = activePerspective, $[9] = t2) : t2 = $[9];
179
+ const studioClient = useClient(t2);
180
+ let t3;
181
+ $[10] !== studioClient ? (t3 = studioClient.withConfig({
182
+ resultSourceMap: "withKeyArraySelector"
183
+ }), $[10] = studioClient, $[11] = t3) : t3 = $[11];
184
+ const client = t3;
185
+ let t4, t5;
186
+ $[12] !== activePerspective || $[13] !== comlink || $[14] !== dataset || $[15] !== projectId ? (t4 = () => {
187
+ comlink && comlink.post("loader/perspective", {
188
+ projectId,
189
+ dataset,
190
+ perspective: activePerspective
191
+ });
192
+ }, t5 = [comlink, activePerspective, projectId, dataset], $[12] = activePerspective, $[13] = comlink, $[14] = dataset, $[15] = projectId, $[16] = t4, $[17] = t5) : (t4 = $[16], t5 = $[17]), useEffect(t4, t5);
193
+ const liveDocument = useDeferredValue(props.liveDocument), liveEvents = useLiveEvents(client);
194
+ let t6;
195
+ $[18] !== liveQueries ? (t6 = [...liveQueries.entries()], $[18] = liveQueries, $[19] = t6) : t6 = $[19];
196
+ let t7;
197
+ return $[20] !== client || $[21] !== comlink || $[22] !== dataset || $[23] !== liveDocument || $[24] !== liveEvents || $[25] !== projectId || $[26] !== t6 ? (t7 = /* @__PURE__ */ jsx(Fragment, { children: t6.map((t8) => {
198
+ const [key, t9] = t8, {
199
+ query,
200
+ params,
201
+ perspective
202
+ } = t9;
203
+ return /* @__PURE__ */ jsx(QuerySubscription, { projectId, dataset, perspective, query, params, comlink, client, liveDocument, liveEventsMessages: liveEvents.messages }, `${liveEvents.resets}:${key}`);
204
+ }) }), $[20] = client, $[21] = comlink, $[22] = dataset, $[23] = liveDocument, $[24] = liveEvents, $[25] = projectId, $[26] = t6, $[27] = t7) : t7 = $[27], t7;
205
+ }
206
+ function _temp() {
207
+ }
208
+ function QuerySubscriptionComponent(props) {
209
+ const $ = c(20), {
210
+ projectId,
211
+ dataset,
212
+ perspective,
213
+ query,
214
+ client,
215
+ liveDocument,
216
+ params,
217
+ comlink,
218
+ liveEventsMessages
219
+ } = props, {
220
+ result,
221
+ resultSourceMap,
222
+ syncTags: tags
223
+ } = useQuerySubscription({
224
+ client,
225
+ liveDocument,
226
+ params,
227
+ perspective,
228
+ query,
229
+ liveEventsMessages
230
+ }) || {};
231
+ let t0;
232
+ $[0] !== dataset || $[1] !== projectId ? (t0 = (comlink_0, perspective_0, query_0, params_0, result_0, resultSourceMap_0, tags_0) => {
233
+ comlink_0?.post("loader/query-change", {
234
+ projectId,
235
+ dataset,
236
+ perspective: perspective_0,
237
+ query: query_0,
238
+ params: params_0,
239
+ result: result_0,
240
+ resultSourceMap: resultSourceMap_0,
241
+ tags: tags_0
242
+ });
243
+ }, $[0] = dataset, $[1] = projectId, $[2] = t0) : t0 = $[2];
244
+ const handleQueryChange = useEffectEvent(t0);
245
+ let t1;
246
+ $[3] !== comlink || $[4] !== handleQueryChange || $[5] !== params || $[6] !== perspective || $[7] !== query || $[8] !== result || $[9] !== resultSourceMap || $[10] !== tags ? (t1 = () => {
247
+ resultSourceMap && handleQueryChange(comlink, perspective, query, params, result, resultSourceMap, tags);
248
+ }, $[3] = comlink, $[4] = handleQueryChange, $[5] = params, $[6] = perspective, $[7] = query, $[8] = result, $[9] = resultSourceMap, $[10] = tags, $[11] = t1) : t1 = $[11];
249
+ let t2;
250
+ return $[12] !== comlink || $[13] !== params || $[14] !== perspective || $[15] !== query || $[16] !== result || $[17] !== resultSourceMap || $[18] !== tags ? (t2 = [comlink, params, perspective, query, result, resultSourceMap, tags], $[12] = comlink, $[13] = params, $[14] = perspective, $[15] = query, $[16] = result, $[17] = resultSourceMap, $[18] = tags, $[19] = t2) : t2 = $[19], useEffect(t1, t2), null;
251
+ }
252
+ const QuerySubscription = memo(QuerySubscriptionComponent);
253
+ QuerySubscription.displayName = "Memo(QuerySubscription)";
254
+ function useQuerySubscription(props) {
255
+ const $ = c(30), {
256
+ liveDocument,
257
+ client,
258
+ query,
259
+ params,
260
+ perspective,
261
+ liveEventsMessages
262
+ } = props, [result, setResult] = useState(null), [resultSourceMap, setResultSourceMap] = useState(null), [syncTags, setSyncTags] = useState(void 0);
263
+ let t0;
264
+ $[0] !== liveEventsMessages ? (t0 = () => new Set(liveEventsMessages.map(_temp2)), $[0] = liveEventsMessages, $[1] = t0) : t0 = $[1];
265
+ const [skipEventIds] = useState(t0);
266
+ let t1;
267
+ if ($[2] !== liveEventsMessages || $[3] !== skipEventIds || $[4] !== syncTags) {
268
+ let t22;
269
+ $[6] !== skipEventIds ? (t22 = (msg_0) => !skipEventIds.has(msg_0.id), $[6] = skipEventIds, $[7] = t22) : t22 = $[7];
270
+ const recentLiveEvents = liveEventsMessages.filter(t22);
271
+ let t32;
272
+ $[8] !== syncTags ? (t32 = (msg_1) => msg_1.tags.some((tag) => syncTags?.includes(tag)), $[8] = syncTags, $[9] = t32) : t32 = $[9], t1 = recentLiveEvents.findLast(t32), $[2] = liveEventsMessages, $[3] = skipEventIds, $[4] = syncTags, $[5] = t1;
273
+ } else
274
+ t1 = $[5];
275
+ const lastLiveEventId = t1?.id, [error, setError] = useState(null);
276
+ if (error)
277
+ throw error;
278
+ let t2, t3;
279
+ $[10] !== client || $[11] !== lastLiveEventId || $[12] !== params || $[13] !== perspective || $[14] !== query ? (t2 = () => {
280
+ const controller = new AbortController();
281
+ return client.fetch(query, params, {
282
+ lastLiveEventId,
283
+ tag: "presentation-loader",
284
+ signal: controller.signal,
285
+ perspective,
286
+ filterResponse: !1,
287
+ returnQuery: !1
288
+ }).then((response) => {
289
+ startTransition(() => {
290
+ setResult((prev) => isEqual(prev, response.result) ? prev : response.result), setResultSourceMap((prev_0) => isEqual(prev_0, response.resultSourceMap) ? prev_0 : response.resultSourceMap), setSyncTags((prev_1) => isEqual(prev_1, response.syncTags) ? prev_1 : response.syncTags);
291
+ });
292
+ }).catch((err) => {
293
+ (typeof err != "object" || err?.name !== "AbortError") && setError(err);
294
+ }), () => {
295
+ controller.abort();
296
+ };
297
+ }, t3 = [client, lastLiveEventId, params, perspective, query], $[10] = client, $[11] = lastLiveEventId, $[12] = params, $[13] = perspective, $[14] = query, $[15] = t2, $[16] = t3) : (t2 = $[15], t3 = $[16]), useEffect(t2, t3);
298
+ let t4;
299
+ bb0: {
300
+ if (liveDocument && resultSourceMap) {
301
+ let t52;
302
+ $[17] !== liveDocument || $[18] !== perspective || $[19] !== result || $[20] !== resultSourceMap ? (t52 = turboChargeResultIfSourceMap(liveDocument, result, perspective, resultSourceMap), $[17] = liveDocument, $[18] = perspective, $[19] = result, $[20] = resultSourceMap, $[21] = t52) : t52 = $[21];
303
+ let t6;
304
+ $[22] !== resultSourceMap || $[23] !== syncTags || $[24] !== t52 ? (t6 = {
305
+ result: t52,
306
+ resultSourceMap,
307
+ syncTags
308
+ }, $[22] = resultSourceMap, $[23] = syncTags, $[24] = t52, $[25] = t6) : t6 = $[25], t4 = t6;
309
+ break bb0;
310
+ }
311
+ let t5;
312
+ $[26] !== result || $[27] !== resultSourceMap || $[28] !== syncTags ? (t5 = {
313
+ result,
314
+ resultSourceMap,
315
+ syncTags
316
+ }, $[26] = result, $[27] = resultSourceMap, $[28] = syncTags, $[29] = t5) : t5 = $[29], t4 = t5;
317
+ }
318
+ return t4;
319
+ }
320
+ function _temp2(msg) {
321
+ return msg.id;
322
+ }
323
+ function turboChargeResultIfSourceMap(liveDocument, result, perspective, resultSourceMap) {
324
+ if (perspective === "raw")
325
+ throw new Error("turboChargeResultIfSourceMap does not support raw perspective");
326
+ return applySourceDocuments(result, resultSourceMap, (sourceDocument) => (
327
+ // If _projectId is set, it's a cross dataset reference and we should skip it
328
+ !sourceDocument._projectId && liveDocument?._id && getPublishedId(liveDocument._id) === getPublishedId(sourceDocument._id) ? typeof liveDocument._id == "string" && typeof sourceDocument._type == "string" ? liveDocument : {
329
+ ...liveDocument,
330
+ _id: liveDocument._id || sourceDocument._id,
331
+ _type: liveDocument._type || sourceDocument._type
332
+ } : null
333
+ ), mapChangedValue, Array.isArray(perspective) ? perspective.filter(Boolean) : perspective);
334
+ }
335
+ export {
336
+ LiveQueries as default,
337
+ turboChargeResultIfSourceMap
338
+ };
339
+ //# sourceMappingURL=LiveQueries.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LiveQueries.js","sources":["../../src/presentation/loader/useLiveEvents.ts","../../src/presentation/loader/utils.ts","../../src/presentation/loader/useLiveQueries.ts","../../src/presentation/loader/LiveQueries.tsx"],"sourcesContent":["import {type LiveEvent, type LiveEventMessage} from '@sanity/client'\nimport {useDeferredValue, useEffect, useReducer, useState} from 'react'\nimport {type SanityClient} from 'sanity'\n\ntype State = {\n /**\n * Growing list over live events with Sync Tags,\n * that can be used to refetch with Sanity Client, using the id as the lastLiveEventId parameter\n */\n messages: LiveEventMessage[]\n /**\n * If the connection experiences a reconnect, or a restart event is received, the counter is incremented.\n * This counter is suitable as a `key` on React Components as a way to reset its internal state and refetch.\n */\n resets: number\n}\n\nexport function reducer(state: State, event: LiveEvent): State {\n switch (event.type) {\n case 'message':\n return {\n ...state,\n messages: [...state.messages, event],\n }\n case 'reconnect':\n case 'restart':\n return {\n ...state,\n messages: [],\n resets: state.resets + 1,\n }\n case 'welcome':\n // no-op\n return state\n default:\n throw Error(\n `Unknown event: ${\n // oxlint-disable-next-line no-explicit-any\n (event as any).type\n }`,\n {cause: event},\n )\n }\n}\n\nexport const initialState: State = {\n messages: [],\n resets: 0,\n}\n\nexport function useLiveEvents(client: SanityClient): State {\n const [state, dispatch] = useReducer(reducer, initialState)\n const [error, setError] = useState<unknown>(null)\n if (error !== null) {\n // Push error to nearest error boundary\n throw error\n }\n\n useEffect(() => {\n const subscription = client.live\n .events({includeDrafts: true, tag: 'presentation-loader'})\n .subscribe({\n next: dispatch,\n error: (err) =>\n setError(\n err instanceof Error\n ? err\n : new Error('Unexpected error in useLiveEvents', {cause: err}),\n ),\n })\n return () => subscription.unsubscribe()\n }, [client.live])\n\n return useDeferredValue(state)\n}\n","import {toPlainText} from '@portabletext/react'\nimport {isPortableTextBlock} from '@portabletext/toolkit'\nimport {type ClientPerspective, type QueryParams} from '@sanity/client'\nimport {type ApplySourceDocumentsUpdateFunction} from '@sanity/client/csm'\nimport {type FIXME} from 'sanity'\n\n/**\n * Used by `applySourceDocuments`\n * @internal\n */\nexport const mapChangedValue: ApplySourceDocumentsUpdateFunction = (\n changedValue: FIXME,\n {previousValue},\n) => {\n if (typeof previousValue === 'string') {\n if (typeof changedValue === 'number') {\n // If the string() function was used in the query, we need to convert the source value to a string as well\n return `${changedValue}`\n }\n // If it's an array in the source, but a string in the query response, it could be pt::text\n if (Array.isArray(changedValue)) {\n if (changedValue.length === 0) {\n // If it's empty assume it's PT and return an empty string\n return ''\n }\n // If the array contains any valid block type, assume the GROQ initially used pt::text on it and do the same conversion\n if (changedValue.some((node) => typeof node === 'object' && isPortableTextBlock(node))) {\n return toPlainText(changedValue)\n }\n }\n }\n\n return changedValue\n}\n\n/**\n * @internal\n */\nexport type QueryCacheKey = `${string}:${string}:${string}`\n/**\n * @internal\n */\nexport function getQueryCacheKey(\n perspective: ClientPerspective,\n query: string,\n params: QueryParams,\n): QueryCacheKey {\n return `${perspective}:${query}:${JSON.stringify(params)}`\n}\n","import {type ClientPerspective} from '@sanity/client'\nimport isEqual from 'fast-deep-equal'\nimport {useDeferredValue, useEffect, useReducer} from 'react'\nimport {type QueryParams} from 'sanity'\n\nimport {LOADER_QUERY_GC_INTERVAL} from '../constants'\nimport {getQueryCacheKey, type QueryCacheKey} from './utils'\n\ntype LiveQueriesState = Map<\n QueryCacheKey,\n {\n query: string\n params: QueryParams\n perspective: ClientPerspective\n }\n>\n\ntype State = {\n queries: LiveQueriesState\n heartbeats: Map<\n QueryCacheKey,\n {\n receivedAt: number\n /**\n * If false it means the query can't safely be garbage collected,\n * as older versions of \\@sanity/core-loader doesn't fire listen events\n * on an interval.\n */\n heartbeat: number | false\n }\n >\n}\n\ntype QueryListenAction = {\n type: 'query-listen'\n payload: {\n perspective: ClientPerspective\n query: string\n params: QueryParams\n heartbeat: number | false\n }\n}\ntype GarbageCollectAction = {type: 'gc'}\ntype Action = QueryListenAction | GarbageCollectAction\n\nfunction gc(state: State): State {\n if (state.queries.size < 1) {\n return state\n }\n\n const now = Date.now()\n const hasAnyExpired = Array.from(state.heartbeats.values()).some(\n (entry) => entry.heartbeat !== false && now > entry.receivedAt + entry.heartbeat,\n )\n if (!hasAnyExpired) {\n return state\n }\n const nextHeartbeats = new Map()\n const nextQueries = new Map()\n for (const [key, entry] of state.heartbeats.entries()) {\n if (entry.heartbeat !== false && now > entry.receivedAt + entry.heartbeat) {\n continue\n }\n nextHeartbeats.set(key, entry)\n nextQueries.set(key, state.queries.get(key))\n }\n\n return {...state, queries: nextQueries, heartbeats: nextHeartbeats}\n}\nfunction queryListen(state: State, {payload}: QueryListenAction): State {\n const key = getQueryCacheKey(payload.perspective, payload.query, payload.params)\n const data = {query: payload.query, params: payload.params, perspective: payload.perspective}\n\n const nextHeartbeats = new Map(state.heartbeats)\n nextHeartbeats.set(key, {\n receivedAt: Date.now(),\n heartbeat: payload.heartbeat,\n })\n\n let nextQueries = state.queries\n /**\n * The data comes from a postMessage event, which uses the structured clone algorithm to serialize state (https://developer.mozilla.org/en-US/docs/Web/API/Window/postMessage#message).\n * This impacts `params`, which is an object, as it will be a new object every time even if the sender is sending the same object instance on their end.\n * It also impacts `perspective`, as it's no longer just a string, but can also be an array of strings.\n * Both cases are handled by fast-deep-equal, which is used to compare the data before deciding wether the state should be updated.\n */\n if (!state.queries.has(key) || !isEqual(state.queries.get(key), data)) {\n nextQueries = new Map(state.queries)\n nextQueries.set(key, data)\n }\n\n return {heartbeats: nextHeartbeats, queries: nextQueries}\n}\n\nexport function reducer(state: State, action: Action): State {\n switch (action.type) {\n case 'query-listen':\n return queryListen(state, action)\n case 'gc':\n return gc(state)\n default:\n throw Error(\n `Unknown action: ${\n // oxlint-disable-next-line no-explicit-any\n (action as any).type\n }`,\n {cause: action},\n )\n }\n}\n\nexport const initialState: State = {\n queries: new Map(),\n heartbeats: new Map(),\n}\n\nexport function useLiveQueries(): [LiveQueriesState, React.ActionDispatch<[action: Action]>] {\n const [state, dispatch] = useReducer(reducer, initialState)\n\n useEffect(() => {\n const interval = setInterval(() => dispatch({type: 'gc'}), LOADER_QUERY_GC_INTERVAL)\n return () => clearInterval(interval)\n }, [])\n\n const queries = useDeferredValue(state.queries)\n return [queries, dispatch]\n}\n","import {\n type ClientPerspective,\n type ContentSourceMap,\n type LiveEventMessage,\n type QueryParams,\n type SyncTag,\n} from '@sanity/client'\nimport {applySourceDocuments, getPublishedId} from '@sanity/client/csm'\nimport {\n type ChannelInstance,\n type Controller,\n createConnectionMachine,\n type StatusEvent,\n} from '@sanity/comlink'\nimport {\n createCompatibilityActors,\n type LoaderControllerMsg,\n type LoaderNodeMsg,\n} from '@sanity/presentation-comlink'\nimport isEqual from 'fast-deep-equal'\nimport {\n memo,\n startTransition,\n useDeferredValue,\n useEffect,\n useEffectEvent,\n useMemo,\n useState,\n} from 'react'\nimport {\n isReleasePerspective,\n RELEASES_STUDIO_CLIENT_OPTIONS,\n type SanityClient,\n type SanityDocument,\n useClient,\n useDataset,\n useProjectId,\n} from 'sanity'\n\nimport {API_VERSION, MIN_LOADER_QUERY_LISTEN_HEARTBEAT_INTERVAL} from '../constants'\nimport {type LoaderConnection, type PresentationPerspective} from '../types'\nimport {type DocumentOnPage} from '../useDocumentsOnPage'\nimport {useLiveEvents} from './useLiveEvents'\nimport {useLiveQueries} from './useLiveQueries'\nimport {mapChangedValue} from './utils'\n\nexport interface LiveQueriesProps {\n liveDocument: Partial<SanityDocument> | null | undefined\n controller: Controller | undefined\n perspective: ClientPerspective\n onLoadersConnection: (event: StatusEvent) => void\n onDocumentsOnPage: (\n key: string,\n perspective: PresentationPerspective,\n state: DocumentOnPage[],\n ) => void\n}\n\nexport default function LiveQueries(props: LiveQueriesProps): React.JSX.Element {\n const {controller, perspective: activePerspective, onLoadersConnection, onDocumentsOnPage} = props\n\n const [comlink, setComlink] = useState<ChannelInstance<LoaderControllerMsg, LoaderNodeMsg>>()\n const [liveQueries, liveQueriesDispatch] = useLiveQueries()\n\n const projectId = useProjectId()\n const dataset = useDataset()\n\n useEffect((): (() => void) => {\n if (controller) {\n const nextComlink = controller.createChannel<LoaderControllerMsg, LoaderNodeMsg>(\n {\n name: 'presentation',\n connectTo: 'loaders',\n heartbeat: true,\n },\n createConnectionMachine<LoaderControllerMsg, LoaderNodeMsg>().provide({\n actors: createCompatibilityActors<LoaderControllerMsg>(),\n }),\n )\n setComlink(nextComlink)\n\n nextComlink.onStatus(onLoadersConnection)\n\n nextComlink.on('loader/documents', (data) => {\n if (data.projectId === projectId && data.dataset === dataset) {\n onDocumentsOnPage(\n 'loaders',\n // oxlint-disable-next-line no-explicit-any\n data.perspective as unknown as any,\n data.documents,\n )\n }\n })\n\n nextComlink.on('loader/query-listen', (data) => {\n if (data.projectId === projectId && data.dataset === dataset) {\n if (\n typeof data.heartbeat === 'number' &&\n data.heartbeat < MIN_LOADER_QUERY_LISTEN_HEARTBEAT_INTERVAL\n ) {\n throw new Error(\n `Loader query listen heartbeat interval must be at least ${MIN_LOADER_QUERY_LISTEN_HEARTBEAT_INTERVAL}ms`,\n )\n }\n liveQueriesDispatch({\n type: 'query-listen',\n payload: {\n perspective: data.perspective,\n query: data.query,\n params: data.params,\n heartbeat: data.heartbeat ?? false,\n },\n })\n }\n })\n\n return nextComlink.start()\n }\n return () => undefined\n }, [controller, dataset, liveQueriesDispatch, onDocumentsOnPage, onLoadersConnection, projectId])\n\n const studioClient = useClient(\n isReleasePerspective(activePerspective)\n ? RELEASES_STUDIO_CLIENT_OPTIONS\n : {apiVersion: API_VERSION},\n )\n const client = useMemo(\n () =>\n studioClient.withConfig({\n resultSourceMap: 'withKeyArraySelector',\n }),\n [studioClient],\n )\n useEffect(() => {\n if (comlink) {\n comlink.post('loader/perspective', {\n projectId,\n dataset,\n perspective: activePerspective,\n })\n }\n }, [comlink, activePerspective, projectId, dataset])\n\n /**\n * Defer the liveDocument to avoid unnecessary rerenders on rapid edits\n */\n const liveDocument = useDeferredValue(props.liveDocument)\n\n const liveEvents = useLiveEvents(client)\n\n return (\n <>\n {[...liveQueries.entries()].map(([key, {query, params, perspective}]) => (\n <QuerySubscription\n key={`${liveEvents.resets}:${key}`}\n projectId={projectId}\n dataset={dataset}\n perspective={perspective}\n query={query}\n params={params}\n comlink={comlink}\n client={client}\n liveDocument={liveDocument}\n liveEventsMessages={liveEvents.messages}\n />\n ))}\n </>\n )\n}\n\ninterface SharedProps {\n /**\n * The Sanity client to use for fetching data and listening to mutations.\n */\n client: SanityClient\n}\n\ninterface QuerySubscriptionProps extends Pick<\n UseQuerySubscriptionProps,\n 'client' | 'liveDocument' | 'liveEventsMessages'\n> {\n projectId: string\n dataset: string\n perspective: ClientPerspective\n query: string\n params: QueryParams\n comlink: LoaderConnection | undefined\n}\nfunction QuerySubscriptionComponent(props: QuerySubscriptionProps) {\n const {\n projectId,\n dataset,\n perspective,\n query,\n client,\n liveDocument,\n params,\n comlink,\n liveEventsMessages,\n } = props\n\n const {\n result,\n resultSourceMap,\n syncTags: tags,\n } = useQuerySubscription({\n client,\n liveDocument,\n params,\n perspective,\n query,\n liveEventsMessages,\n }) || {}\n\n /* eslint-disable @typescript-eslint/no-shadow,max-params */\n const handleQueryChange = useEffectEvent(\n (\n comlink: LoaderConnection | undefined,\n perspective: ClientPerspective,\n query: string,\n params: QueryParams,\n result: unknown,\n resultSourceMap: ContentSourceMap | undefined,\n tags: `s1:${string}`[] | undefined,\n ) => {\n comlink?.post('loader/query-change', {\n projectId,\n dataset,\n perspective,\n query,\n params,\n result,\n resultSourceMap,\n tags,\n })\n },\n )\n /* eslint-enable @typescript-eslint/no-shadow,max-params */\n\n useEffect(() => {\n if (resultSourceMap) {\n handleQueryChange(comlink, perspective, query, params, result, resultSourceMap, tags)\n }\n return undefined\n }, [comlink, params, perspective, query, result, resultSourceMap, tags])\n\n return null\n}\nconst QuerySubscription = memo(QuerySubscriptionComponent)\nQuerySubscription.displayName = 'Memo(QuerySubscription)'\n\ninterface UseQuerySubscriptionProps extends Required<Pick<SharedProps, 'client'>> {\n liveDocument: Partial<SanityDocument> | null | undefined\n query: string\n params: QueryParams\n perspective: ClientPerspective\n liveEventsMessages: LiveEventMessage[]\n}\nfunction useQuerySubscription(props: UseQuerySubscriptionProps) {\n const {liveDocument, client, query, params, perspective, liveEventsMessages} = props\n const [result, setResult] = useState<unknown>(null)\n const [resultSourceMap, setResultSourceMap] = useState<ContentSourceMap | null | undefined>(null)\n const [syncTags, setSyncTags] = useState<SyncTag[] | undefined>(undefined)\n const [skipEventIds] = useState(() => new Set(liveEventsMessages.map((msg) => msg.id)))\n const recentLiveEvents = liveEventsMessages.filter((msg) => !skipEventIds.has(msg.id))\n const lastLiveEvent = recentLiveEvents.findLast((msg) =>\n msg.tags.some((tag) => syncTags?.includes(tag)),\n )\n const lastLiveEventId = lastLiveEvent?.id\n\n // Make sure any async errors bubble up to the nearest error boundary\n const [error, setError] = useState<unknown>(null)\n if (error) throw error\n\n /* eslint-disable max-nested-callbacks */\n useEffect(() => {\n const controller = new AbortController()\n\n client\n .fetch(query, params, {\n lastLiveEventId,\n tag: 'presentation-loader',\n signal: controller.signal,\n perspective,\n filterResponse: false,\n returnQuery: false,\n })\n .then((response) => {\n startTransition(() => {\n setResult((prev: unknown) => (isEqual(prev, response.result) ? prev : response.result))\n setResultSourceMap((prev) =>\n isEqual(prev, response.resultSourceMap) ? prev : response.resultSourceMap,\n )\n setSyncTags((prev) => (isEqual(prev, response.syncTags) ? prev : response.syncTags))\n })\n })\n .catch((err) => {\n if (typeof err !== 'object' || err?.name !== 'AbortError') {\n setError(err)\n }\n })\n\n return () => {\n controller.abort()\n }\n }, [client, lastLiveEventId, params, perspective, query])\n /* eslint-enable max-nested-callbacks */\n\n return useMemo(() => {\n if (liveDocument && resultSourceMap) {\n return {\n result: turboChargeResultIfSourceMap(liveDocument, result, perspective, resultSourceMap),\n resultSourceMap,\n syncTags,\n }\n }\n return {result, resultSourceMap, syncTags}\n }, [liveDocument, perspective, result, resultSourceMap, syncTags])\n}\n\nexport function turboChargeResultIfSourceMap<T = unknown>(\n liveDocument: Partial<SanityDocument> | null | undefined,\n result: T,\n perspective: ClientPerspective,\n resultSourceMap?: ContentSourceMap,\n): T {\n if (perspective === 'raw') {\n throw new Error('turboChargeResultIfSourceMap does not support raw perspective')\n }\n return applySourceDocuments(\n result,\n resultSourceMap,\n (sourceDocument) => {\n // If there's a displayed document, always prefer it\n if (\n // If _projectId is set, it's a cross dataset reference and we should skip it\n !sourceDocument._projectId &&\n liveDocument?._id &&\n getPublishedId(liveDocument._id) === getPublishedId(sourceDocument._id)\n ) {\n if (typeof liveDocument._id === 'string' && typeof sourceDocument._type === 'string') {\n return liveDocument as unknown as Required<Pick<SanityDocument, '_id' | '_type'>>\n }\n return {\n ...liveDocument,\n _id: liveDocument._id || sourceDocument._id,\n _type: liveDocument._type || sourceDocument._type,\n }\n }\n return null\n },\n mapChangedValue,\n Array.isArray(perspective) ? perspective.filter(Boolean) : perspective,\n )\n}\n"],"names":["reducer","state","event","type","messages","resets","Error","cause","initialState","useLiveEvents","client","$","_c","dispatch","useReducer","error","setError","useState","t0","t1","live","subscription","events","includeDrafts","tag","subscribe","next","err","unsubscribe","useEffect","useDeferredValue","mapChangedValue","changedValue","previousValue","Array","isArray","length","some","node","isPortableTextBlock","toPlainText","getQueryCacheKey","perspective","query","params","JSON","stringify","gc","queries","size","now","Date","from","heartbeats","values","entry","heartbeat","receivedAt","nextHeartbeats","Map","nextQueries","key","entries","set","get","queryListen","payload","data","has","isEqual","action","useLiveQueries","Symbol","for","interval","setInterval","LOADER_QUERY_GC_INTERVAL","clearInterval","t2","LiveQueries","props","controller","activePerspective","onLoadersConnection","onDocumentsOnPage","comlink","setComlink","liveQueries","liveQueriesDispatch","projectId","useProjectId","dataset","useDataset","nextComlink","createChannel","name","connectTo","createConnectionMachine","provide","actors","createCompatibilityActors","onStatus","on","documents","data_0","MIN_LOADER_QUERY_LISTEN_HEARTBEAT_INTERVAL","start","_temp","isReleasePerspective","RELEASES_STUDIO_CLIENT_OPTIONS","apiVersion","API_VERSION","studioClient","useClient","t3","withConfig","resultSourceMap","t4","t5","post","liveDocument","liveEvents","t6","t7","map","t8","t9","QuerySubscriptionComponent","liveEventsMessages","result","syncTags","tags","useQuerySubscription","comlink_0","perspective_0","query_0","params_0","result_0","resultSourceMap_0","tags_0","handleQueryChange","useEffectEvent","QuerySubscription","memo","displayName","setResult","setResultSourceMap","setSyncTags","undefined","Set","_temp2","skipEventIds","msg_0","msg","id","recentLiveEvents","filter","msg_1","includes","findLast","lastLiveEventId","AbortController","fetch","signal","filterResponse","returnQuery","then","response","startTransition","prev","prev_0","prev_1","catch","abort","bb0","turboChargeResultIfSourceMap","applySourceDocuments","sourceDocument","_projectId","_id","getPublishedId","_type","Boolean"],"mappings":"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"}
@@ -0,0 +1,106 @@
1
+ import { jsx, jsxs } from "react/jsx-runtime";
2
+ import { c } from "react/compiler-runtime";
3
+ import { Popover, useLayer, useGlobalKeyDown, useClickOutsideEvent, Flex, Box, Text, Button, Grid, MenuGroup as MenuGroup$1 } from "@sanity/ui";
4
+ import { useRef } from "react";
5
+ import { useTranslation } from "react-i18next";
6
+ import { Tooltip } from "./index.js";
7
+ function ConfirmPopover(t0) {
8
+ const $ = c(16), {
9
+ cancelButtonIcon,
10
+ cancelButtonText,
11
+ confirmButtonIcon,
12
+ confirmButtonText,
13
+ message,
14
+ onCancel,
15
+ onConfirm,
16
+ open,
17
+ referenceElement,
18
+ tone: t1,
19
+ placement: t2,
20
+ fallbackPlacements: t3
21
+ } = t0, tone = t1 === void 0 ? "critical" : t1, placement = t2 === void 0 ? "top" : t2;
22
+ let t4;
23
+ $[0] !== t3 ? (t4 = t3 === void 0 ? ["left", "bottom"] : t3, $[0] = t3, $[1] = t4) : t4 = $[1];
24
+ const fallbackPlacements = t4;
25
+ if (!open)
26
+ return null;
27
+ let t5;
28
+ $[2] !== cancelButtonIcon || $[3] !== cancelButtonText || $[4] !== confirmButtonIcon || $[5] !== confirmButtonText || $[6] !== message || $[7] !== onCancel || $[8] !== onConfirm || $[9] !== tone ? (t5 = /* @__PURE__ */ jsx(ConfirmPopoverContent, { cancelButtonIcon, cancelButtonText, confirmButtonIcon, confirmButtonText, message, onCancel, onConfirm, tone }), $[2] = cancelButtonIcon, $[3] = cancelButtonText, $[4] = confirmButtonIcon, $[5] = confirmButtonText, $[6] = message, $[7] = onCancel, $[8] = onConfirm, $[9] = tone, $[10] = t5) : t5 = $[10];
29
+ let t6;
30
+ return $[11] !== fallbackPlacements || $[12] !== placement || $[13] !== referenceElement || $[14] !== t5 ? (t6 = /* @__PURE__ */ jsx(Popover, { content: t5, constrainSize: !0, fallbackPlacements, open: !0, placement, portal: !0, preventOverflow: !0, referenceElement }), $[11] = fallbackPlacements, $[12] = placement, $[13] = referenceElement, $[14] = t5, $[15] = t6) : t6 = $[15], t6;
31
+ }
32
+ function ConfirmPopoverContent(t0) {
33
+ const $ = c(29), {
34
+ cancelButtonIcon,
35
+ cancelButtonText,
36
+ confirmButtonIcon,
37
+ confirmButtonText,
38
+ message,
39
+ onCancel,
40
+ onConfirm,
41
+ tone
42
+ } = t0, {
43
+ t
44
+ } = useTranslation(), {
45
+ isTopLayer
46
+ } = useLayer(), ref = useRef(null);
47
+ let t1;
48
+ $[0] !== isTopLayer || $[1] !== onCancel ? (t1 = (event) => {
49
+ event.key === "Escape" && isTopLayer && onCancel();
50
+ }, $[0] = isTopLayer, $[1] = onCancel, $[2] = t1) : t1 = $[2], useGlobalKeyDown(t1);
51
+ let t2;
52
+ $[3] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t2 = () => [ref.current], $[3] = t2) : t2 = $[3], useClickOutsideEvent(isTopLayer && onCancel, t2);
53
+ let t3;
54
+ $[4] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t3 = {
55
+ minWidth: 280,
56
+ maxWidth: 350
57
+ }, $[4] = t3) : t3 = $[4];
58
+ let t4;
59
+ $[5] !== message ? (t4 = /* @__PURE__ */ jsx(Box, { flex: 1, overflow: "auto", padding: 4, children: /* @__PURE__ */ jsx(Text, { size: 1, children: message }) }), $[5] = message, $[6] = t4) : t4 = $[6];
60
+ let t5;
61
+ $[7] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t5 = {
62
+ borderTop: "1px solid var(--card-border-color)"
63
+ }, $[7] = t5) : t5 = $[7];
64
+ let t6;
65
+ $[8] !== cancelButtonText || $[9] !== t ? (t6 = cancelButtonText || t("common.dialog.cancel-button.text"), $[8] = cancelButtonText, $[9] = t, $[10] = t6) : t6 = $[10];
66
+ let t7;
67
+ $[11] !== cancelButtonIcon || $[12] !== onCancel || $[13] !== t6 ? (t7 = /* @__PURE__ */ jsx(Button, { "data-testid": "confirm-popover-cancel-button", icon: cancelButtonIcon, onClick: onCancel, mode: "ghost", padding: 2, text: t6, size: 1 }), $[11] = cancelButtonIcon, $[12] = onCancel, $[13] = t6, $[14] = t7) : t7 = $[14];
68
+ let t8;
69
+ $[15] !== confirmButtonText || $[16] !== t ? (t8 = confirmButtonText || t("common.dialog.confirm-button.text"), $[15] = confirmButtonText, $[16] = t, $[17] = t8) : t8 = $[17];
70
+ let t9;
71
+ $[18] !== confirmButtonIcon || $[19] !== onConfirm || $[20] !== t8 || $[21] !== tone ? (t9 = /* @__PURE__ */ jsx(Button, { "data-testid": "confirm-popover-confirm-button", icon: confirmButtonIcon, onClick: onConfirm, padding: 2, text: t8, tone, size: 1 }), $[18] = confirmButtonIcon, $[19] = onConfirm, $[20] = t8, $[21] = tone, $[22] = t9) : t9 = $[22];
72
+ let t10;
73
+ $[23] !== t7 || $[24] !== t9 ? (t10 = /* @__PURE__ */ jsx(Box, { paddingX: 4, paddingY: 3, style: t5, children: /* @__PURE__ */ jsxs(Grid, { columns: 2, gap: 2, children: [
74
+ t7,
75
+ t9
76
+ ] }) }), $[23] = t7, $[24] = t9, $[25] = t10) : t10 = $[25];
77
+ let t11;
78
+ return $[26] !== t10 || $[27] !== t4 ? (t11 = /* @__PURE__ */ jsxs(Flex, { direction: "column", ref, style: t3, children: [
79
+ t4,
80
+ t10
81
+ ] }), $[26] = t10, $[27] = t4, $[28] = t11) : t11 = $[28], t11;
82
+ }
83
+ const MenuGroup = (props) => {
84
+ const $ = c(11);
85
+ let rest, tooltipProps;
86
+ $[0] !== props ? ({
87
+ tooltipProps,
88
+ ...rest
89
+ } = props, $[0] = props, $[1] = rest, $[2] = tooltipProps) : (rest = $[1], tooltipProps = $[2]);
90
+ let t0;
91
+ $[3] !== rest ? (t0 = /* @__PURE__ */ jsx(MenuGroup$1, { ...rest, fontSize: 1, padding: 3 }), $[3] = rest, $[4] = t0) : t0 = $[4];
92
+ const children = t0;
93
+ if (tooltipProps) {
94
+ const t1 = tooltipProps?.content;
95
+ let t2;
96
+ $[5] !== children ? (t2 = /* @__PURE__ */ jsx("div", { children }), $[5] = children, $[6] = t2) : t2 = $[6];
97
+ let t3;
98
+ return $[7] !== t1 || $[8] !== t2 || $[9] !== tooltipProps ? (t3 = /* @__PURE__ */ jsx(Tooltip, { content: t1, portal: !0, ...tooltipProps, children: t2 }), $[7] = t1, $[8] = t2, $[9] = tooltipProps, $[10] = t3) : t3 = $[10], t3;
99
+ }
100
+ return children;
101
+ };
102
+ export {
103
+ ConfirmPopover,
104
+ MenuGroup
105
+ };
106
+ //# sourceMappingURL=MenuGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MenuGroup.js","sources":["../../src/ui-components/confirmPopover/ConfirmPopover.tsx","../../src/ui-components/menuGroup/MenuGroup.tsx"],"sourcesContent":["/* eslint-disable no-restricted-imports, @sanity/i18n/no-i18next-import */\nimport {\n Box,\n Button as UIButton,\n Flex,\n Grid,\n Popover as UIPopover,\n type PopoverProps as UIPopoverProps,\n Text,\n useClickOutsideEvent,\n useGlobalKeyDown,\n useLayer,\n} from '@sanity/ui'\nimport {type ComponentType, type ReactNode, useCallback, useRef} from 'react'\nimport {useTranslation} from 'react-i18next'\n\nexport interface ConfirmPopoverProps {\n cancelButtonIcon?: ReactNode | ComponentType\n cancelButtonText?: string\n confirmButtonIcon?: ReactNode | ComponentType\n confirmButtonText?: string\n message: ReactNode\n onCancel: () => void\n onConfirm: () => void\n open: boolean\n referenceElement: HTMLElement | null\n tone?: 'default' | 'primary' | 'positive' | 'caution' | 'critical' | 'neutral' | 'suggest'\n placement?: UIPopoverProps['placement']\n fallbackPlacements?: UIPopoverProps['fallbackPlacements']\n}\n\n/**\n * A popover component for inline confirmation dialogs.\n * Follows the same pattern as document action confirm dialogs.\n *\n * @internal\n */\nexport function ConfirmPopover({\n cancelButtonIcon,\n cancelButtonText,\n confirmButtonIcon,\n confirmButtonText,\n message,\n onCancel,\n onConfirm,\n open,\n referenceElement,\n tone = 'critical',\n placement = 'top',\n fallbackPlacements = ['left', 'bottom'],\n}: ConfirmPopoverProps) {\n if (!open) return null\n\n return (\n <UIPopover\n content={\n <ConfirmPopoverContent\n cancelButtonIcon={cancelButtonIcon}\n cancelButtonText={cancelButtonText}\n confirmButtonIcon={confirmButtonIcon}\n confirmButtonText={confirmButtonText}\n message={message}\n onCancel={onCancel}\n onConfirm={onConfirm}\n tone={tone}\n />\n }\n constrainSize\n fallbackPlacements={fallbackPlacements}\n open\n placement={placement}\n portal\n preventOverflow\n referenceElement={referenceElement}\n />\n )\n}\n\nfunction ConfirmPopoverContent({\n cancelButtonIcon,\n cancelButtonText,\n confirmButtonIcon,\n confirmButtonText,\n message,\n onCancel,\n onConfirm,\n tone,\n}: Omit<ConfirmPopoverProps, 'open' | 'referenceElement' | 'placement' | 'fallbackPlacements'>) {\n const {t} = useTranslation()\n const {isTopLayer} = useLayer()\n const ref = useRef<HTMLDivElement | null>(null)\n\n const handleGlobalKeyDown = useCallback(\n (event: KeyboardEvent) => {\n if (event.key === 'Escape' && isTopLayer) onCancel()\n },\n [isTopLayer, onCancel],\n )\n\n useGlobalKeyDown(handleGlobalKeyDown)\n useClickOutsideEvent(isTopLayer && onCancel, () => [ref.current])\n\n return (\n <Flex direction=\"column\" ref={ref} style={{minWidth: 280, maxWidth: 350}}>\n <Box flex={1} overflow=\"auto\" padding={4}>\n <Text size={1}>{message}</Text>\n </Box>\n <Box paddingX={4} paddingY={3} style={{borderTop: '1px solid var(--card-border-color)'}}>\n <Grid columns={2} gap={2}>\n <UIButton\n data-testid=\"confirm-popover-cancel-button\"\n icon={cancelButtonIcon}\n onClick={onCancel}\n mode=\"ghost\"\n padding={2}\n text={cancelButtonText || t('common.dialog.cancel-button.text')}\n size={1}\n />\n <UIButton\n data-testid=\"confirm-popover-confirm-button\"\n icon={confirmButtonIcon}\n onClick={onConfirm}\n padding={2}\n text={confirmButtonText || t('common.dialog.confirm-button.text')}\n tone={tone}\n size={1}\n />\n </Grid>\n </Box>\n </Flex>\n )\n}\n","/* eslint-disable no-restricted-imports */\nimport {MenuGroup as UIMenuGroup, type MenuGroupProps as UIMenuGroupProps} from '@sanity/ui'\nimport {type HTMLProps} from 'react'\n\nimport {Tooltip, type TooltipProps} from '../tooltip/Tooltip'\n\n/** @internal */\nexport type MenuGroupProps = Pick<UIMenuGroupProps, 'icon' | 'popover' | 'text' | 'tone'>\n\n/**\n * Customized Sanity UI <MenuGroup> component with pre-defined layout options.\n *\n * @internal\n */\nexport const MenuGroup = (\n props: MenuGroupProps &\n Omit<HTMLProps<HTMLDivElement>, 'as' | 'height' | 'ref' | 'tabIndex' | 'popover'> & {\n tooltipProps?: TooltipProps | null\n },\n) => {\n const {tooltipProps, ...rest} = props\n\n const children = <UIMenuGroup {...rest} fontSize={1} padding={3} />\n\n if (tooltipProps) {\n return (\n <Tooltip content={tooltipProps?.content} portal {...tooltipProps}>\n {/* This div is needed to make the tooltip work in disabled menu items */}\n <div>{children}</div>\n </Tooltip>\n )\n }\n\n return children\n}\n"],"names":["ConfirmPopover","t0","$","_c","cancelButtonIcon","cancelButtonText","confirmButtonIcon","confirmButtonText","message","onCancel","onConfirm","open","referenceElement","tone","t1","placement","t2","fallbackPlacements","t3","undefined","t4","t5","t6","UIPopover","ConfirmPopoverContent","t","useTranslation","isTopLayer","useLayer","ref","useRef","event","key","useGlobalKeyDown","Symbol","for","current","useClickOutsideEvent","minWidth","maxWidth","borderTop","t7","UIButton","t8","t9","t10","t11","MenuGroup","props","rest","tooltipProps","UIMenuGroup","children","content"],"mappings":"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"}
@@ -0,0 +1,72 @@
1
+ import { c } from "react/compiler-runtime";
2
+ import { memo, useEffect } from "react";
3
+ import { filter, shareReplay, first, merge } from "rxjs";
4
+ import { RELEASES_STUDIO_CLIENT_OPTIONS, isReleasePerspective, useClient } from "sanity";
5
+ import { API_VERSION } from "./presentation.js";
6
+ const PostMessageDocuments = (props) => {
7
+ const $ = c(14), {
8
+ comlink,
9
+ perspective
10
+ } = props;
11
+ let t0;
12
+ $[0] !== perspective ? (t0 = isReleasePerspective(perspective) ? RELEASES_STUDIO_CLIENT_OPTIONS : {
13
+ apiVersion: API_VERSION
14
+ }, $[0] = perspective, $[1] = t0) : t0 = $[1];
15
+ const client = useClient(t0);
16
+ let t1, t2;
17
+ $[2] !== client || $[3] !== comlink ? (t1 = () => {
18
+ const listener = client.listen('*[!(_id in path("_.**"))]', {}, {
19
+ effectFormat: "mendoza",
20
+ events: ["welcome", "mutation", "reconnect"],
21
+ includePreviousRevision: !1,
22
+ includeResult: !1,
23
+ includeAllVersions: !0,
24
+ tag: "presentation-documents",
25
+ visibility: "transaction"
26
+ }).pipe(filter(_temp)), welcome = listener.pipe(filter(_temp2), shareReplay({
27
+ bufferSize: 1,
28
+ refCount: !1
29
+ })), unsubscribe = comlink.on("visual-editing/snapshot-welcome", async () => ({
30
+ event: await new Promise((resolve) => {
31
+ welcome.pipe(first()).subscribe((event_1) => {
32
+ resolve(event_1);
33
+ });
34
+ })
35
+ })), reconnect = listener.pipe(filter(_temp3)), mutations = listener.pipe(filter(_temp4)), events = merge(welcome, mutations, reconnect).subscribe((event_5) => {
36
+ comlink.post("presentation/snapshot-event", {
37
+ event: event_5
38
+ });
39
+ });
40
+ return () => {
41
+ unsubscribe(), events.unsubscribe();
42
+ };
43
+ }, t2 = [client, comlink], $[2] = client, $[3] = comlink, $[4] = t1, $[5] = t2) : (t1 = $[4], t2 = $[5]), useEffect(t1, t2);
44
+ let t3, t4;
45
+ $[6] !== client || $[7] !== comlink ? (t3 = () => comlink.on("visual-editing/fetch-snapshot", async (data) => ({
46
+ snapshot: await client.getDocument(data.documentId, {
47
+ tag: "document.snapshots"
48
+ })
49
+ })), t4 = [client, comlink], $[6] = client, $[7] = comlink, $[8] = t3, $[9] = t4) : (t3 = $[8], t4 = $[9]), useEffect(t3, t4);
50
+ let t5, t6;
51
+ return $[10] !== client || $[11] !== comlink ? (t5 = () => comlink.on("visual-editing/mutate", async (data_0) => client.dataRequest("mutate", data_0, {
52
+ visibility: "async",
53
+ returnDocuments: !0
54
+ })), t6 = [client, comlink], $[10] = client, $[11] = comlink, $[12] = t5, $[13] = t6) : (t5 = $[12], t6 = $[13]), useEffect(t5, t6), null;
55
+ };
56
+ var PostMessageDocuments_default = memo(PostMessageDocuments);
57
+ function _temp(event) {
58
+ return event.type === "welcome" || event.type === "reconnect" || event.type === "mutation";
59
+ }
60
+ function _temp2(event_0) {
61
+ return event_0.type === "welcome";
62
+ }
63
+ function _temp3(event_3) {
64
+ return event_3.type === "reconnect";
65
+ }
66
+ function _temp4(event_4) {
67
+ return event_4.type === "mutation";
68
+ }
69
+ export {
70
+ PostMessageDocuments_default as default
71
+ };
72
+ //# sourceMappingURL=PostMessageDocuments.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PostMessageDocuments.js","sources":["../../src/presentation/overlays/PostMessageDocuments.tsx"],"sourcesContent":["import {\n type ClientPerspective,\n type MutationEvent,\n type ReconnectEvent,\n type WelcomeEvent,\n} from '@sanity/client'\nimport {type FunctionComponent, memo, useEffect} from 'react'\nimport {filter, first, merge, shareReplay} from 'rxjs'\nimport {isReleasePerspective, RELEASES_STUDIO_CLIENT_OPTIONS, useClient} from 'sanity'\n\nimport {API_VERSION} from '../constants'\nimport {type VisualEditingConnection} from '../types'\n\ninterface PostMessageDocumentsProps {\n comlink: VisualEditingConnection\n perspective: ClientPerspective\n}\n\nconst PostMessageDocuments: FunctionComponent<PostMessageDocumentsProps> = (props) => {\n const {comlink, perspective} = props\n\n const client = useClient(\n isReleasePerspective(perspective) ? RELEASES_STUDIO_CLIENT_OPTIONS : {apiVersion: API_VERSION},\n )\n\n useEffect(() => {\n const listener = client\n .listen(\n '*[!(_id in path(\"_.**\"))]',\n {},\n {\n effectFormat: 'mendoza',\n events: ['welcome', 'mutation', 'reconnect'],\n includePreviousRevision: false,\n includeResult: false,\n includeAllVersions: true,\n tag: 'presentation-documents',\n visibility: 'transaction',\n },\n )\n .pipe(\n filter(\n (event): event is WelcomeEvent | ReconnectEvent | MutationEvent =>\n event.type === 'welcome' || event.type === 'reconnect' || event.type === 'mutation',\n ),\n )\n\n const welcome = listener.pipe(\n filter((event): event is WelcomeEvent => event.type === 'welcome'),\n shareReplay({bufferSize: 1, refCount: false}),\n )\n\n // When new contexts initialize, they need to explicitly request the welcome\n // event, as we can't rely on emitting it into the void\n const unsubscribe = comlink.on('visual-editing/snapshot-welcome', async () => {\n const event = await new Promise<WelcomeEvent>((resolve) => {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n welcome.pipe(first()).subscribe((event) => {\n resolve(event)\n })\n })\n return {event}\n })\n\n const reconnect = listener.pipe(\n filter((event): event is ReconnectEvent => event.type === 'reconnect'),\n )\n\n const mutations = listener.pipe(\n filter((event): event is MutationEvent => event.type === 'mutation'),\n )\n\n const events = merge(\n /**\n * @deprecated remove 'welcome' here and switch to explict welcome message fetching at next major\n */\n welcome,\n mutations,\n reconnect,\n ).subscribe((event) => {\n comlink.post('presentation/snapshot-event', {event})\n })\n\n return () => {\n unsubscribe()\n events.unsubscribe()\n }\n }, [client, comlink])\n\n useEffect(() => {\n return comlink.on('visual-editing/fetch-snapshot', async (data) => {\n const snapshot = await client.getDocument(data.documentId, {\n tag: 'document.snapshots',\n })\n return {snapshot}\n })\n }, [client, comlink])\n\n useEffect(() => {\n return comlink.on('visual-editing/mutate', async (data) => {\n return client.dataRequest('mutate', data, {\n visibility: 'async',\n returnDocuments: true,\n })\n })\n }, [client, comlink])\n\n return null\n}\n\nexport default memo(PostMessageDocuments)\n"],"names":["PostMessageDocuments","props","$","_c","comlink","perspective","t0","isReleasePerspective","RELEASES_STUDIO_CLIENT_OPTIONS","apiVersion","API_VERSION","client","useClient","t1","t2","listener","listen","effectFormat","events","includePreviousRevision","includeResult","includeAllVersions","tag","visibility","pipe","filter","_temp","welcome","_temp2","shareReplay","bufferSize","refCount","unsubscribe","on","event","Promise","resolve","first","subscribe","event_1","reconnect","_temp3","mutations","_temp4","merge","event_5","post","useEffect","t3","t4","data","snapshot","getDocument","documentId","t5","t6","data_0","dataRequest","returnDocuments","memo","type","event_0","event_3","event_4"],"mappings":"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"}