Admin Panel for Nuxt.js sites
- Configurable hierarchical menu
- Data lists for content management
- Easy configurable forms
- Block editor
- Inline editor
- Nuxt.js :-)
- Vuex store
npm i @getsedona/nuxt-admin-module
- Register module in
nuxt.config.js
modules: ['@getsedona/nuxt-admin-module'],
-
Confire a menu
-
Add auth system. E.g. nuxt-auth
-
Add login method in component
methods: {
async login() {
// add here a method for login
// load dependencies for admin panel (vuex modules, ui components and other)
await this.$adminLoader.load();
},
async logOut() {
// add here a method for logout
// unregister vuex modules
await this.$adminLoader.unload();
},
},
- Add plugin and add check auth and login in plugin
~plugins/admin.client.js
export default async function(context) {
await context.$adminLoader.load();
}
Main toolbar has two default buttons: Home button and Hide button. Their can be hiding via an admin config.
Example:
{
"showHome": true,
"showHide": false,
}
There are adding custom buttons to panel.
Example:
"buttons": [
{
"title": "SEO",
"icon": "folder",
"component": "components/post-seo"
}
]
There are adding title after Home button and custom buttons.
Example:
"toolbar": {
"title": "Admin Panel"
},
Default config for toolbar:
"toolbar": {
"showHome": true,
"showHide": false,
"buttons": []
},
Is used global event bus this.$admin
this.$admin.$emit('admin:view-change', MenuItem | string)
– change view. Provide menu item object or menu id
~/components/blocks
– directory for blocks. Subdirectories not supported yet
A block is a vue component (vue or js file).
- Create vue component in the blocks folder
- Add
blockMixin
to block (required) - Add export const
meta
object. Is used for admin panel (optional) – see interfaceBlockMeta