2017-08-22 10:53:26 +03:00
|
|
|
import Component from '@ember/component';
|
2018-05-03 19:52:39 +03:00
|
|
|
import config from 'ghost-admin/config/environment';
|
2019-11-13 17:31:42 +03:00
|
|
|
import moment from 'moment';
|
|
|
|
import {computed} from '@ember/object';
|
|
|
|
import {inject as service} from '@ember/service';
|
2017-05-29 21:50:03 +03:00
|
|
|
import {task, timeout} from 'ember-concurrency';
|
2017-04-11 16:39:45 +03:00
|
|
|
|
|
|
|
export default Component.extend({
|
2019-11-13 17:31:42 +03:00
|
|
|
clock: service(),
|
2019-11-13 19:10:29 +03:00
|
|
|
|
2017-04-11 16:39:45 +03:00
|
|
|
post: null,
|
|
|
|
isSaving: false,
|
|
|
|
|
|
|
|
'data-test-editor-post-status': true,
|
|
|
|
|
|
|
|
_isSaving: false,
|
|
|
|
|
2019-11-13 17:31:42 +03:00
|
|
|
countdown: computed('post.{publishedAtUTC,isScheduled}', 'clock.second', function () {
|
|
|
|
let isScheduled = this.get('post.isScheduled');
|
|
|
|
let publishTime = this.get('post.publishedAtUTC') || moment.utc();
|
|
|
|
|
|
|
|
let timeUntilPublished = publishTime.diff(moment.utc(), 'minutes', true);
|
|
|
|
let isPublishedSoon = timeUntilPublished > 0 && timeUntilPublished < 15;
|
|
|
|
|
|
|
|
// force a recompute
|
|
|
|
this.get('clock.second');
|
|
|
|
|
|
|
|
if (isScheduled && isPublishedSoon) {
|
|
|
|
return moment(publishTime).fromNow();
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}),
|
|
|
|
|
2017-04-11 16:39:45 +03:00
|
|
|
// isSaving will only be true briefly whilst the post is saving,
|
|
|
|
// we want to ensure that the "Saving..." message is shown for at least
|
|
|
|
// a few seconds so that it's noticeable
|
|
|
|
didReceiveAttrs() {
|
2019-03-06 16:53:54 +03:00
|
|
|
if (this.isSaving) {
|
|
|
|
this.showSavingMessage.perform();
|
2017-04-11 16:39:45 +03:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
showSavingMessage: task(function* () {
|
|
|
|
this.set('_isSaving', true);
|
2018-05-03 19:52:39 +03:00
|
|
|
yield timeout(config.environment === 'test' ? 0 : 3000);
|
2019-12-17 12:57:37 +03:00
|
|
|
|
|
|
|
if (!this.isDestroyed && !this.isDestroying) {
|
|
|
|
this.set('_isSaving', false);
|
|
|
|
}
|
2017-04-11 16:39:45 +03:00
|
|
|
}).drop()
|
|
|
|
});
|