mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-04 08:54:36 +03:00
fb239054a0
follow up from #95 - converts components to use ember-cli-shims
107 lines
3.9 KiB
JavaScript
107 lines
3.9 KiB
JavaScript
import Component from 'ember-component';
|
|
import computed from 'ember-computed';
|
|
|
|
export default Component.extend({
|
|
tagName: 'section',
|
|
classNames: ['splitbtn', 'js-publish-splitbutton'],
|
|
classNameBindings: ['isNew:unsaved'],
|
|
|
|
isNew: null,
|
|
isPublished: null,
|
|
willPublish: null,
|
|
willSchedule: null,
|
|
timeScheduled: null,
|
|
postOrPage: null,
|
|
submitting: false,
|
|
statusFreeze: null,
|
|
scheduledWillPublish: false,
|
|
|
|
// Tracks whether we're going to change the state of the post on save
|
|
isDangerous: computed('isPublished', 'willPublish', 'willSchedule', 'isScheduled', 'scheduledWillPublish', 'statusFreeze', function () {
|
|
if (this.get('scheduledWillPublish')) {
|
|
if (this.get('willPublish') !== this.get('willSchedule')) {
|
|
return false;
|
|
} else {
|
|
return true;
|
|
}
|
|
} else {
|
|
if (this.get('isPublished') !== this.get('willPublish')) {
|
|
return true;
|
|
} else if (this.get('isScheduled') !== this.get('willSchedule')) {
|
|
return true;
|
|
} else if (this.get('statusFreeze')) {
|
|
// always show the save button in red, when we're 2 minutes before the scheduled date
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
}),
|
|
|
|
// Text for non-scheduled Posts
|
|
publishText: computed('isPublished', 'postOrPage', 'scheduledWillPublish', function () {
|
|
if (this.get('scheduledWillPublish')) {
|
|
return (this.get('willPublish') || this.get('willSchedule')) ? `Update ${this.get('postOrPage')}` : 'Publish Now';
|
|
} else {
|
|
return this.get('isPublished') ? `Update ${this.get('postOrPage')}` : 'Publish Now';
|
|
}
|
|
}),
|
|
|
|
draftText: computed('isPublished', 'scheduledWillPublish', function () {
|
|
if (this.get('scheduledWillPublish')) {
|
|
return (!this.get('willPublish') || !this.get('willSchedule')) ? 'Unpublish' : 'Save Draft';
|
|
} else {
|
|
return this.get('isPublished') ? 'Unpublish' : 'Save Draft';
|
|
}
|
|
}),
|
|
|
|
savePostText: computed('willPublish', 'publishText', 'postOrPage', 'draftText', 'scheduledWillPublish', 'willSchedule', function () {
|
|
// we have to show the menu for a published post when a scheduled post gets published while the user is in the
|
|
// editor and didn't refresh yet. To do so, we use the 'scheduledWillPublish' CP helper
|
|
if (this.get('scheduledWillPublish')) {
|
|
if (this.get('willSchedule') || this.get('willPublish')) {
|
|
return `Update ${this.get('postOrPage')}`;
|
|
} else {
|
|
return 'Unpublish';
|
|
}
|
|
} else {
|
|
return this.get('willPublish') ? this.get('publishText') : this.get('draftText');
|
|
}
|
|
}),
|
|
|
|
// Text for scheduled Posts
|
|
scheduleText: computed('isScheduled', 'postOrPage', function () {
|
|
return this.get('isScheduled') ? `Update ${this.get('postOrPage')}` : 'Schedule Post';
|
|
}),
|
|
|
|
unscheduleText: computed('isScheduled', function () {
|
|
return this.get('isScheduled') ? 'Unschedule' : 'Save Draft';
|
|
}),
|
|
|
|
saveScheduleText: computed('willSchedule', 'scheduleText', 'unscheduleText', function () {
|
|
return this.get('willSchedule') ? this.get('scheduleText') : this.get('unscheduleText');
|
|
}),
|
|
|
|
deleteText: computed('postOrPage', function () {
|
|
return `Delete ${this.get('postOrPage')}`;
|
|
}),
|
|
|
|
activeClass: computed('willPublish', 'willSchedule', function () {
|
|
return this.get('willPublish') || this.get('willSchedule') ? true : false;
|
|
}),
|
|
|
|
actions: {
|
|
save() {
|
|
this.sendAction('save');
|
|
},
|
|
|
|
setSaveType(saveType) {
|
|
this.sendAction('setSaveType', saveType);
|
|
},
|
|
|
|
delete() {
|
|
this.sendAction('delete');
|
|
}
|
|
}
|
|
});
|