StoryKit is a React toolkit that allows builders to integrate and interact with Story's Proof of Creativity protocol with prebuilt IP management components.
StoryKit is currently a GitHub Package so you will need repo access and a personal access token to use.
Also you will need Node.js 20+.
1 . Create a personal access token: github.com/settings/tokens.
2 . Create an .npmrc
file in the root of your project and add the following, replacing NPM_TOKEN
with your access token:
//npm.pkg.github.com/:_authToken=NPM_TOKEN
@storyprotocol/storykit:registry=https://npm.pkg.github.com
The first line authenticates you with the github package registry, the second line tells npm to use the Storykit package from the github registry.
3 . Add .npmrc
to your .gitignore
to keep your access token private.
4 . Install the package and the required dependencies:
npm install @storyprotocol/storykit @tanstack/react-query react-force-graph-2d
To use StoryKit’s API functionalities, you’ll need two types of API keys:
-
Story Protocol API Key: You can request an API key by completing this form.
-
SimpleHash API Key: You can generate an api token for free at simplehash.com.
Add these keys to your environment configuration:
NEXT_PUBLIC_STORY_PROTOCOL_X_API_KEY="YOUR_STORY_PROTOCOL_API_KEY_HERE"
NEXT_PUBLIC_SIMPLE_HASH_API_KEY="SIMPLEHASH_API_KEY_HERE"
To initialize StoryKit in your project, you’ll need to wrap your application in QueryProvider
and StoryKitProvider
.
we recommend doing this once in the root of the app.
// app/layout.tsx
import Providers from "./Providers";
export default function Layout({ children }) {
return (
<html>
<body>
<Providers>{children}</Providers>
</body>
</html>
);
}
// app/Providers.tsx
"use client";
import { QueryClientProvider, QueryClient } from "@tanstack/react-query";
import {
StoryKitProvider,
STORYKIT_SUPPORTED_CHAIN,
} from "@storyprotocol/storykit";
export default function Providers({ children }: { children: React.ReactNode }) {
const queryClient = new QueryClient();
return (
<QueryClientProvider client={queryClient}>
<StoryKitProvider chain={STORYKIT_SUPPORTED_CHAIN.STORY_TESTNET}>
{children}
</StoryKitProvider>
</QueryClientProvider>
);
}
The IpProvider
provides IP Asset data to child components.
"use client"
import { IpProvider, useIpContext } from "@storyprotocol/storykit"
const ExamplePage = () => {
return (
<IpProvider ipId={"0xbbf08a30b9ff0f717a024a75963d3196aaf0f0dd"}>
<ExampleComponent />
</IpProvider>
);
};
const ExampleComponent = () => {
const { nftData, isNftDataLoading } = useIpContext()
return (
<div>
{isNftDataLoading && <div>Fetching Asset...</div>}
{nftData && !isNftDataLoading ? (
<div>nft id: {nftData.nft_id}</div>
) : null}
</div>
);
};
Among the components that start with Ip
, all except IpWidget require the IpProvider to supply asset data. Check the Storybook of each component for detailed usage.
"use client";
import { IpProvider, IpGraph } from "@storyprotocol/storykit";
const ExamplePage = () => {
return (
<IpProvider ipId={"0xbbf08a30b9ff0f717a024a75963d3196aaf0f0dd"}>
<IpGraph />
</IpProvider>
);
};
Run Storybook locally for component development and documentation:
pnpm dev
Find the Storybook at http://localhost:6006
Run the example app.
pnpm build
pnpm example --filter @example/simple-setup
pnpm example --filter @example/custom-theme
The dev server will be running at http://localhost:3000
See the github repo and the example app.
- Build: pnpm run build
- Lint: pnpm run lint
- Format: pnpm run format
For guidelines on contributing to StoryKit, see the CONTRIBUTING.md file.