This is a simple website template for getting NFT information directly from chain. It uses wallet (like metamask) to assure NFT connection.
If you have no experience with git and would still like to use our template file to enable your freshly deployed NFT collection, feel free to click the green button "Code" on the upper right corner of this website and then selecting "Download ZIP". Once downloaded, the zip file includes all files you need to display your NFT collection. Before that happens you need to configure the file, as explained in Configure section.
- Fork the repo
- Configure config/production.ts
- Make changes to the website (optional)
- Deploy files to Apillon hosting
Before the template can interact with the Smart Contract you have deployed via UI, it needs to be manually configured.
To configure the template, do the following:
- Open the template folder "config"
- Locate production.ts file within the config folder
- Open the production.ts file in code editor
- Change the first line by entering your smart contract address between parenthesis
- Select the chain version by commenting and uncommenting the right chain
Example:
CONTRACT_ADDRESS = ""; // Paste the address of the NFT collection between the parenthesis
// uncomment the chain you are using by deleting the slashes
// CHAIN_ID = "0x507"; // Moonbase
// CHAIN_ID = "0x504"; // Moonbeam
// CHAIN_ID = "0x250"; // Astar
Once you have updated the config/${env}.ts file, save it. Now the website files are ready to be deployed.
Before uploading the website to Apillon hosting, feel free to edit the code, add any customization or just review whether everything works as expected.
To preview the website on your computer you need to serve a http server from the root folder of the website. For example, you can run node package http-server from root folder like this:
npm install
npm run dev
To deploy the website on Apillon hosting you need to build project with a command below:
npm run generate
And then deploy folder dist according to this documentation: Wiki
- If not already, register to Apillon.io
- Log in to Apillon console and create new Hosting bucket inside your project.
- Select all files of your website (as configured in the previous step) and use drag&drop action to pull the files into the Hosting bucket
- Once the files are uploaded, push them to Staging and finally to the Production
- Add your custom domain (as displayed in the dashboards UI)
- Review your newly deployed website
To deploy your NFT website to Apillon Hosting you should:
- Clone this repository and configure it to your needs.
- If not already, register to Apillon.io
- Log in to Apillon console and create new Hosting bucket inside your project.
- In settings, create an API KEY with storage permissions. Write down API key and API secret.
- In your github repository setup actions secrets (variables)
- WEBSITE_UUID : copy UUID from hosting bucket on Apillon dashboard
- APILLON_API_KEY : your previously created API key
- APILLON_API_SECRET : your previously created API secret
Now everything should be ready. When you will push to master branch, your website should start deploy to Apillon IPFS hosting. Monitor progress on Apillon.io dashboard. After some time you'll be able to get IPNS url and also setup your own domain.
You can change behavior of the automatic deployment by editing /.github/workflows/deploy.yml.