Admin panel for FounderLab apps
This module will auto generate a full admin site to manage a backend based on Frameworkstein models. You provide the models you want to manage for and it will generate routes and form pages for them.
Screenshots
Homepage
data:image/s3,"s3://crabby-images/f00c7/f00c7de78d8749906027347b3c9e32614a91830f" alt="Select a model type to edit its data."
Model list
data:image/s3,"s3://crabby-images/31059/31059f2d0353a140fdeaaca69aba53e06b027242" alt="Fields can be configured to display and edit on the list page."
Model detail
data:image/s3,"s3://crabby-images/c4b28/c4b288a78e49d5dc68f2b645083ce66d60697e34" alt="Fields can have their inputs configured for the detail page."
How it works
You call configureAdmin
and configure the admin with a list of models. It examines each models fields via its schema and generates form fields to edit them. You can pass in some options to control how these form fields are rendered.
Example
import configureAdmin from 'fl-admin'
import StaticPage from './models/StaticPage'
import User from './models/User'
configureAdmin({
models: [
{
Model: User,
display: model => model.email,
fields: {
email: {
listDisplay: true,
},
admin: {
listDisplay: true,
},
},
},
{
Model: Post,
fields: {
title: {
listEdit: true,
},
content: {
input: 'textarea',
},
},
},
],
})
Configuration
There are model-level and field-level configuration options. Models given to configuration functions are plain javascript objects (not instances of the model class).
Model configuration options
Values below are the defaults.
{
Model: null,
display: model.name || model.title,
name: Model.modelName || Model.model_name || Model.name,
sort: 'id',
perPage: 50,
listDelete: false,
rootPath: options.rootPath,
path: table(Model),
plural: plural(Model),
actionType: `${ACTION_PREFIX}${upper(Model)}`,
readOnlyFields: ['createdDate'],
ListComponent,
CreateComponent,
DetailComponent,
}
Field configuration options
Values below are the defaults.
{
label: label(key),
InputComponent: SmartInput,
input: 'text',
listDisplay: false,
listEdit: false,
readOnly: false,
hidden: false,
}