The project is a node application that takes json schema as input and generate a MERN CRUD Application as output. The generated application contains React crud app, Node crud app with Express Api's and corresponding database in mongodb. The purpose of creating the project is
- To save developers time generating all the four CRUD functionalities for each Entity.
- Generate relations between these entities if there are any.
- To provide React, Node and Express developers with an easy to read and update code following good conventions.
- The MERN CRUD Generator Generates a basic CRUD application, if you have some custom requirements for your generated app or you want us to update or generate your application you can Contact us.
To generate your MERN CRUD App the only thing you need is a json schema file in a specific format, a sample schema which uses all the features of MERN CRUD Generator is attached at the bottom of the page here Sample Schema File, you just need to run this command.
npx mern-crud-generator
This command shows a list of options asking for the kind of project you want to generate each of these is explained here What Projects can be generated, you just need to run this command. Once you have generated your project the only thing you need is navigate to both React and Node project and run the following command,
npm install
This command will connect to npm and install the required dependency packages, once the packages are installed run the following command to start your application.
npm start
Or Just watch this short video to quickly generate your first CRUD app here, Quickest way to use MERN CRUD Generator.
- User can generate a complete MERN CRUD application.This option generate two projects.
- React Project which contains create, update Forms and a List page having View and delete functionality for each entity. The Project also constains login, signUp and update user information form. check out React Project Features for details.
- Node project which contains the database models,Express API endpoints for each entity and also creates the database in MongoDB check out Node Project Features for details.
- User can generate only the Node/Express api CRUD, In this case only node project is generated.
- Node project which contains the database models,Express API endpoints for each entity and also creates the database in MongoDB check out Node Project Features for details.
- User can generate an empty MERN Application,This option don,t require schema from user and generate two projects.
- React Project haiving an empty Component along with login, signUp and update user information form.
- Node project which in this case contains only "User" database model and its Express API endpoints and a database in MongoDB.
To successfully generate a MERN CRUD Application the only thing you need is to create a JSON file having the following set of properties. Every thing you need to know about these properties is defined in following table and also an image is below for ease.
property name | type | info | default value | |
---|---|---|---|---|
appName | string | Its value will be used as the name of application generated. | optional | sampleApp |
appTheme | enum | Its value is used to decide the theme of the generated React application. | optional | defaultLight |
Its value can be dark , defaultLight , electricBlue . |
||||
appDbName | string | Its value will be used as the name of the database created for generated project. | optional | sampleDB |
If its not passed but appName is passed then DB name will also be its value. |
||||
appSchema | object | It has two arrays representing the app to generate tables ,relations . |
required | |
tables | array | It contains a collection of objects each representing an entity. | required | |
Each contains two properties name and columns representing its structure. |
||||
name | string | Its value will be the name of the entity but there is a restrication that, | required | |
the first letter of the string should be capital. | ||||
columns | array | It contains a collection of objects each representing a property of an entity. | required | |
It has three properties name , type and required . |
||||
name | string | It is the name property of columns array the first one was name for the entity. | required | |
Its value will be used as name of the specific property of entity. | ||||
type | enum | Its value will be used as the type of the specific property of entity. | required | |
Its value can be either text ,number ,email ,password ,date . |
||||
required | boolean | Its value will be used to tell either the specific property of entity is required | optional | false |
Its value can be either true ,false . |
||||
relations | array | It contains a collection of objects each representing a relation b/w two entities | optional | |
It has four properties, | ||||
firstTable , secondTable , relationType , secondTableColumn . |
||||
firstTable | string | Its value should be same as name of any entity we defined in tables property |
required | |
secondTable | string | Its value should be same as name of any entity we defined in tables property |
required | |
or it can also be User which is a builtin entity that is automatically created. |
||||
so relation will be created b/w entities mentioned in firstTable and secondTable. | ||||
relationType | enum | Its value will be used to tell the type of the relation b/w the two entities, | required | |
we defined in firstTable and secondTable . Its value can be either |
||||
select , radio , checkBox ,multiselect ,oneToMany ,manyToMany . |
||||
for details regarding each type checkout Realtions Supported. | ||||
secondTableColumn | string | Its value should be same as name property value from columns array of the |
required | |
respective entity mentioned in secondTable , Where its used?. |
A complete structure and properties the schema needs is also explained here for quick understanding.
A realtion b/w two entities is created using 4 properties firstTable
, secondTable
, relationType
, secondTableColumn
, to understand how a relation is created lets take an example say we have two entities product
and category
and we want to create a relation of type select
between them.
- The
product
has two propertiesprodName
andprice
. - The
category
has two propertiescatName
andtype
. If a relation object has these valuesfirstTable
="product",secondTable
="category",relationType
="select",secondTableColumn
="catName". This means in theproduct
create form there will be acategory
select/dropdown and that dropdown will have the data of thecatName
property of thecategory
entity.
Currently CRUD Generator supports the following relation types.
relationType | info |
---|---|
select | creates a select/dropdown representing a one to many relation b/w the entities |
radio | creates a radio buttons representing a one to many relation b/w the entities |
checkBox | creates checkboxes representing a many to many relation b/w the entities |
multiselect | creates a multiSelect/dropdown representing a many to many relation b/w the entities |
oneToMany | creates a select/dropdown representing |
manyToMany | creates a multiSelect/dropdown representing |
For better understanding Checkout the screenshots at the bottom of the page click here |
- For each entity seperate React Components are created for Create,View,Update,delete and list page.
- For each entity seperate service is created for get, put, post and delete calls to the Node Project the services uses axios for this purpose.
- Each Form element/input will have client side validation applied using JOI depending upon type of the element that user provides.
- List Page avoid lengthy pages by providing pagination.
- Provides Authentication System containing 5 functionalties login, logout, register, update password and user inforamtion using their forms.
- The Navbar will have the name of all the Entities user provided for easy navigation b/w all these CRUD's. We used react-router-dom for ease.
- Depending upon the name of theme provided the UI of the App changes.
- Responsive Design for both Desktop and mobile size displays.
- For clearer picture about the features Checkout the screenshots of a generated project at the bottom of the page click here
- If you want to add some new fearures in your generated CRUD app you can Contact us
- For each entity seperate database models are created using Mongoose.
- For each entity seperate API Endpoints are created i.e all [get, put, post and delete] which are accessible by authenticated users of generated React Project. These endpoints are created using express.
- For Providing Authentication System a User database model and its respective API Endpoints are automatically created. The project uses jsonwebtoken for token managment.
- The project creates respective database in MongoDB with a default user which can login.
- The project also has nodemon which helps developers by automatically
restarting the application when file changes are detected. - If you want to add some new features in your generated CRUD app you can Contact us
The MERN CRUD Generator Generates a basic CRUD application. If you have some custom requirments that is you want us to modify or add some new features or you need our help in Developing a complete MERN Application for your business We are available for your help 24/7 you can contact us here on
- Gmail [email protected].
- LinkedIn linkedin.com/in/umairshehzad128/.
To generate your CRUD app the only thing you need is a json schema file in a specific format but if the provided schema file has not valid format or schema does not follow the rules then on runtime all those errors are wrote to a file named errors.txt and this file will be placed where you wanted your CRUD app to be generated. So here we have disscussed about some of the most common errors and these errors are explained in such a way that they will help you in understanding any other errors that may generate.
instance.appTheme is not one of enum values: dark,defaultLight,electricBlue
, hereinstance.appTheme
means firstinstance
means your schema file andappTheme
is the property of schema, and the complete error statement is telling that the appTheme is an enum type property and allows only following set of value use any of thesedark,defaultLight,electricBlue
.instance.appSchema.tables[2].name does not match pattern "^[A-Z][a-zA-Z]*$"
, hereinstance.appSchema
means firstinstance
means your schema file andappSchema
is the property of schema, and the complete error statement means inside theappSchema
we have andtables
array andtables[2].name
means on the second object of tables array there is aname
property which has the error, the error is telling thatname
property value should be a string whose first letter should be capital.instance.appSchema.tables[5].columns[1].required is not of a type(s) boolean
, hereinstance.appSchema
means firstinstance
means your schema file andappSchema
is the property of schema, and the complete error statement means inside theappSchema
we have andtables
array andtables[5].columns[1].required
means on the fifth object of tables array there is acolumns
array whose first index has therequired
property which has the error, the error is telling thatrequired
property supports typeboolean
and its value can be eithertrue
orfalse
.invalid table name used on firstTable of instance.appSchema.relations[3], please specify name of table that you provided in scheema
, hereinstance.appSchema
means firstinstance
means your schema file andappSchema
is the property of schema, and the complete error statement means inside theappSchema
we have andrelations
array andfirstTable of relations[3]
means on the third object of relations array there is afirstTable
property which has the error, the error is telling thatfirstTable
property value should be same as thename
property of any of thetables
array object of respective schema.There can only be one relation between two tables, relation between Order and Product are defined twice on instance.appSchema.relations[3] and instance.appSchema.relations[4]
means firstinstance
means your schema file andappSchema
is the property of schema, and the complete error statement means inside theappSchema
we have andrelations
array andrelations[n]
means a specific object of relations array and the error statement is telling that two relation object have samefirstTable
andsecondTable
value but have differentrelationType
property value means you are trying to create multiple relations b/w two entities and it is not possible remove any of them to resole error.invalid column name used in secondTableColumn on instance.appSchema.relations[3], please specify name of column that exist in Product scheema .
, hereinstance.appSchema
means firstinstance
means your schema file andappSchema
is the property of schema, and the complete error statement means inside theappSchema
we have andrelations
array andfirstTable of relations[3]
means on the third object of relations array there is asecondTableColumn
property which has the error, the error is telling thatsecondTableColumn
property value should be same as thename
property of any of thecolumns
array object of respective table you mentioned in thesecondTable
property.
The following is a sample schema for an Ecommerace Application and it uses all datatypes,relations and fearures supported.
{
"appName": "Ecomerace",
"appTheme": "dark",
"appDbName": "EcomeraceDb",
"appSchema": {
"tables": [
{
"name": "Product",
"columns": [
{
"name": "ProdName",
"type": "text",
"required": true
},
{
"name": "Price",
"type": "number",
"required": true
}
]
},
{
"name": "Category",
"columns": [
{
"name": "CatName",
"type": "text",
"required": true
},
{
"name": "Type",
"type": "text",
"required": false
}
]
},
{
"name": "Order",
"columns": [
{
"name": "OrderName",
"type": "text",
"required": true
},
{
"name": "OrderDate",
"type": "date",
"required": true
}
]
},
{
"name": "Status",
"columns": [
{
"name": "StatName",
"type": "text",
"required": true
}
]
},
{
"name": "Customer",
"columns": [
{
"name": "Name",
"type": "text",
"required": true
},
{
"name": "Email",
"type": "email"
},
{
"name": "Password",
"type": "password"
},
{
"name": "Phone",
"type": "number",
"required": true
}
]
},
{
"name": "Suplier",
"columns": [
{
"name": "Name",
"type": "text",
"required": true
},
{
"name": "Phone",
"type": "number",
"required": true
}
]
}
],
"relations": [
{
"firstTable": "Product",
"secondTable": "Category",
"relationType": "oneToMany",
"secondTableColumn": "CatName"
},
{
"firstTable": "Order",
"secondTable": "User",
"relationType": "select",
"secondTableColumn": "email"
},
{
"firstTable": "Order",
"secondTable": "Status",
"relationType": "radio",
"secondTableColumn": "StatName"
},
{
"firstTable": "Order",
"secondTable": "Product",
"relationType": "checkBox",
"secondTableColumn": "ProdName"
},
{
"firstTable": "Customer",
"secondTable": "Order",
"relationType": "manyToMany",
"secondTableColumn": "OrderName"
},
{
"firstTable": "Suplier",
"secondTable": "Product",
"relationType": "multiselect",
"secondTableColumn": "ProdName"
}
]
}
}