Intuitive, type safe and flexible ORM for Pinia based on Vuex ORM Next
You want to migrate from vuex to pinia and with it vuex-orm to pinia-orm but you don't know yet? Well maybe this table will help you to decide. This comparison is just about facts and current state.
Features | [email protected] | @vuex-orm/[email protected] | @vuex-orm/[email protected] |
---|---|---|---|
Bundle Size (Min + GZIP) | 9.9 KB | 16.7 KB | 12.6 KB |
Relations (hasMany, belongsTo, morphOne, hasManyBy, hasOne, morphTo) | ✅ | ✅ | ✅ |
Relations (morphMany, belongsToMany, hasManyThrough) | ✅ | ✅ | ❌ |
Relations (morphToMany, morphedByMany) | ❌ | ✅ | ❌ |
Mutators | ✅ | ✅ | ❌ |
Casts | ✅ | ❌ | ❌ |
Decorators | ✅ | ❌ | ✅ |
Single Table Inheritance | ✅ | ✅ | ❌ |
Lifecycle Hooks | ✅ | ✅ | ❌ |
Aggregates | ✅ | ✅ | ❌ |
Query (orHas, doesntHave, orDoesntHave, whereHas, orWhereHas, groupBy) | ✅ | ❌ | ❌ |
Collection Helpers | ✅ | (✅) can use pinia-orm helpers too | (✅) can use pinia-orm helpers too |
Hidden Fields | ✅ | ❌ | ❌ |
Metadata field | ✅ | ❌ | ❌ |
Caching of queries with gc | ✅ | (✅) with plugin | ❌ |
If you decide to migrate then there are some breaking changes. A guide how to migrate will be written. Small overview:
- Fields are by default
null
- Renamed some functions aligning more with laravel naming
- Code is based on
vuex-orm-next
and not onvuex-orm
!
- Clone this repository
- Enable Corepack using
corepack enable
(usenpm i -g corepack
for Node.js < 16.10) - Install dependencies using
pnpm install
- Build normalizr package:
pnpm build
- Run interactive tests using
cd packages/pinia-orm && pnpm test:ui
Made with ❤️
Published under MIT License.