7 Commits

Author SHA1 Message Date
bf7f9db63d chore: update cover 2024-01-17 14:34:17 -07:00
71837428dd docs: update dependencies 2024-01-17 14:30:08 -07:00
12d62d873b docs: update dependencies 2024-01-17 14:25:53 -07:00
61cc32381b chore: update cover 2024-01-17 14:20:44 -07:00
42b3b8375a chore: update playground 2024-01-17 13:57:49 -07:00
bdab2c5395 chore: update dependencies 2024-01-17 13:56:38 -07:00
d6b8e91f06 refactor: split services into individual files 2024-01-17 13:49:12 -07:00
10 changed files with 3484 additions and 4048 deletions

View File

@ -1,4 +1,4 @@
![nuxt-mongoose](https://nuxt-mongoose.nuxt.space/cover.jpg)
![nuxt-mongoose](https://raw.githubusercontent.com/arashsheyda/nuxt-mongoose/main/docs/public/cover.jpg)
<div align="center">
<h1>Nuxt Mongoose</h1>

View File

@ -1,5 +1,5 @@
{
"name": "docus-starter",
"name": "nuxt-mongoose-docs",
"version": "0.1.0",
"private": true,
"scripts": {
@ -11,7 +11,7 @@
},
"devDependencies": {
"@nuxt-themes/docus": "^1.15.0",
"@nuxthq/studio": "^1.0.2",
"nuxt": "^3.8.0"
"@nuxthq/studio": "^1.0.8",
"nuxt": "^3.9.3"
}
}

4465
docs/pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff

Binary file not shown.

Before

Width:  |  Height:  |  Size: 46 KiB

After

Width:  |  Height:  |  Size: 237 KiB

View File

@ -49,26 +49,26 @@
"lint": "eslint . --fix"
},
"dependencies": {
"@nuxt/devtools-kit": "1.0.0",
"@nuxt/devtools-ui-kit": "1.0.0",
"@nuxt/kit": "^3.9.0",
"@vueuse/core": "^10.7.1",
"defu": "^6.1.3",
"@nuxt/devtools-kit": "1.0.8",
"@nuxt/devtools-ui-kit": "1.0.8",
"@nuxt/kit": "^3.9.3",
"@vueuse/core": "^10.7.2",
"defu": "^6.1.4",
"fs-extra": "^11.2.0",
"mongoose": "^7.6.7",
"mongoose": "^8.1.0",
"ofetch": "^1.3.3",
"pathe": "^1.1.1",
"pathe": "^1.1.2",
"pluralize": "^8.0.0",
"sirv": "^2.0.4"
},
"devDependencies": {
"@antfu/eslint-config": "1.0.0-beta.29",
"@antfu/eslint-config": "2.6.3",
"@nuxt/module-builder": "^0.5.5",
"@types/fs-extra": "^11.0.4",
"@types/pluralize": "^0.0.32",
"@types/pluralize": "^0.0.33",
"changelogen": "^0.5.5",
"eslint": "8.52.0",
"nuxt": "^3.9.0",
"eslint": "8.56.0",
"nuxt": "^3.9.3",
"sass": "^1.69.7"
}
}

View File

@ -1,8 +1,14 @@
<script setup>
<script setup lang="ts">
const { data } = await useFetch('/api/users')
</script>
<template>
<div>
Nuxt module playground!
<br>
<pre
v-html="JSON.stringify(data, null, 2)"
style="background: #131313;color: #4EA65A;padding: 20px;border-radius: 7px;text-shadow: 0px 0px 10px #00ff22;"
/>
</div>
</template>

2926
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,20 @@
import type { ConnectOptions } from 'mongoose'
import { logger } from '@nuxt/kit'
import mongoose from 'mongoose'
// @ts-ignore
import { useRuntimeConfig } from '#imports'
export async function defineMongooseConnection({ uri, options }: { uri?: string; options?: ConnectOptions } = {}): Promise<void> {
const config = useRuntimeConfig().mongoose
const mongooseUri = uri || config.uri
const mongooseOptions = options || config.options
try {
await mongoose.connect(mongooseUri, { ...mongooseOptions })
logger.success('Connected to `MongoDB`')
}
catch (err) {
logger.error('Error connecting to `MongoDB`', err)
}
}

View File

@ -1,49 +1,2 @@
import { logger } from '@nuxt/kit'
import mongoose from 'mongoose'
import type { ConnectOptions, Model, SchemaDefinition, SchemaOptions } from 'mongoose'
import { useRuntimeConfig } from '#imports'
export async function defineMongooseConnection({ uri, options }: { uri?: string; options?: ConnectOptions } = {}): Promise<void> {
const config = useRuntimeConfig().mongoose
const mongooseUri = uri || config.uri
const mongooseOptions = options || config.options
try {
await mongoose.connect(mongooseUri, { ...mongooseOptions })
logger.success('Connected to `MongoDB`')
}
catch (err) {
logger.error('Error connecting to `MongoDB`', err)
}
}
export function defineMongooseModel<T>(
nameOrOptions: string | {
name: string
schema: SchemaDefinition<T>
options?: SchemaOptions
hooks?: (schema: mongoose.Schema<T>) => void
},
schema?: SchemaDefinition<T>,
options?: SchemaOptions,
hooks?: (schema: mongoose.Schema<T>) => void,
): Model<T> {
let name: string
if (typeof nameOrOptions === 'string') {
name = nameOrOptions
}
else {
name = nameOrOptions.name
schema = nameOrOptions.schema
options = nameOrOptions.options
hooks = nameOrOptions.hooks
}
const newSchema = new mongoose.Schema<T>(schema, options as any)
if (hooks)
hooks(newSchema)
return mongoose.model<T>(name, newSchema)
}
export { defineMongooseConnection } from './connection'
export { defineMongooseModel } from './model'

View File

@ -0,0 +1,32 @@
import type { Model, SchemaDefinition, SchemaOptions } from 'mongoose'
import mongoose from 'mongoose'
export function defineMongooseModel<T>(
nameOrOptions: string | {
name: string
schema: SchemaDefinition<T>
options?: SchemaOptions
hooks?: (schema: mongoose.Schema<T>) => void
},
schema?: SchemaDefinition<T>,
options?: SchemaOptions,
hooks?: (schema: mongoose.Schema<T>) => void,
): Model<T> {
let name: string
if (typeof nameOrOptions === 'string') {
name = nameOrOptions
}
else {
name = nameOrOptions.name
schema = nameOrOptions.schema
options = nameOrOptions.options
hooks = nameOrOptions.hooks
}
const newSchema = new mongoose.Schema<T>(schema, options as any)
if (hooks)
hooks(newSchema)
return mongoose.model<T>(name, newSchema)
}