npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

xchange-create

v0.0.4

Published

Create Xchange Project

Downloads

9

Readme

Requirements

Before you begin, you need to install the following tools:

Quickstart

To get started with Xchange Create, follow the steps below:

  1. Install from NPM Registry and follow the CLI instructions.
npx xchange-create@latest

💬 Hint: If you choose Foundry as solidity framework in the CLI, you'll also need Foundryup installed in your machine. Checkout: getfoundry.sh

  1. Run a local network in the first terminal:
pnpm run chain

This command starts a local Ethereum network using Hardhat or Foundry, depending on which one you selected in the CLI. The network runs on your local machine and can be used for testing and development. You can customize the network configuration in:

  • packages/hardhat/hardhat.config.ts if you have Hardhat as solidity framework.
  • packages/foundry/foundry.toml if you have Foundry as solidity framework.
  1. On a second terminal, deploy the test contract:
pnpm run task deploy:all

This command deploys a test smart contract to the local network. The contract can be modified to suit your needs. Is located in:

  • Hardhat => packages/hardhat/contracts
  • Foundry => packages/foundry/contracts

The pnpm run deploy command uses a deploy script to deploy the contract to the network. You can customize it. Is located in:

  • Hardhat => packages/hardhat/deploy
  • Foundry => packages/foundry/script
  1. On a third terminal, start your NextJS app:
pnpm run start

Visit your app on: http://localhost:3000. You can interact with your smart contract using the Debug Contracts page. You can tweak the app config in packages/nextjs/xchange.config.ts.

Run smart contract test with pnpm run hardhat:test or pnpm run foundry:test depending of your solidity framework.

What's next:

  • Edit your smart contract TestContract.sol in packages/hardhat/contracts
  • Edit your frontend homepage at packages/nextjs/app/page.tsx. For guidance on routing and configuring pages/layouts checkout the Next.js documentation.
  • Edit your deployment scripts in packages/hardhat/deploy
  • Edit your smart contract test in: packages/hardhat/test. To run test use pnpm run hardhat:test
# fastest way to deploy a loan locally
pnpm install && pnpm run generate

# separate shell
pnpm run chain

# deploy all
pnpm run task deploy:all

# nextjs run front-end
pnpm run next:format && pnpm run next:check-types && pnpm run next:lint && pnpm run next:build && pnpm run start