2017-03-23 16:27:59 +09:00
|
|
|
import Users from 'meteor/vulcan:users';
|
2016-06-23 15:00:58 +09:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @summary Comments schema
|
2016-11-22 18:14:51 -05:00
|
|
|
* @type {Object}
|
2016-06-23 15:00:58 +09:00
|
|
|
*/
|
2016-11-22 18:14:51 -05:00
|
|
|
const schema = {
|
2016-06-23 15:00:58 +09:00
|
|
|
/**
|
|
|
|
ID
|
|
|
|
*/
|
|
|
|
_id: {
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
2016-12-06 10:55:47 +01:00
|
|
|
viewableBy: ['guests'],
|
2016-06-23 15:00:58 +09:00
|
|
|
},
|
|
|
|
/**
|
|
|
|
The `_id` of the parent comment, if there is one
|
|
|
|
*/
|
|
|
|
parentCommentId: {
|
|
|
|
type: String,
|
|
|
|
// regEx: SimpleSchema.RegEx.Id,
|
|
|
|
max: 500,
|
2016-12-06 10:55:47 +01:00
|
|
|
viewableBy: ['guests'],
|
|
|
|
insertableBy: ['members'],
|
2016-06-23 15:00:58 +09:00
|
|
|
optional: true,
|
2016-11-08 14:56:39 +09:00
|
|
|
resolveAs: 'parentComment: Comment',
|
2016-11-18 10:03:01 +01:00
|
|
|
hidden: true // never show this
|
2016-06-23 15:00:58 +09:00
|
|
|
},
|
|
|
|
/**
|
|
|
|
The `_id` of the top-level parent comment, if there is one
|
|
|
|
*/
|
|
|
|
topLevelCommentId: {
|
|
|
|
type: String,
|
|
|
|
// regEx: SimpleSchema.RegEx.Id,
|
|
|
|
max: 500,
|
2016-12-06 10:55:47 +01:00
|
|
|
viewableBy: ['guests'],
|
|
|
|
insertableBy: ['members'],
|
2016-06-23 15:00:58 +09:00
|
|
|
optional: true,
|
2016-11-08 14:56:39 +09:00
|
|
|
resolveAs: 'topLevelComment: Comment',
|
2016-11-18 10:03:01 +01:00
|
|
|
hidden: true // never show this
|
2016-06-23 15:00:58 +09:00
|
|
|
},
|
|
|
|
/**
|
|
|
|
The timestamp of comment creation
|
|
|
|
*/
|
|
|
|
createdAt: {
|
|
|
|
type: Date,
|
|
|
|
optional: true,
|
2016-12-06 10:55:47 +01:00
|
|
|
viewableBy: ['admins'],
|
2016-11-14 17:17:44 +09:00
|
|
|
autoValue: (documentOrModifier) => {
|
2016-12-08 23:48:16 +01:00
|
|
|
if (documentOrModifier && !documentOrModifier.$set) return new Date() // if this is an insert, set createdAt to current timestamp
|
2016-11-14 17:17:44 +09:00
|
|
|
}
|
2016-06-23 15:00:58 +09:00
|
|
|
},
|
|
|
|
/**
|
|
|
|
The timestamp of the comment being posted. For now, comments are always created and posted at the same time
|
|
|
|
*/
|
|
|
|
postedAt: {
|
|
|
|
type: Date,
|
|
|
|
optional: true,
|
2016-12-08 23:48:16 +01:00
|
|
|
viewableBy: ['guests'],
|
2016-11-14 17:17:44 +09:00
|
|
|
autoValue: (documentOrModifier) => {
|
2016-12-08 23:48:16 +01:00
|
|
|
if (documentOrModifier && !documentOrModifier.$set) return new Date() // if this is an insert, set createdAt to current timestamp
|
2016-11-14 17:17:44 +09:00
|
|
|
}
|
2016-06-23 15:00:58 +09:00
|
|
|
},
|
|
|
|
/**
|
|
|
|
The comment body (Markdown)
|
|
|
|
*/
|
|
|
|
body: {
|
|
|
|
type: String,
|
|
|
|
max: 3000,
|
2016-12-06 10:55:47 +01:00
|
|
|
viewableBy: ['guests'],
|
|
|
|
insertableBy: ['members'],
|
|
|
|
editableBy: ['members'],
|
2016-06-23 15:00:58 +09:00
|
|
|
control: "textarea"
|
|
|
|
},
|
|
|
|
/**
|
|
|
|
The HTML version of the comment body
|
|
|
|
*/
|
|
|
|
htmlBody: {
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
2016-12-06 10:55:47 +01:00
|
|
|
viewableBy: ['guests'],
|
2016-06-23 15:00:58 +09:00
|
|
|
},
|
|
|
|
/**
|
|
|
|
The comment author's name
|
|
|
|
*/
|
|
|
|
author: {
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
2016-12-06 10:55:47 +01:00
|
|
|
viewableBy: ['guests'],
|
2016-11-14 17:17:44 +09:00
|
|
|
autoValue: (documentOrModifier) => {
|
|
|
|
// if userId is changing, change the author name too
|
|
|
|
const userId = documentOrModifier.userId || documentOrModifier.$set && documentOrModifier.$set.userId
|
|
|
|
if (userId) return Users.getDisplayNameById(userId)
|
|
|
|
}
|
2016-06-23 15:00:58 +09:00
|
|
|
},
|
|
|
|
/**
|
|
|
|
Whether the comment is inactive. Inactive comments' scores gets recalculated less often
|
|
|
|
*/
|
|
|
|
inactive: {
|
|
|
|
type: Boolean,
|
|
|
|
optional: true,
|
2016-12-06 10:55:47 +01:00
|
|
|
viewableBy: ['guests'],
|
2016-06-23 15:00:58 +09:00
|
|
|
},
|
|
|
|
/**
|
|
|
|
The post's `_id`
|
|
|
|
*/
|
|
|
|
postId: {
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
2016-12-06 10:55:47 +01:00
|
|
|
viewableBy: ['guests'],
|
|
|
|
insertableBy: ['members'],
|
2016-06-23 15:00:58 +09:00
|
|
|
// regEx: SimpleSchema.RegEx.Id,
|
|
|
|
max: 500,
|
2016-11-08 14:56:39 +09:00
|
|
|
resolveAs: 'post: Post',
|
2016-11-18 10:03:01 +01:00
|
|
|
hidden: true // never show this
|
2016-06-23 15:00:58 +09:00
|
|
|
},
|
|
|
|
/**
|
|
|
|
The comment author's `_id`
|
|
|
|
*/
|
|
|
|
userId: {
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
2016-12-06 10:55:47 +01:00
|
|
|
viewableBy: ['guests'],
|
|
|
|
insertableBy: ['members'],
|
2016-11-18 10:03:01 +01:00
|
|
|
hidden: true,
|
2016-11-18 09:28:32 +01:00
|
|
|
resolveAs: 'user: User',
|
2016-06-23 15:00:58 +09:00
|
|
|
},
|
|
|
|
/**
|
2016-11-26 02:46:55 +08:00
|
|
|
Whether the comment is deleted. Delete comments' content doesn't appear on the site.
|
2016-06-23 15:00:58 +09:00
|
|
|
*/
|
|
|
|
isDeleted: {
|
|
|
|
type: Boolean,
|
|
|
|
optional: true,
|
2016-12-06 10:55:47 +01:00
|
|
|
viewableBy: ['guests'],
|
2016-06-23 15:00:58 +09:00
|
|
|
},
|
|
|
|
userIP: {
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
2016-12-06 10:55:47 +01:00
|
|
|
viewableBy: ['admins'],
|
2016-06-23 15:00:58 +09:00
|
|
|
},
|
|
|
|
userAgent: {
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
2016-12-06 10:55:47 +01:00
|
|
|
viewableBy: ['admins'],
|
2016-06-23 15:00:58 +09:00
|
|
|
},
|
|
|
|
referrer: {
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
2016-12-06 10:55:47 +01:00
|
|
|
viewableBy: ['admins'],
|
2016-06-23 15:00:58 +09:00
|
|
|
}
|
2016-11-22 18:14:51 -05:00
|
|
|
};
|
2016-06-23 15:00:58 +09:00
|
|
|
|
2016-11-22 18:14:51 -05:00
|
|
|
export default schema;
|