@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.
- package/LICENSE +21 -0
- package/README.md +57 -0
- package/bin/sanity +209 -0
- package/changes.json +114 -0
- package/lib/_chunks-dts/ActiveWorkspaceMatcherContext.d.ts +16164 -0
- package/lib/_chunks-dts/index.d.ts +780 -0
- package/lib/_chunks-dts/types.d.ts +2765 -0
- package/lib/_chunks-dts/types2.d.ts +656 -0
- package/lib/_chunks-dts/types3.d.ts +303 -0
- package/lib/_chunks-es/BroadcastDisplayedDocument.js +20 -0
- package/lib/_chunks-es/BroadcastDisplayedDocument.js.map +1 -0
- package/lib/_chunks-es/DisplayedDocumentBroadcaster.js +32 -0
- package/lib/_chunks-es/DisplayedDocumentBroadcaster.js.map +1 -0
- package/lib/_chunks-es/LiveQueries.js +339 -0
- package/lib/_chunks-es/LiveQueries.js.map +1 -0
- package/lib/_chunks-es/MenuGroup.js +106 -0
- package/lib/_chunks-es/MenuGroup.js.map +1 -0
- package/lib/_chunks-es/PostMessageDocuments.js +72 -0
- package/lib/_chunks-es/PostMessageDocuments.js.map +1 -0
- package/lib/_chunks-es/PostMessagePerspective.js +23 -0
- package/lib/_chunks-es/PostMessagePerspective.js.map +1 -0
- package/lib/_chunks-es/PostMessagePreviewSnapshots.js +69 -0
- package/lib/_chunks-es/PostMessagePreviewSnapshots.js.map +1 -0
- package/lib/_chunks-es/PostMessageRefreshMutations.js +74 -0
- package/lib/_chunks-es/PostMessageRefreshMutations.js.map +1 -0
- package/lib/_chunks-es/PostMessageSchema.js +502 -0
- package/lib/_chunks-es/PostMessageSchema.js.map +1 -0
- package/lib/_chunks-es/PostMessageTelemetry.js +21 -0
- package/lib/_chunks-es/PostMessageTelemetry.js.map +1 -0
- package/lib/_chunks-es/PresentationToolGrantsCheck.js +3848 -0
- package/lib/_chunks-es/PresentationToolGrantsCheck.js.map +1 -0
- package/lib/_chunks-es/QRCodeSVG.js +692 -0
- package/lib/_chunks-es/QRCodeSVG.js.map +1 -0
- package/lib/_chunks-es/StructureToolProvider.js +2360 -0
- package/lib/_chunks-es/StructureToolProvider.js.map +1 -0
- package/lib/_chunks-es/VideoPlayer.js +22 -0
- package/lib/_chunks-es/VideoPlayer.js.map +1 -0
- package/lib/_chunks-es/ViteDevServerStopped.js +52 -0
- package/lib/_chunks-es/ViteDevServerStopped.js.map +1 -0
- package/lib/_chunks-es/index.js +285 -0
- package/lib/_chunks-es/index.js.map +1 -0
- package/lib/_chunks-es/index2.js +105 -0
- package/lib/_chunks-es/index2.js.map +1 -0
- package/lib/_chunks-es/index3.js +139 -0
- package/lib/_chunks-es/index3.js.map +1 -0
- package/lib/_chunks-es/index4.js +1020 -0
- package/lib/_chunks-es/index4.js.map +1 -0
- package/lib/_chunks-es/pane.js +5 -0
- package/lib/_chunks-es/pane.js.map +1 -0
- package/lib/_chunks-es/pane2.js +5 -0
- package/lib/_chunks-es/pane2.js.map +1 -0
- package/lib/_chunks-es/presentation.js +549 -0
- package/lib/_chunks-es/presentation.js.map +1 -0
- package/lib/_chunks-es/resources.js +303 -0
- package/lib/_chunks-es/resources.js.map +1 -0
- package/lib/_chunks-es/resources2.js +459 -0
- package/lib/_chunks-es/resources2.js.map +1 -0
- package/lib/_chunks-es/resources3.js +281 -0
- package/lib/_chunks-es/resources3.js.map +1 -0
- package/lib/_chunks-es/resources4.js +184 -0
- package/lib/_chunks-es/resources4.js.map +1 -0
- package/lib/_chunks-es/resources5.js +161 -0
- package/lib/_chunks-es/resources5.js.map +1 -0
- package/lib/_chunks-es/resources6.js +141 -0
- package/lib/_chunks-es/resources6.js.map +1 -0
- package/lib/_chunks-es/resources7.js +24 -0
- package/lib/_chunks-es/resources7.js.map +1 -0
- package/lib/_chunks-es/resources8.js +603 -0
- package/lib/_chunks-es/resources8.js.map +1 -0
- package/lib/_chunks-es/resources9.js +126 -0
- package/lib/_chunks-es/resources9.js.map +1 -0
- package/lib/_chunks-es/structureTool.js +13673 -0
- package/lib/_chunks-es/structureTool.js.map +1 -0
- package/lib/_chunks-es/version.js +17 -0
- package/lib/_chunks-es/version.js.map +1 -0
- package/lib/_createContext.d.ts +12 -0
- package/lib/_createContext.js +38 -0
- package/lib/_createContext.js.map +1 -0
- package/lib/_internal.d.ts +9 -0
- package/lib/_internal.js +12 -0
- package/lib/_internal.js.map +1 -0
- package/lib/_singletons.d.ts +951 -0
- package/lib/_singletons.js +284 -0
- package/lib/_singletons.js.map +1 -0
- package/lib/cli.d.ts +3 -0
- package/lib/cli.js +9 -0
- package/lib/cli.js.map +1 -0
- package/lib/desk.d.ts +910 -0
- package/lib/desk.js +71 -0
- package/lib/desk.js.map +1 -0
- package/lib/index.d.ts +4 -0
- package/lib/index.js +92934 -0
- package/lib/index.js.map +1 -0
- package/lib/media-library.d.ts +85 -0
- package/lib/media-library.js +11 -0
- package/lib/media-library.js.map +1 -0
- package/lib/migrate.d.ts +1 -0
- package/lib/migrate.js +2 -0
- package/lib/migrate.js.map +1 -0
- package/lib/presentation.d.ts +28 -0
- package/lib/presentation.js +10 -0
- package/lib/presentation.js.map +1 -0
- package/lib/router.d.ts +560 -0
- package/lib/router.js +777 -0
- package/lib/router.js.map +1 -0
- package/lib/structure.d.ts +3 -0
- package/lib/structure.js +639 -0
- package/lib/structure.js.map +1 -0
- package/mock-browser-env-stub-loader.mjs +27 -0
- package/package.json +383 -0
- package/static/favicons/apple-touch-icon.png +0 -0
- package/static/favicons/favicon-192.png +0 -0
- package/static/favicons/favicon-512.png +0 -0
- package/static/favicons/favicon-96.png +0 -0
- package/static/favicons/favicon.ico +0 -0
- 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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"}
|