What happened to the original author?#

A: The original author szokodiakos (github name) has abandoned the project, but might look into it again at some time.

Is this Project still active?#

A: Yes it is, but not on the main repository anymore because of What happened to the original author? and Github Permissions (TL;DR: a collaborator cannot add another collaborater, only the owner can)

Why is the original project not archived?#

A: because a collaborator cannot archive a project, only the owner can (What happened to the original author?)

Why is the package now released in another package?#

(context: from typegoose to @typegoose/typegoose)
A: Because of a Repository Switch (reasons) and because a name cannot be used by multiple packages, except if it is scoped.

Why @typegoose/typegoose#

A: because I (hasezoey) don't have permissions over the old typegoose repository and I dont want to touch the old npm package. It is a typical forking and continuation of an OSS project.


Why does new Model({}) not have types?#

A: because Typegoose doesn't modify any Mongoose code, it is still the same as Mongoose's original new Model(), you would have to do new Model({} as Class) (or sometimes new Model({} as Partial<Class>), because of functions.)


since @types/mongoose@5.7.22 there are typings for .create, but are not fully compatible with Typegoose. For more information please read known-issues

Why is 7.4.x constrained to mongoose 5.10.18?#

A: this because in mongoose 5.10.19 and higher, mongoose has its own typescript definitions, and typegoose is not upgraded for that yet

Edge Cases#

I want to the return document with property id instead of _id#

Mongoose automatically adds a virtual named id, use the following for type definitions:

class Cat {
id: mongoose.Types.ObjectId;
_id: mongoose.Types.ObjectId;