Vulcan/packages/telescope-base/lib/base.js
Sacha Greif b8dc56ea40 Merge branch 'master' into quickform
Conflicts:
	.meteor/versions
	client/views/settings/quickFormSettings.html
	collections/posts.js
	lib/router.js
	packages/telescope-api/versions.json
	packages/telescope-base/versions.json
	packages/telescope-module-embedly/versions.json
	packages/telescope-module-share/versions.json
	packages/telescope-notifications/versions.json
	packages/telescope-rss/versions.json
	packages/telescope-theme-base/versions.json
	packages/telescope-theme-hubble/versions.json
2014-11-26 11:22:54 +09:00

215 lines
No EOL
4.3 KiB
JavaScript

// ------------------------------------- Schemas -------------------------------- //
// array containing properties to be added to the post/settings/comments schema on startup.
addToPostSchema = [];
addToCommentsSchema = [];
addToSettingsSchema = [];
SimpleSchema.extendOptions({
editable: Match.Optional(Boolean), // editable: true means the field can be edited by the document's owner
hidden: Match.Optional(Boolean) // hidden: true means the field is never shown in a form no matter what
});
// ----------------------------------- Posts Statuses ------------------------------ //
postStatuses = [
{
value: 1,
label: 'Pending'
},
{
value: 2,
label: 'Approved'
},
{
value: 3,
label: 'Rejected'
}
]
STATUS_PENDING=1;
STATUS_APPROVED=2;
STATUS_REJECTED=3;
// ------------------------------------- Navigation -------------------------------- //
// array containing nav items; initialize with views menu and admin menu
primaryNav = ['viewsMenu', 'adminMenu'];
secondaryNav = ['userMenu', 'notificationsMenu', 'submitButton'];
// array containing items in the admin menu
adminNav = [];
// array containing items in the views menu
viewNav = [
{
route: 'posts_top',
label: 'top'
},
{
route: 'posts_new',
label: 'new'
},
{
route: 'posts_best',
label: 'best'
},
{
route: 'posts_digest_default',
label: 'digest'
}
];
// ------------------------------------- Views -------------------------------- //
// object containing post list view parameters
viewParameters = {}
viewParameters.top = function (terms) {
return {
options: {sort: {sticky: -1, score: -1}}
};
}
viewParameters.new = function (terms) {
return {
options: {sort: {sticky: -1, postedAt: -1}}
};
}
viewParameters.best = function (terms) {
return {
options: {sort: {sticky: -1, baseScore: -1}}
};
}
viewParameters.pending = function (terms) {
return {
find: {
status: 1,
postedAt: {$lte: null}
},
options: {sort: {createdAt: -1}}
};
}
viewParameters.digest = function (terms) {
return {
find: {
postedAt: {
$gte: terms.after,
$lt: terms.before
}
},
options: {
sort: {sticky: -1, baseScore: -1, limit: 0}
}
};
}
heroModules = [];
footerModules = [];
// array containing post modules
modulePositions = [
'left-left',
'left-center',
'left-right',
'center-left',
'center-center',
'center-right',
'right-left',
'right-center',
'right-right'
];
postModules = [
{
template: 'postUpvote',
position: 'left-left'
},
{
template: 'postActions',
position: 'left-right'
},
{
template: 'postContent',
position: 'center-center'
},
{
template: 'postDiscuss',
position: 'right-right'
}
];
postHeading = [
{
template: 'postTitle',
order: 1
},
{
template: 'postDomain',
order: 5
}
]
postMeta = [
{
template: 'postInfo',
order: 1
},
{
template: 'postCommentsLink',
order: 3
},
{
template: 'postAdmin',
order: 5
}
]
// ------------------------------ Callbacks ------------------------------ //
postSubmitRenderedCallbacks = [];
postSubmitClientCallbacks = [];
postSubmitMethodCallbacks = [];
postAfterSubmitMethodCallbacks = [];
postEditRenderedCallbacks = [];
postEditClientCallbacks = [];
postEditMethodCallbacks = []; // not used yet
postAfterMethodCallbacks = []; // not used yet
commentSubmitRenderedCallbacks = [];
commentSubmitClientCallbacks = [];
commentSubmitMethodCallbacks = [];
commentAfterSubmitMethodCallbacks = [];
commentEditRenderedCallbacks = [];
commentEditClientCallbacks = [];
commentEditMethodCallbacks = []; // not used yet
commentAfterEditMethodCallbacks = []; // not used yet
// ------------------------------ Dynamic Templates ------------------------------ //
templates = {}
getTemplate = function (name) {
// if template has been overwritten, return this; else return template name
return !!templates[name] ? templates[name] : name;
}
// ------------------------------ Theme Settings ------------------------------ //
themeSettings = {
'useDropdowns': true // whether or not to use dropdown menus in a theme
};
// ------------------------------ Subscriptions ------------------------------ //
// array containing subscriptions to be preloaded
preloadSubscriptions = [];