Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nikhil-swamix/mongeasy
https://github.com/nikhil-swamix/mongeasy
Last synced: 15 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/nikhil-swamix/mongeasy
- Owner: nikhil-swamix
- Created: 2023-10-04T17:24:47.000Z (about 1 year ago)
- Default Branch: master
- Last Pushed: 2023-12-04T04:13:04.000Z (about 1 year ago)
- Last Synced: 2024-04-23T02:31:03.273Z (9 months ago)
- Language: JavaScript
- Size: 673 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
## Stable version released!
Mongeasy aims to streamline the management of models and schemas in your projects by utilizing a simple syntax. This is achieved by employing CSS (Carnage Schema Syntax), which is
a flag-based declaration and modification language designed by [Nikhil Swami](https://www.linkedin.com/in/nikhilswamiofficial/) also visit swamix.com . CSS is just a shortcut way of
writing mongoose schemas, which is a superset of mongoose. It is not a new library, it is just a new way of writing mongoose schemas, which is more readable, clean and easy to
maintain. It is not a replacement for mongoose, rather an extension. if you know how `ls -la` works in linux, you know this package half already!### Why Should I Use It?
- easy to use, mongeasy!
- light weight less than 100 kb.
- lesser boilerplate and redeclarations.
- 66% shorter code!
- reverse compatibility, fallback to mongoose anytime, without breaking anything.## Install
```bash
npm i mongeasy
pnpm i mongeasy
yarn i mongeasy
bun i mongeasy
```## Example
```javascript
import mongoose from 'mongoose';
import { models } from 'mongeasy';let Models = models({
Computer: [
'name |String |!|*|#|(3,16)', // ! = unique, * = required, # = index, (3,16) = minlength,maxlength
'price |Number |+U|+R|+I', // same as above, +U = unique, +R = required, +I = index
'madeIn |ObjectId|ref:CountryNames', // ref:CountryNames = reference to another model
'dateOfPurchase |Date |*', // Date = Date , * = required
"color |String |['red','blue','green']", // ['red','blue','green'] = enum
'inStock |Boolean|',
'storageTemp |Number |(-10,60)', // (0,) = min no upper limit
'globalStockQty |Number |(0,)', // (0,) = min, no upper limit // (,100) = no lower limit
],
Employee: [
'name|String|!|*|#|(3,16)',
'salary|Number|+R',
'dateOfJoining|Date|*',
'designation|String|*',
'gender|String|["male","female"]',
'isMarried|Boolean|*',
'address|String|*',
'phone|String|*',
],
});console.log(Models);
// Connect to database , connection is same
mongoose.connect('mongodb://localhost:27017/test', {
useNewUrlParser: true,
useUnifiedTopology: true,
});// add a computer as usual
let c = new Models.Computer({
name: 'Macbook Pro 2',
price: 2000 + Math.random() * 1000,
madeIn: 'India',
dateOfPurchase: new Date(),
color: 'red',
inStock: true,
storageTemp: 50,
globalStockQty: 100,
});
c.save();// exit
setTimeout(() => {
mongoose.disconnect();
}, 100);
```### **Format:** `` | `` | ``
**Name:**
- the name of field - emojis also supported
**Type :**
all supported, as we directly pass to Core Library https://mongoosejs.com/docs/schematypes.html
- [ Array, Boolean, BigInt, Buffer, Date, Decimal, Decimal128, DocumentArray, Map, Mixed, Number, ObjectId, String, Subdocument, UUID, Oid, Object, Bool, ObjectID ]
**Modifiers:**
The syntax consists of the following elements: Note: "/" means "either option" refer https://mongoosejs.com/docs/schematypes.html#indexes
- +U / ! = unique
- +R / \* = required
- +I / # = index
- (0, 999) = min,max
- ['adam', 'eve'] = enumThis CSS-based declaration paradigm aims to provide a simplified way of defining Mongoose schemas, making it easier to work with MongoDB data models.