[] (https://gitter.im/zimme/meteor-collection-softremovable) [] (https://codeclimate.com/github/zimme/meteor-collection-softremovable)
Add soft remove to collections.
meteor add zimme:collection-softremovable
Basic usage examples.
Posts = new Mongo.Collection('posts');
//Attach behaviour with the default options
Posts.attachBehaviour('softRemovable');
//Attach behaviour with custom options
Posts.attachBehaviour('softRemovable', {
removed: 'deleted',
removedBy: false,
restoredAt: 'undeletedAt',
restoredBy: false
});
// Soft remove document by _id
Posts.softRemove({_id: 'BFpDzGuWG8extPwrE'});
// Restore document by _id
Posts.restore('BFpDzGuWG8extPwrE');
// Actually remove document from collection
Posts.remove({_id: 'BFpDzGuWG8extPwrE'});
// Find all posts except soft removed posts
Posts.find({});
// Find only posts that have been soft removed
Posts.find({removed: true});
// Find all posts including removed
Posts.find({}, {removed: true});
For you to be able to find soft removed documents on the client you will need to explicitly publish those. The example code below belongs in server-side code.
Meteor.publish('posts', function() {
return Posts.find({});
});
Meteor.publish('removedPosts', function() {
return Posts.find({removed: true});
});
Meteor.publish('allPosts', function() {
return Posts.find({}, {removed: true});
});
The following options can be used:
-
removed
: Optional. Set to'string'
to change the fields name. This field can't be omitted. -
removedAt
: Optional. Set to'string'
to change the fields name. Set tofalse
to omit field. -
removedBy
: Optional. Set to'string'
to change the fields name. Set tofalse
to omit field. -
restoredAt
: Optional. Set to'string'
to change the fields name. Set tofalse
to omit field. -
restoredBy
: Optional. Set to'string'
to change the fields name. Set tofalse
to omit field. -
systemId
: Optional. Set to'string'
to change the id representing the system.
// Configure behaviour globally
// All collection using this behaviour will use these settings as defaults
// The settings below are the package default settings
CollectionBehaviours.configure('softRemovable',{
removed: 'removed',
removedAt: 'removedAt',
removedBy: 'removedBy',
restoredAt: 'restoredAt',
restoredBy: 'restoredAt',
systemId: '0'
});
- This package attaches a schema to the collection if
aldeed:simple-schema
,aldeed:collection2
and/oraldeed:autoform
are used in the application.