mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-07 11:30:55 +03:00
Ensure slug generation has completed prior to save
Refs #4307 Refs #4259 - Make sure that a slug has been generated prior to the first save that occurs on a post. - Wait on in-flight slug generation requests before saving.
This commit is contained in:
parent
7e123c8665
commit
2369080572
@ -7,6 +7,8 @@ var PostSettingsMenuController = Ember.ObjectController.extend({
|
||||
//State for if the user is viewing a tab's pane.
|
||||
needs: 'application',
|
||||
|
||||
lastPromise: null,
|
||||
|
||||
isViewingSubview: Ember.computed('controllers.application.showRightOutlet', function (key, value) {
|
||||
// Not viewing a subview if we can't even see the PSM
|
||||
if (!this.get('controllers.application.showRightOutlet')) {
|
||||
@ -89,11 +91,22 @@ var PostSettingsMenuController = Ember.ObjectController.extend({
|
||||
//Requests slug from title
|
||||
generateAndSetSlug: function (destination) {
|
||||
var self = this,
|
||||
title = this.get('titleScratch');
|
||||
title = this.get('titleScratch'),
|
||||
afterSave = this.get('lastPromise'),
|
||||
promise;
|
||||
|
||||
this.get('slugGenerator').generateSlug(title).then(function (slug) {
|
||||
// Only set an "untitled" slug once per post
|
||||
if (title === '(Untitled)' && this.get('slug')) {
|
||||
return;
|
||||
}
|
||||
|
||||
promise = Ember.RSVP.resolve(afterSave).then(function () {
|
||||
return self.get('slugGenerator').generateSlug(title).then(function (slug) {
|
||||
self.set(destination, slug);
|
||||
});
|
||||
});
|
||||
|
||||
this.set('lastPromise', promise);
|
||||
},
|
||||
|
||||
metaTitleScratch: boundOneWay('meta_title'),
|
||||
@ -168,11 +181,15 @@ var PostSettingsMenuController = Ember.ObjectController.extend({
|
||||
}
|
||||
}.observes('model'),
|
||||
titleObserver: function () {
|
||||
var debounceId;
|
||||
|
||||
if (this.get('isNew') && !this.get('title')) {
|
||||
Ember.run.debounce(this, 'generateAndSetSlug', ['slugPlaceholder'], 700);
|
||||
debounceId = Ember.run.debounce(this, 'generateAndSetSlug', ['slugPlaceholder'], 700);
|
||||
} else if (this.get('title') === '(Untitled)') {
|
||||
Ember.run.debounce(this, 'generateAndSetSlug', ['slug'], 700);
|
||||
debounceId = Ember.run.debounce(this, 'generateAndSetSlug', ['slug'], 700);
|
||||
}
|
||||
|
||||
this.set('debounceId', debounceId);
|
||||
},
|
||||
slugPlaceholder: Ember.computed(function (key, value) {
|
||||
var slug = this.get('slug');
|
||||
|
@ -12,7 +12,7 @@ PostModel.eachAttribute(function (name) {
|
||||
});
|
||||
|
||||
var EditorControllerMixin = Ember.Mixin.create(MarkerManager, {
|
||||
needs: ['post-tags-input'],
|
||||
needs: ['post-tags-input', 'post-settings-menu'],
|
||||
|
||||
init: function () {
|
||||
var self = this;
|
||||
@ -195,7 +195,9 @@ var EditorControllerMixin = Ember.Mixin.create(MarkerManager, {
|
||||
prevStatus = this.get('status'),
|
||||
isNew = this.get('isNew'),
|
||||
autoSaveId = this.get('autoSaveId'),
|
||||
self = this;
|
||||
self = this,
|
||||
psmController = this.get('controllers.post-settings-menu'),
|
||||
promise;
|
||||
|
||||
options = options || {};
|
||||
|
||||
@ -221,11 +223,21 @@ var EditorControllerMixin = Ember.Mixin.create(MarkerManager, {
|
||||
|
||||
this.set('title', this.get('titleScratch'));
|
||||
|
||||
return this.get('model').save(options).then(function (model) {
|
||||
if (!this.get('slug')) {
|
||||
// Cancel any pending slug generation that may still be queued in the
|
||||
// run loop because we need to run it before the post is saved.
|
||||
Ember.run.cancel(psmController.get('debounceId'));
|
||||
|
||||
psmController.generateAndSetSlug('slug');
|
||||
}
|
||||
|
||||
promise = Ember.RSVP.resolve(psmController.get('lastPromise')).then(function () {
|
||||
return self.get('model').save(options).then(function (model) {
|
||||
if (!options.silent) {
|
||||
self.showSaveNotification(prevStatus, model.get('status'), isNew ? true : false);
|
||||
}
|
||||
return model;
|
||||
});
|
||||
}).catch(function (errors) {
|
||||
if (!options.silent) {
|
||||
self.showErrorNotification(prevStatus, self.get('status'), errors);
|
||||
@ -234,6 +246,10 @@ var EditorControllerMixin = Ember.Mixin.create(MarkerManager, {
|
||||
|
||||
return Ember.RSVP.reject(errors);
|
||||
});
|
||||
|
||||
psmController.set('lastPromise', promise);
|
||||
|
||||
return promise;
|
||||
},
|
||||
|
||||
setSaveType: function (newType) {
|
||||
|
Loading…
Reference in New Issue
Block a user