npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

mern-crud-generator

v1.1.2

Published

A CLI that takes JSON scheema and helps in generating CRUD in React along with API in express and database in MongoDB

Downloads

16

Readme

MERN CRUD Generator

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

  1. To save developers time generating all the four CRUD functionalities for each Entity.
  2. Generate relations between these entities if there are any.
  3. 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.

Quick Start

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.

What Projects can be generated?

  1. 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.
  2. 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.
  3. 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.

Creating Schema for CRUD Generator input

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.

Relations Between Entities

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 properties prodName and price.
  • The category has two properties catName and type. If a relation object has these values firstTable="product", secondTable="category", relationType="select", secondTableColumn="catName". This means in the product create form there will be a category select/dropdown and that dropdown will have the data of the catName property of the category entity.

Relation Types Supported

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

React Project Features

  • 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

Node Project Features

  • 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

Looking for some other Features

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

Dealing with Errors

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, here instance.appTheme means first instance means your schema file and appTheme 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 these dark,defaultLight,electricBlue.
  • instance.appSchema.tables[2].name does not match pattern "^[A-Z][a-zA-Z]*$", here instance.appSchema means first instance means your schema file and appSchema is the property of schema, and the complete error statement means inside the appSchema we have and tables array and tables[2].name means on the second object of tables array there is a name property which has the error, the error is telling that name 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, here instance.appSchema means first instance means your schema file and appSchema is the property of schema, and the complete error statement means inside the appSchema we have and tables array and tables[5].columns[1].required means on the fifth object of tables array there is a columns array whose first index has the required property which has the error, the error is telling that required property supports type boolean and its value can be either true or false.
  • invalid table name used on firstTable of instance.appSchema.relations[3], please specify name of table that you provided in scheema , here instance.appSchema means first instance means your schema file and appSchema is the property of schema, and the complete error statement means inside the appSchema we have and relations array and firstTable of relations[3] means on the third object of relations array there is a firstTable property which has the error, the error is telling that firstTable property value should be same as the name property of any of the tables 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 first instance means your schema file and appSchema is the property of schema, and the complete error statement means inside the appSchema we have and relations array and relations[n] means a specific object of relations array and the error statement is telling that two relation object have same firstTable and secondTable value but have different relationType 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 ., here instance.appSchema means first instance means your schema file and appSchema is the property of schema, and the complete error statement means inside the appSchema we have and relations array and firstTable of relations[3] means on the third object of relations array there is a secondTableColumn property which has the error, the error is telling that secondTableColumn property value should be same as the name property of any of the columns array object of respective table you mentioned in the secondTable property.

Sample Schema File

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"
            }
        ]
    }
}

Generated CRUD APP Screenshots

Some of the screenshots from the project generated by using the above Ecommerace JSON scheema, If images are not clear Open them in new tab i.e right click on image and then from dropdown select open image in new tab.