... rollup's best friend for bundling Venin
Do a
npm install --save-dev @buidlerlabs/rollup-plugin-hashgraph-venin
then, in your rollup.config.json
or any other Rollup config option of preference, do
import venin from "@buidlerlabs/rollup-plugin-hashgraph-venin";
//...
export default {
//...
plugins: [
venin(),
//...
]
//...
}
That's it! 🍾 Now you can bundle your dApp and have Venin embedded in it, ready to be used. 🥂
You can configure the plugin by passing in an object with the following properties and meaning:
Prop | Description |
---|---|
contracts.path |
Where to load the solidity contracts from |
contracts.recurse |
true to deep load all the inner directory's contracts from contracts.path , false to only load the provided top directory |
environment |
The environment object passed to Venin to be used when creating ApiSession.default instances |
includeCompiler |
true to embed a web-worker that will allow in-browser compilation (note: the solidity compiler is lazy loaded the first time a Contract.newFrom /Contract.allFrom is called) and false if you don't intend to use this feature (conserves bandwidth) |
sourceMap |
true to include the source-map (helpful for debugging), false otherwise |
Embedding the plugin with no such object is equivalent to virtually calling:
venin({
contracts: {
path: './contracts',
recurse: false
},
environment: process.env,
includeCompiler: false,
sourceMap: false
})
For an immediate working example, have a look at our bundler recipe used by our test-base.
Need more context and configurability? Check our official docs page for more info.
Have the .env
file ready (see above) and run
$ npm test
... are more then welcome! Head over to our issues page and let us know your thoughts or, better yet, open that PR and lets discuss it there!
Oh! And if you ever feel like talking to us, you can reach us on discord. We're very friendly! 👨👩👧👦
This work has been published under the MIT License.