mirror of
https://github.com/vale981/Vulcan
synced 2025-03-10 04:26:41 -04:00

Currently, ``throwError`` is used for all manner of messages, including errors, "success" messages, and "info" messages. This makes appropriate styling of the error message difficult. In addition, the name ``throwError`` seems to create confusion, implying that an error will actually be thrown (e.g. stopping execution when a user isn't logged in [0][1]), when in fact it just displays a message. Replace ``throwError`` with ``flashMessage``, and reliably include a message "type" (e.g. "error", "success", "info") every time. rename ``lib/errors.js`` to ``lib/messages.js`` to more accurately reflect its function. This commit doesn't rename the message collection (``Errors``), nor the template responsible for rendering the messages (``error_item.html``) -- that should probably still be done, but has higher likelihood of trouble for existing alternate themes and installations. [0]6ccf7d7d47/client/views/users/user_edit.js (L43)
[1]083a4c4dc4/client/views/users/user_email.js (L13)
156 lines
4.7 KiB
JavaScript
156 lines
4.7 KiB
JavaScript
Template[getTemplate('post_submit')].helpers({
|
|
categoriesEnabled: function(){
|
|
return Categories.find().count();
|
|
},
|
|
categories: function(){
|
|
return Categories.find();
|
|
},
|
|
users: function(){
|
|
return Meteor.users.find({}, {sort: {'profile.name': 1}});
|
|
},
|
|
userName: function(){
|
|
return getDisplayName(this);
|
|
},
|
|
isSelected: function(user){
|
|
return user._id == Meteor.userId() ? "selected" : "";
|
|
},
|
|
showPostedAt: function () {
|
|
if(Session.get('currentPostStatus') == STATUS_APPROVED){
|
|
return 'visible'
|
|
}else{
|
|
return 'hidden'
|
|
}
|
|
// return (Session.get('currentPostStatus') || STATUS_APPROVED) == STATUS_APPROVED; // default to approved
|
|
}
|
|
});
|
|
|
|
Template[getTemplate('post_submit')].rendered = function(){
|
|
// run all post submit rendered callbacks
|
|
var instance = this;
|
|
postSubmitRenderedCallbacks.forEach(function(callback) {
|
|
callback(instance);
|
|
});
|
|
|
|
Session.set('currentPostStatus', STATUS_APPROVED);
|
|
Session.set('selectedPostId', null);
|
|
if(!this.editor && $('#editor').exists())
|
|
this.editor= new EpicEditor(EpicEditorOptions).load();
|
|
|
|
$('#postedAtDate').datepicker();
|
|
|
|
// $("#postUser").selectToAutocomplete(); // XXX
|
|
|
|
};
|
|
|
|
Template[getTemplate('post_submit')].events({
|
|
'change input[name=status]': function (e, i) {
|
|
Session.set('currentPostStatus', e.currentTarget.value);
|
|
},
|
|
'click input[type=submit]': function(e, instance){
|
|
e.preventDefault();
|
|
|
|
$(e.target).addClass('disabled');
|
|
|
|
// ------------------------------ Checks ------------------------------ //
|
|
|
|
if(!Meteor.user()){
|
|
flashMessage(i18n.t('You must be logged in.'), "error");
|
|
return false;
|
|
}
|
|
|
|
// ------------------------------ Properties ------------------------------ //
|
|
|
|
// Basic Properties
|
|
|
|
var properties = {
|
|
title: $('#title').val(),
|
|
body: instance.editor.exportFile(),
|
|
sticky: $('#sticky').is(':checked'),
|
|
userId: $('#postUser').val(),
|
|
status: parseInt($('input[name=status]:checked').val())
|
|
};
|
|
|
|
// PostedAt
|
|
|
|
var $postedAtDate = $('#postedAtDate');
|
|
var $postedAtTime = $('#postedAtTime');
|
|
var setPostedAt = false;
|
|
var postedAt = new Date(); // default to current browser date and time
|
|
var postedAtDate = $postedAtDate.datepicker('getDate');
|
|
var postedAtTime = $postedAtTime.val();
|
|
|
|
if ($postedAtDate.exists() && postedAtDate != "Invalid Date"){ // if custom date is set, use it
|
|
postedAt = postedAtDate;
|
|
setPostedAt = true;
|
|
}
|
|
|
|
if ($postedAtTime.exists() && postedAtTime.split(':').length==2){ // if custom time is set, use it
|
|
var hours = postedAtTime.split(':')[0];
|
|
var minutes = postedAtTime.split(':')[1];
|
|
postedAt = moment(postedAt).hour(hours).minute(minutes).toDate();
|
|
setPostedAt = true;
|
|
}
|
|
|
|
if(setPostedAt) // if either custom date or time has been set, pass result to properties
|
|
properties.postedAt = postedAt;
|
|
|
|
|
|
// URL
|
|
|
|
var url = $('#url').val();
|
|
if(!!url){
|
|
var cleanUrl = (url.substring(0, 7) == "http://" || url.substring(0, 8) == "https://") ? url : "http://"+url;
|
|
properties.url = cleanUrl;
|
|
}
|
|
|
|
// ------------------------------ Callbacks ------------------------------ //
|
|
|
|
// run all post submit client callbacks on properties object successively
|
|
properties = postSubmitClientCallbacks.reduce(function(result, currentFunction) {
|
|
return currentFunction(result);
|
|
}, properties);
|
|
|
|
// console.log(properties)
|
|
|
|
// ------------------------------ Insert ------------------------------ //
|
|
if (properties) {
|
|
Meteor.call('post', properties, function(error, post) {
|
|
if(error){
|
|
flashMessage(error.reason, "error");
|
|
clearSeenMessages();
|
|
$(e.target).removeClass('disabled');
|
|
if(error.error == 603)
|
|
Router.go('/posts/'+error.details);
|
|
}else{
|
|
trackEvent("new post", {'postId': post._id});
|
|
if(post.status === STATUS_PENDING)
|
|
flashMessage('Thanks, your post is awaiting approval.', "success");
|
|
Router.go('/posts/'+post._id);
|
|
}
|
|
});
|
|
} else {
|
|
$(e.target).removeClass('disabled');
|
|
}
|
|
|
|
},
|
|
'click .get-title-link': function(e){
|
|
e.preventDefault();
|
|
var url=$("#url").val();
|
|
var $getTitleLink = $(".get-title-link");
|
|
$getTitleLink.addClass("loading");
|
|
if(url){
|
|
$.get(url, function(response){
|
|
if ((suggestedTitle=((/<title>(.*?)<\/title>/m).exec(response.responseText))) != null){
|
|
$("#title").val(suggestedTitle[1]);
|
|
}else{
|
|
alert("Sorry, couldn't find a title...");
|
|
}
|
|
$getTitleLink.removeClass("loading");
|
|
});
|
|
}else{
|
|
alert("Please fill in an URL first!");
|
|
$getTitleLink.removeClass("loading");
|
|
}
|
|
}
|
|
|
|
});
|