Go to file
Fernando Falci a39c2a1d79
Revert "chore: font face inter"
This reverts commit add7a7dc8d.
2024-04-25 12:44:56 +02:00
.github/workflows chore(ci): publish to GH Pages 2024-04-22 16:01:27 +02:00
public chore: base website 2024-04-18 11:49:31 +02:00
src refactor: move CustomAvatar to components 2024-04-24 15:14:41 +02:00
.eslintrc.cjs chore: base website 2024-04-18 11:49:31 +02:00
.gitignore chore: base website 2024-04-18 11:49:31 +02:00
CNAME Create CNAME 2024-04-16 10:48:39 -07:00
index.html Revert "chore: font face inter" 2024-04-25 12:44:56 +02:00
LICENSE Initial commit 2024-04-16 10:48:14 -07:00
package.json Revert "chore: font face inter" 2024-04-25 12:44:56 +02:00
postcss.config.js chore: base website 2024-04-18 11:49:31 +02:00
README.md chore: custom connect button 2024-04-23 14:56:10 +02:00
tailwind.config.js Revert "chore: font face inter" 2024-04-25 12:44:56 +02:00
vite.config.js chore: base website 2024-04-18 11:49:31 +02:00
yarn.lock Revert "chore: font face inter" 2024-04-25 12:44:56 +02:00

Wallet.id

This is a white label template for hns.id. You can fork and modify to be used with any staked TLD

Customization

Basic customization are in the constants.js file and the src/assets folder, more specifically avatar.png and brand.png, as well as public/favicon.svg.

For more advanced customization, any component can be updated.

Contracts

The contracts addresses are also in the constants.js file. First is the testnet (Optimism Sepolia), and second the mainnet (Optimism).

Data

This project can be deployed as static website. All the data needed comes from smart contracts.

Handling the communication with the contracts can be done with a few React hooks:

useDomainStatus()

const { data } = useDomainStatus({ label: 'my-sld' });

/* Returns:
{
  "isAvailable": true,
  "labelValid": true,
  "publicRegistrationOpen": false,
  "isPremium": false,
  "priceInDollars": "5.00",
  "priceInWei": "2500000000000000",
  "label": "my-sld"
}
/*

useRegister()

const register = useRegister({
  label: 'my-sld',
  priceInWei: '2500000000000000',
});

<button onClick={register}>🤝</button>;

register is an async function that will invoke Metamask (or any other wallet the user choose) and will be resolved once the user signs the transaction.

Tip: you can connect both hooks:

const { data } = useDomainStatus({ label: 'my-sld' });
const register = useRegister(data);

usePrimaryName()

const { name, avatar } = usePrimaryName();

Both can be empty/null if the user hasn't defined a primary name a name yet.

Running locally

It uses yarn, so...

yarn install
yarn dev

... should do the magic.

GitHub Pages

As mentioned about, this project can be deployed as a static webpage, with no need for a backend like NodeJS or even Vercel, making it a great fit for GitHub pages.

After forking the project, enable Pages in the repository settings and update the CNAME file.