Loading...
Loading...
Compare original and translation side by side
"@icp-sdk/auth": "^7.1.0"
"@icp-sdk/core": "^5.3.0""@icp-sdk/auth": "^7.1.0"
"@icp-sdk/core": "^5.3.0"@caffeineai/core-infrastructure@caffeineai/core-infrastructureInternetIdentityProviderQueryClientProviderimport { InternetIdentityProvider } from "@caffeineai/core-infrastructure";
import { QueryClient, QueryClientProvider } from "@tanstack/react-query";
import ReactDOM from "react-dom/client";
import App from "./App";
const queryClient = new QueryClient();
ReactDOM.createRoot(document.getElementById("root")!).render(
<QueryClientProvider client={queryClient}>
<InternetIdentityProvider>
<App />
</InternetIdentityProvider>
</QueryClientProvider>,
);InternetIdentityProviderQueryClientProviderimport { InternetIdentityProvider } from "@caffeineai/core-infrastructure";
import { QueryClient, QueryClientProvider } from "@tanstack/react-query";
import ReactDOM from "react-dom/client";
import App from "./App";
const queryClient = new QueryClient();
ReactDOM.createRoot(document.getElementById("root")!).render(
<QueryClientProvider client={queryClient}>
<InternetIdentityProvider>
<App />
</InternetIdentityProvider>
</QueryClientProvider>,
);useInternetIdentity()useInternetIdentity()| Field | Type | Description |
|---|---|---|
| | The user's identity (available after login or session restore) |
| | Opens the II popup. Fire-and-forget — do not |
| | Logs out and clears stored identity. Fire-and-forget. |
| | |
| | |
| | |
| | |
| | |
| | The error object when |
| 字段 | 类型 | 描述 |
|---|---|---|
| | 用户身份(登录或会话恢复后可用) |
| | 打开II弹窗。无需等待,直接调用即可。 |
| | 登出并清除存储的身份信息。无需等待,直接调用即可。 |
| | 用户拥有有效身份时为 |
| | |
| | II弹窗打开时为 |
| | 仅在交互式登录完成后为 |
| | 登录或初始化失败时为 |
| | |
| Scenario | | |
|---|---|---|
| Page load, no stored session | | |
| Restoring stored session | | |
| Stored session restored after reload | | |
| Interactive login in progress | | |
| Interactive login just completed | | |
| Login popup failed / cancelled | | |
isLoginSuccesstrueisAuthenticated| 场景 | | |
|---|---|---|
| 页面加载,无存储会话 | | |
| 恢复存储会话中 | | |
| 页面重载后恢复存储会话 | | |
| 交互式登录进行中 | | |
| 交互式登录刚完成 | | |
| 登录弹窗失败/取消 | | |
isLoginSuccesstruetrueisAuthenticatedisAuthenticatedconst { isAuthenticated } = useInternetIdentity();
{isAuthenticated ? <AuthenticatedApp /> : <LoginScreen />}const { login, isInitializing, isLoggingIn } = useInternetIdentity();
<button onClick={() => login()} disabled={isInitializing || isLoggingIn}>
Sign in
</button>login()clear()isLoggingInisInitializinguseStateisPendingisAuthenticatedconst { isAuthenticated } = useInternetIdentity();
{isAuthenticated ? <AuthenticatedApp /> : <LoginScreen />}const { login, isInitializing, isLoggingIn } = useInternetIdentity();
<button onClick={() => login()} disabled={isInitializing || isLoggingIn}>
登录
</button>login()clear()isLoggingInisInitializinguseStateisPendinguseActor()useActor()import { useActor } from "@caffeineai/core-infrastructure";
import { createActor } from "declarations/backend";
function MyComponent() {
const { actor, isFetching } = useActor(createActor);
// actor is null while loading, then the typed backend actor
if (!actor || isFetching) return <Loading />;
// Call backend methods directly
const data = await actor.myBackendMethod();
}import { useActor } from "@caffeineai/core-infrastructure";
import { createActor } from "declarations/backend";
function MyComponent() {
const { actor, isFetching } = useActor(createActor);
// 加载时actor为null,之后变为类型化的后端角色
if (!actor || isFetching) return <Loading />;
// 直接调用后端方法
const data = await actor.myBackendMethod();
}| Field | Type | Description |
|---|---|---|
| | The typed backend actor, or |
| | |
| 字段 | 类型 | 描述 |
|---|---|---|
| | 类型化的后端角色,加载时为 |
| | 创建角色实例时为 |