@sanity/assist 4.4.4 → 4.4.6
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/dist/index.esm.js +41 -37
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +41 -37
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +41 -37
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
- package/src/assistDocument/hooks/useAssistDocumentContextValue.tsx +1 -1
- package/src/assistLayout/AiAssistanceConfigContext.tsx +13 -1
- package/src/useApiClient.ts +6 -11
package/dist/index.js
CHANGED
|
@@ -478,39 +478,6 @@ function useAiPaneRouter() {
|
|
|
478
478
|
[paneRouter]
|
|
479
479
|
);
|
|
480
480
|
}
|
|
481
|
-
const AiAssistanceConfigContext = react.createContext({});
|
|
482
|
-
function useAiAssistanceConfig() {
|
|
483
|
-
const context = react.useContext(AiAssistanceConfigContext);
|
|
484
|
-
if (!context)
|
|
485
|
-
throw new Error("Missing AiAssistanceConfigContext");
|
|
486
|
-
return context;
|
|
487
|
-
}
|
|
488
|
-
function AiAssistanceConfigProvider(props) {
|
|
489
|
-
const [status, setStatus] = react.useState(), [error, setError] = react.useState(), apiClient = useApiClient(props.config?.__customApiClient), { getInstructStatus, loading: statusLoading } = useGetInstructStatus(apiClient), { initInstruct, loading: initLoading } = useInitInstruct(apiClient);
|
|
490
|
-
react.useEffect(() => {
|
|
491
|
-
getInstructStatus().then((s) => setStatus(s)).catch((e) => {
|
|
492
|
-
console.error(e), setError(e);
|
|
493
|
-
});
|
|
494
|
-
}, [getInstructStatus]);
|
|
495
|
-
const init = react.useCallback(async () => {
|
|
496
|
-
setError(void 0);
|
|
497
|
-
try {
|
|
498
|
-
await initInstruct();
|
|
499
|
-
const status2 = await getInstructStatus();
|
|
500
|
-
setStatus(status2);
|
|
501
|
-
} catch (e) {
|
|
502
|
-
console.error("Failed to init ai assistance", e), setError(e);
|
|
503
|
-
}
|
|
504
|
-
}, [initInstruct, getInstructStatus, setStatus]), { config, children } = props, context = react.useMemo(() => ({
|
|
505
|
-
config,
|
|
506
|
-
status,
|
|
507
|
-
statusLoading,
|
|
508
|
-
init,
|
|
509
|
-
initLoading,
|
|
510
|
-
error
|
|
511
|
-
}), [config, status, init, statusLoading, initLoading, error]);
|
|
512
|
-
return /* @__PURE__ */ jsxRuntime.jsx(AiAssistanceConfigContext.Provider, { value: context, children });
|
|
513
|
-
}
|
|
514
481
|
const hiddenTypes = [
|
|
515
482
|
"any",
|
|
516
483
|
"array",
|
|
@@ -633,6 +600,43 @@ function refToTypeNames(type) {
|
|
|
633
600
|
function removeUndef(obj) {
|
|
634
601
|
return Object.keys(obj).forEach((key) => obj[key] === void 0 ? delete obj[key] : {}), obj;
|
|
635
602
|
}
|
|
603
|
+
const AiAssistanceConfigContext = react.createContext({});
|
|
604
|
+
function useAiAssistanceConfig() {
|
|
605
|
+
const context = react.useContext(AiAssistanceConfigContext);
|
|
606
|
+
if (!context)
|
|
607
|
+
throw new Error("Missing AiAssistanceConfigContext");
|
|
608
|
+
return context;
|
|
609
|
+
}
|
|
610
|
+
function useSerializedTypes() {
|
|
611
|
+
return useAiAssistanceConfig().serializedTypes;
|
|
612
|
+
}
|
|
613
|
+
function AiAssistanceConfigProvider(props) {
|
|
614
|
+
const [status, setStatus] = react.useState(), [error, setError] = react.useState(), apiClient = useApiClient(props.config?.__customApiClient), { getInstructStatus, loading: statusLoading } = useGetInstructStatus(apiClient), { initInstruct, loading: initLoading } = useInitInstruct(apiClient), schema = sanity.useSchema(), serializedTypes = react.useMemo(() => serializeSchema(schema, { leanFormat: !0 }), [schema]);
|
|
615
|
+
react.useEffect(() => {
|
|
616
|
+
getInstructStatus().then((s) => setStatus(s)).catch((e) => {
|
|
617
|
+
console.error(e), setError(e);
|
|
618
|
+
});
|
|
619
|
+
}, [getInstructStatus]);
|
|
620
|
+
const init = react.useCallback(async () => {
|
|
621
|
+
setError(void 0);
|
|
622
|
+
try {
|
|
623
|
+
await initInstruct();
|
|
624
|
+
const status2 = await getInstructStatus();
|
|
625
|
+
setStatus(status2);
|
|
626
|
+
} catch (e) {
|
|
627
|
+
console.error("Failed to init ai assistance", e), setError(e);
|
|
628
|
+
}
|
|
629
|
+
}, [initInstruct, getInstructStatus, setStatus]), { config, children } = props, context = react.useMemo(() => ({
|
|
630
|
+
config,
|
|
631
|
+
status,
|
|
632
|
+
statusLoading,
|
|
633
|
+
init,
|
|
634
|
+
initLoading,
|
|
635
|
+
error,
|
|
636
|
+
serializedTypes
|
|
637
|
+
}), [config, status, init, statusLoading, initLoading, error, serializedTypes]);
|
|
638
|
+
return /* @__PURE__ */ jsxRuntime.jsx(AiAssistanceConfigContext.Provider, { value: context, children });
|
|
639
|
+
}
|
|
636
640
|
const basePath = "/assist/tasks/instruction", API_VERSION_WITH_EXTENDED_TYPES = "2025-04-01";
|
|
637
641
|
function canUseAssist(status) {
|
|
638
642
|
return status?.enabled && status.initialized && status.validToken;
|
|
@@ -645,7 +649,7 @@ function useApiClient(customApiClient) {
|
|
|
645
649
|
);
|
|
646
650
|
}
|
|
647
651
|
function useTranslate(apiClient) {
|
|
648
|
-
const [loading, setLoading] = react.useState(!1), user = sanity.useCurrentUser(),
|
|
652
|
+
const [loading, setLoading] = react.useState(!1), user = sanity.useCurrentUser(), types = useSerializedTypes(), toast = ui.useToast(), translate = react.useCallback(
|
|
649
653
|
({
|
|
650
654
|
documentId,
|
|
651
655
|
languagePath,
|
|
@@ -694,7 +698,7 @@ function useTranslate(apiClient) {
|
|
|
694
698
|
);
|
|
695
699
|
}
|
|
696
700
|
function useGenerateCaption(apiClient) {
|
|
697
|
-
const [loading, setLoading] = react.useState(!1), user = sanity.useCurrentUser(),
|
|
701
|
+
const [loading, setLoading] = react.useState(!1), user = sanity.useCurrentUser(), types = useSerializedTypes(), toast = ui.useToast(), generateCaption = react.useCallback(
|
|
698
702
|
({ path, documentId }) => (setLoading(!0), apiClient.request({
|
|
699
703
|
method: "POST",
|
|
700
704
|
url: `/assist/tasks/generate-caption/${apiClient.config().dataset}?projectId=${apiClient.config().projectId}`,
|
|
@@ -726,7 +730,7 @@ function useGenerateCaption(apiClient) {
|
|
|
726
730
|
);
|
|
727
731
|
}
|
|
728
732
|
function useGenerateImage(apiClient) {
|
|
729
|
-
const [loading, setLoading] = react.useState(!1), user = sanity.useCurrentUser(),
|
|
733
|
+
const [loading, setLoading] = react.useState(!1), user = sanity.useCurrentUser(), types = useSerializedTypes(), toast = ui.useToast(), generateImage = react.useCallback(
|
|
730
734
|
({ path, documentId }) => (setLoading(!0), apiClient.request({
|
|
731
735
|
method: "POST",
|
|
732
736
|
url: `/assist/tasks/generate-image/${apiClient.config().dataset}?projectId=${apiClient.config().projectId}`,
|
|
@@ -788,7 +792,7 @@ function useInitInstruct(apiClient) {
|
|
|
788
792
|
};
|
|
789
793
|
}
|
|
790
794
|
function useRunInstructionApi(apiClient) {
|
|
791
|
-
const toast = ui.useToast(), [loading, setLoading] = react.useState(!1), user = sanity.useCurrentUser(),
|
|
795
|
+
const toast = ui.useToast(), [loading, setLoading] = react.useState(!1), user = sanity.useCurrentUser(), types = useSerializedTypes(), {
|
|
792
796
|
config: { assist: assistConfig }
|
|
793
797
|
} = useAiAssistanceConfig(), runInstruction = react.useCallback(
|
|
794
798
|
(request) => {
|