// The Post Settings Menu available in the content preview screen, as well as the post editor. /*global window, document, $, _, Backbone, Ghost, moment */ (function () { "use strict"; Ghost.View.PostSettings = Ghost.View.extend({ events: { 'blur .post-setting-slug' : 'editSlug', 'click .post-setting-slug' : 'selectSlug', 'blur .post-setting-date' : 'editDate', 'click .delete' : 'deletePost' }, initialize: function () { if (this.model) { this.listenTo(this.model, 'change:id', this.render); this.listenTo(this.model, 'change:status', this.render); this.listenTo(this.model, 'change:published_at', this.render); } }, render: function () { var slug = this.model ? this.model.get('slug') : '', pubDate = this.model ? this.model.get('published_at') : 'Not Published', $pubDateEl = this.$('.post-setting-date'); $('.post-setting-slug').val(slug); // Insert the published date, and make it editable if it exists. if (this.model && this.model.get('published_at')) { pubDate = moment(pubDate).format('DD MMM YY'); } if (this.model && this.model.get('id')) { this.$('.delete').removeClass('hidden'); } $pubDateEl.val(pubDate); }, selectSlug: function (e) { e.currentTarget.select(); }, editSlug: function (e) { e.preventDefault(); var self = this, slug = self.model.get('slug'), slugEl = e.currentTarget, newSlug = slugEl.value; // Ignore empty or unchanged slugs if (newSlug.length === 0 || slug === newSlug) { slugEl.value = slug === undefined ? '' : slug; return; } this.model.save({ slug: newSlug }, { success : function (model, response, options) { // Repopulate slug in case it changed on the server (e.g. 'new-slug-2') slugEl.value = model.get('slug'); Ghost.notifications.addItem({ type: 'success', message: "Permalink successfully changed to " + model.get('slug') + '.', status: 'passive' }); }, error : function (model, xhr) { Ghost.notifications.addItem({ type: 'error', message: Ghost.Views.Utils.getRequestErrorMessage(xhr), status: 'passive' }); } }); }, editDate: function (e) { e.preventDefault(); var self = this, momentPubDate, errMessage = '', pubDate = self.model.get('published_at'), pubDateEl = e.currentTarget, newPubDate = pubDateEl.value; // Ensure the published date has changed if (newPubDate.length === 0 || pubDate === newPubDate) { pubDateEl.value = pubDate === undefined ? 'Not Published' : moment(pubDate).format("DD MMM YY"); return; } // Validate new Published date momentPubDate = moment(newPubDate, ["DD MMM YY", "DD MMM YYYY", "DD/MM/YY", "DD/MM/YYYY", "DD-MM-YY", "DD-MM-YYYY"]); if (!momentPubDate.isValid()) { errMessage = 'Published Date must be a valid date with format: DD MMM YY (e.g. 6 Dec 14)'; } if (momentPubDate.diff(new Date(), 'h') > 0) { errMessage = 'Published Date cannot currently be in the future.'; } if (errMessage.length) { Ghost.notifications.addItem({ type: 'error', message: errMessage, status: 'passive' }); pubDateEl.value = moment(pubDate).format("DD MMM YY"); return; } // Save new 'Published' date this.model.save({ // Temp Fix. Set hour to 12 instead of 00 to avoid some TZ issues. published_at: momentPubDate.hour(12).toDate() }, { success : function (model, response, options) { pubDateEl.value = moment(model.get('published_at')).format("DD MMM YY"); Ghost.notifications.addItem({ type: 'success', message: "Publish date successfully changed to " + pubDateEl.value + '.', status: 'passive' }); }, error : function (model, xhr) { Ghost.notifications.addItem({ type: 'error', message: Ghost.Views.Utils.getRequestErrorMessage(xhr), status: 'passive' }); } }); }, deletePost: function (e) { e.preventDefault(); var self = this; this.addSubview(new Ghost.Views.Modal({ model: { options: { close: false, confirm: { accept: { func: function () { self.model.destroy({ wait: true }).then(function () { // Redirect to content screen if deleting post from editor. if (window.location.pathname.indexOf('editor') > -1) { window.location = '/ghost/content/'; } Ghost.notifications.addItem({ type: 'success', message: 'Your post has been deleted.', status: 'passive' }); }, function () { Ghost.notifications.addItem({ type: 'error', message: 'Your post could not be deleted. Please try again.', status: 'passive' }); }); }, text: "Yes" }, reject: { func: function () { return true; }, text: "No" } }, type: "action", style: ["wide", "centered"], animation: 'fade' }, content: { template: 'blank', title: 'Are you sure you want to delete this post?' } } })); } }); }());