nut
nut copied to clipboard
🌰 A framework born for micro frontends
NUT Project
Features
- Flexible layout mechanism
- File-based router system
- Customizable layouts and themes
- Builtin markdown support
- System events
- Configuration management
- Convenient hot reload during development
- Plugin system
layout / theme HMR
data:image/s3,"s3://crabby-images/e88c7/e88c741ecfc9cf8858520c6f6094333597afcc9b" alt="hmr.gif"
markdown theme HMR
data:image/s3,"s3://crabby-images/537f4/537f44309b53889f607789f089f4b649377b49ad" alt="markdown-theme-hmr.gif"
System events
data:image/s3,"s3://crabby-images/7b208/7b2081023d5e8dcade3d41def6908bfb1bdf74bb" alt="system-events.jpg"
Route matching
data:image/s3,"s3://crabby-images/f2ae3/f2ae364f624306f3206d26fdf99141cac30ff80f" alt="route-match.jpg"
Builtin layouts
default
ocean | sakura |
---|---|
![]() |
![]() |
saber
ocean | sakura |
---|---|
![]() |
![]() |
now
data:image/s3,"s3://crabby-images/50ab3/50ab36f68a80aaa9cbff419faf4b443d301f9190" alt="now"
How to write a layout
...
How to write a plugin
A standard plugin looks like
export default {
name: 'your-superb-plugin',
// some special plugin need specify type,but you can ignore this in most cases
type: 'login',
apply( ctx = {}, options = {} ) {
const { api, events } = ctx
api.expose( 'method_name', () => {} )
api.expose( 'prop', 'value' )
events.on( 'system:before-startup', async ctx => {
await api.axios() // do some request
await events.pluginEmit( 'some-event', data ) // emit plugin event out
} )
}
}
You can expose some methods or props to application, or listen for system events, emit out some event in plugin
Using plugin
nut.config.js
module.exports = {
plugins: {
superb: {
package: 'your-superb-plugin',
enable: true,
}
}
}
superb is the name in current application
Use above plugin for example
// plugin exposed
ctx.use( 'superb', 'method_name' )
ctx.use( 'superb', 'prop' )
// plugin events
ctx.events.on( 'plugin:superb:some-event', async data => {} )
Get started
yarn global add @nut-project/cli
nut # develop locally
nut --prod # build for production