Vulcan/client/views/posts/post_submit.js
Charlie DeTar ea7efc3550 Replace "throwError" with "flashMessage" and type
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)
2014-11-05 13:12:09 -07:00

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");
}
}
});