Skip to content

Commit

Permalink
docs: use basename (#1174)
Browse files Browse the repository at this point in the history
  • Loading branch information
Zizzamia authored Aug 28, 2024
1 parent 1c73305 commit 8372d07
Show file tree
Hide file tree
Showing 14 changed files with 274 additions and 71 deletions.
2 changes: 1 addition & 1 deletion playground/nextjs-app-router/components/demo/Identity.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ export default function IdentityDemo() {
ensName: 'zizzamia.eth',
});
const { data: avatarBasename } = useAvatar({
ensName: 'zizzamia.eth',
ensName: 'zizzamia.base.eth',
chain: base,
});
const { data: name } = useName({ address: demoAddress });
Expand Down
2 changes: 1 addition & 1 deletion site/docs/pages/guides/contribution.mdx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
title: OnchainKit Contribution Guide
title: Contribution Guide · OnchainKit
description: Learn how to contribute to OnchainKit
---

Expand Down
2 changes: 1 addition & 1 deletion site/docs/pages/guides/reporting-bug.mdx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
title: Reporting a bug
title: Reporting a bug · OnchainKit
description: Help us make OnchainKit better
---

Expand Down
2 changes: 1 addition & 1 deletion site/docs/pages/guides/tailwind.mdx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
title: Tailwindcss Integration Guide
title: Tailwindcss Integration Guide · OnchainKit
description: Learn how to integrate tailwindcss with OnchainKit
---

Expand Down
99 changes: 99 additions & 0 deletions site/docs/pages/guides/use-basename-in-onchain-app.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
---
title: Use Basename · OnchainKit
description: Integrate Basenames into your onchain app, in just a few steps.
---
import { Avatar, Name } from '@coinbase/onchainkit/identity';
import App from '../../components/App';
import { base } from 'viem/chains';

# Use Basename

Basenames are an essential onchain building block that empowers builders to establish their identity on Base by registering human-readable names for their wallet addresses.

They operate entirely onchain, utilizing the same technology as ENS names, and are deployed on Base.

You can integrate [Basenames](https://www.base.org/names) into your app with few these steps.

::::steps

### New to OnchainKit?

Follow the [Getting Started](/getting-started) guide to install the package.

### Already using OnchainKit?

Update to the latest version and choose from the following steps: a React component approach, a React hook, or a pure TypeScript utility function.

::::

## React components with `<Avatar>` and `<Name>`

Use the [`<Avatar>`](/identity/avatar) and [`<Name>`](/identity/name) components to display Basenames associated with Ethereum addresses.

The `chain` prop is optional and setting to Base, it's what makes the components switch from ENS to Basenames.

```tsx
import { Name } from '@coinbase/onchainkit/identity';
import { base } from 'viem/chains';

const address = '0x02feeb0AdE57b6adEEdE5A4EEea6Cf8c21BeB6B1';

// omitted component code for brevity
<Avatar address={address} chain={base} />
<Name address={address} chain={base} />
```

<App>
<Avatar address="0x02feeb0AdE57b6adEEdE5A4EEea6Cf8c21BeB6B1" chain={base}/>
<Name address="0x02feeb0AdE57b6adEEdE5A4EEea6Cf8c21BeB6B1" chain={base}/>
</App>

## React hooks with `useAvatar` and `useName`

Use the [`useAvatar`](/identity/use-avatar) and [`useName`](/identity/use-name) hooks to get Basenames associated with Ethereum addresses.

The hooks are incredibly useful for building custom components while leveraging OnchainKit for efficient data fetching.

:::code-group

```tsx [code]
import { useAvatar, useName } from '@coinbase/onchainkit/identity';
import { base } from 'viem/chains';

const address = '0x02feeb0AdE57b6adEEdE5A4EEea6Cf8c21BeB6B1';
const basename = 'zizzamia.base.eth';
const { data: avatar, isLoading } = await useAvatar({ ensName: basename, chain: base });
const { data: name, isLoading } = await useName({ address, chain: base });
```

```ts [return value]
{ data: '', isLoading: false }
{ data: 'zizzamia.base.eth', isLoading: false }
```

:::

## Typescript utility with `getAvatar` and `getName`

Use the [`getAvatar`](/identity/get-name) and [`getName`](/identity/get-name) functions to get Basenames associated with Ethereum addresses.

Being pure functions, it seamlessly integrates into any TypeScript project, including Vue, Angular, Svelte, or Node.js.

:::code-group

```tsx [code]
import { getName } from '@coinbase/onchainkit/identity';
import { base } from 'viem/chains';

const address = '0x02feeb0AdE57b6adEEdE5A4EEea6Cf8c21BeB6B1';
const basename = 'zizzamia.base.eth';
const avatar = await getAvatar({ ensName: basename, chain: base });
const name = await getName({ address, chain: base });
```

```ts [return value]

zizzamia.base.eth;
```

:::
45 changes: 45 additions & 0 deletions site/docs/pages/identity/get-address.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
# `getAddress`

The `getAddress` utility is designed to retrieve an address from an onchain identity provider for a given name.

## Usage

Get ENS Name from mainnet chain

:::code-group
```tsx [code]
import { getAddress } from '@coinbase/onchainkit/identity';

const address = await getAddress({ name: 'zizzamia.eth' });
```

```ts [return value]
0x02feeb0AdE57b6adEEdE5A4EEea6Cf8c21BeB6B1
```

:::

Get Basename from base chain

:::code-group

```tsx [code]
import { getAddress } from '@coinbase/onchainkit/identity';
import { base } from 'viem/chains';

const address = await getAddress({ name: 'zizzamia.base.eth', chain: base });
```

```ts [return value]
0x02feeb0AdE57b6adEEdE5A4EEea6Cf8c21BeB6B1
```

:::

## Returns

[`Promise<GetAddressReturnType>`](/identity/types#getaddressreturntype)

## Parameters

[`GetAddress`](/identity/types#getaddress)
6 changes: 0 additions & 6 deletions site/docs/pages/identity/get-name.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,6 @@ provider for a specific address.
Consider the utility instead of the hook when you
use it with Next.js or any Node.js backend.

Supported providers:

- [Basenames](https://www.base.org/names)
- ENS

## Usage

Get ENS name from an address:
Expand Down Expand Up @@ -46,7 +41,6 @@ const name = await getName({ address, chain: base });
zizzamia.base.eth;
```


:::

Get a sliced address when address does not have an ENS name:
Expand Down
17 changes: 12 additions & 5 deletions site/docs/pages/identity/name.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Badge, Name, Identity, } from '@coinbase/onchainkit/identity';
import { Badge, Name, Identity } from '@coinbase/onchainkit/identity';
import App from '../../components/App';
import { base } from 'viem/chains';

Expand All @@ -12,7 +12,9 @@ Address with an ENS:

```tsx
import { Name } from '@coinbase/onchainkit/identity';
<Name address="0x02feeb0AdE57b6adEEdE5A4EEea6Cf8c21BeB6B1" /> // [!code focus]

const address = '0x02feeb0AdE57b6adEEdE5A4EEea6Cf8c21BeB6B1';
<Name address={address} /> // [!code focus]
```

<App>
Expand All @@ -24,7 +26,9 @@ Address with a Basename:
```tsx
import { Name } from '@coinbase/onchainkit/identity';
import { base } from 'viem/chains'; // [!code focus]
<Name address="0x02feeb0AdE57b6adEEdE5A4EEea6Cf8c21BeB6B1" chain={base} /> // [!code focus]

const address = '0x02feeb0AdE57b6adEEdE5A4EEea6Cf8c21BeB6B1';
<Name address={address} chain={base} /> // [!code focus]
```

<App>
Expand All @@ -37,9 +41,11 @@ You can override component styles using `className`.

```tsx
import { Name } from '@coinbase/onchainkit/identity';

const address = '0x02feeb0AdE57b6adEEdE5A4EEea6Cf8c21BeB6B1';
<Name
address={address}
className="bg-emerald-400 px-2 py-1 rounded"// [!code focus]
address="0x02feeb0AdE57b6adEEdE5A4EEea6Cf8c21BeB6B1"
/>
```

Expand All @@ -56,9 +62,10 @@ Use [`OnchainKitProvider`](/config/onchainkit-provider) or [`Identity`](/identit
```tsx
import { Badge, Name, Identity } from '@coinbase/onchainkit/identity'; // [!code focus]

const address = '0x838aD0EAE54F99F1926dA7C3b6bFbF617389B4D9';
<Identity
address={address}
schemaId="0xf8b05c79f090979bf4a80270aba232dff11a10d9ca55c4f88de95317970f0de9" // [!code focus]
address="0x838aD0EAE54F99F1926dA7C3b6bFbF617389B4D9"
>
<Name> // [!code focus]
<Badge /> // [!code focus]
Expand Down
40 changes: 28 additions & 12 deletions site/docs/pages/identity/types.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,9 @@ description: Glossary of Types in Identity components & utilities.

```ts
type AddressReact = {
address?: Address | null; // The Ethereum address to render
address?: Address | null; // The Ethereum address to render.
className?: string; // Optional className override for top span element.
isSliced?: boolean; // Determines if the displayed address should be sliced.
};
```

Expand Down Expand Up @@ -94,6 +95,21 @@ type EthBalanceReact = {
};
```

## `GetAddress`

```ts
type GetAddress = {
name: string | Basename;
chain?: Chain;
};
```

## `GetAddressReturnType`

```ts
type GetAddressReturnType = Address | null;
```

## `GetAttestationsOptions`

```ts
Expand Down Expand Up @@ -168,6 +184,15 @@ type NameReact = {
} & HTMLAttributes<HTMLSpanElement>; // Optional additional span attributes to apply to the name.
```

## `UseAddressOptions`

```ts
type UseAddressOptions = {
name: string | Basename; // The ENS or Basename for which the Ethereum address is to be fetched
chain?: Chain; // Optional chain for domain resolution
};
```

## `UseAvatarOptions`

```ts
Expand All @@ -177,10 +202,10 @@ type UseAvatarOptions = {
};
```

## `UseAvatarQueryOptions`
## `UseQueryOptions`

```ts
type UseAvatarQueryOptions = {
type UseQueryOptions = {
enabled?: boolean;
cacheTime?: number;
};
Expand All @@ -194,12 +219,3 @@ type UseNameOptions = {
chain?: Chain; // Optional chain for domain resolution
};
```

## `UseNameQueryOptions`

```ts
type UseNameQueryOptions = {
enabled?: boolean; // Whether the query should be enabled. Defaults to true.
cacheTime?: number; // Cache time in milliseconds.
};
```
20 changes: 20 additions & 0 deletions site/docs/pages/identity/use-address.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
# `useAddress`

The `useAddress` hook is used to get an address from an onchain identity provider for a given name.

## Usage

```tsx
import { useAddress } from '@coinbase/onchainkit/identity';

const { data: address, isLoading } = useAddress({ name: 'zizzamia.base.eth' });
```

## Returns

[`useQuery<Promise<GetAddressReturnType>>`](/identity/types#getaddressreturntype)

## Parameters

[`UseAddressOptions`](/identity/types#useaddressoptions)
[`UseQueryOptions`](/identity/types#usequeryoptions)
19 changes: 5 additions & 14 deletions site/docs/pages/identity/use-avatar.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,6 @@
The `useAvatar` hook is used to get avatar image url from an onchain identity
provider for a given name.

Supported providers:

- ENS

## Usage

```tsx
Expand All @@ -17,14 +13,9 @@ const { data: avatar, isLoading } = useAvatar({ ensName: 'vitalik.eth' });

## Returns

```ts
type UseAvatarOptions = {
ensName: string;
chain?: Chain;
};
[`useQuery<Promise<GetAddressReturnType>>`](/identity/types#getaddressreturntype)

type UseAvatarQueryOptions = {
enabled?: boolean;
cacheTime?: number;
};
```
## Parameters

[`UseAvatarOptions`](/identity/types#useavataroptions)
[`UseQueryOptions`](/identity/types#usequeryoptions)
Loading

0 comments on commit 8372d07

Please sign in to comment.