@evmts/plugin-webpack
TypeScript icon, indicating that this package has built-in type declarations

0.0.1 • Public • Published

@evmts/plugin-webpack

A webpack plugin for importing solidity files.

Instalation

pnpm i @evmts/plugin-webpack

Webpack usage

Install webpack plugin

npm i @evmts/plugin-webpack

Add to your webpack config

import { EvmTsPlugin } from '@evmts/plugin-webpack`
import { defineConfig } from 'vite'

export default defineConfig({
  plugins: [
    new EvmTsPlugin()
  ]
})

NEXT.js Usage

To use in next add to next.config.js

import { EvmTsPlugin } from "@evmts/webpackPlugin";

/** @type {import('next').NextConfig} */
const nextConfig = {
  webpack: (
    config,
    { buildId, dev, isServer, defaultLoaders, nextRuntime, webpack }
  ) => {
    config.plugins.push(new EvmTsPlugin({}));
    return config;
  },
};

module.exports = nextConfig;

How it works

Under the hood this plugin will transform solidity imports

When the plugin sees a solidity import it will make the following changes

  1. Update the import to import a .ts file
- import scripts from './MyScript.sol'
+ import scripts from './MyScript.sol.ts'

Insert a new typescript file MyScript.sol.ts as an artifact

// MyScript.sol.ts
export default {
  name,
  artifactPath,
  contractPath,
  address,
  abi,
  bytecode,
};

The typescript can then go ahead and use the artifacts however it pleases

Usage in @evmts/core

See full evms-core for how it's used in evmts. This plugin can be used in other repos as well.

Usage in other libraries

Currently only @evmts/core is using this but this could easily be adapted or extended for other libraries.

Autocompletion and Typesafety

For typesafety and autocompletion in your editor add @evmts/ts-plugin to your tsconfig.json.

Custom Ts plugins are for developer experience only

The typescript compiler does not use custom ts plugins at compile time only in your editor. You will get red squiggly lines telling you something is wrong but it will still compile.

Other plugins

See plugin-rollup if using vitest, vite, or rollup

Package Sidebar

Install

npm i @evmts/plugin-webpack

Weekly Downloads

0

Version

0.0.1

License

MIT

Unpacked Size

309 kB

Total Files

5

Last publish

Collaborators

  • fucory