0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-06 22:40:14 -05:00

Use private properties for unobserved render state

* Drop set for local private editor property
* Only run preview setup on didInsertElement
* Drop set for local scrollWrapper prop
* Selectize setup on afterRender instead of next
* Use local props for editor save timers
This commit is contained in:
Matthew Beale 2015-11-20 11:40:41 -05:00
parent 89030580b8
commit 2fa9a2e98a
6 changed files with 28 additions and 27 deletions

View file

@ -8,7 +8,7 @@ export default Ember.Component.extend({
isFocused: false,
value: '', // make sure a value exists
editor: null, // reference to CodeMirror editor
_editor: null, // reference to CodeMirror editor
// options for the editor
lineNumbers: true,
@ -31,13 +31,13 @@ export default Ember.Component.extend({
});
});
this.set('editor', editor);
this._editor = editor;
},
willDestroyElement: function () {
var editor = this.get('editor').getWrapperElement();
var editor = this._editor.getWrapperElement();
editor.parentNode.removeChild(editor);
this.set('editor', null);
this._editor = null;
}
});

View file

@ -6,7 +6,7 @@ export default Ember.Component.extend({
content: null,
didRender: function () {
didInsertElement: function () {
var el = this.$();
el.on('scroll', Ember.run.bind(el, setScrollClassName, {

View file

@ -4,8 +4,10 @@ import uploader from 'ghost/assets/lib/uploader';
export default Ember.Component.extend({
config: Ember.inject.service(),
_scrollWrapper: null,
didInsertElement: function () {
this.set('scrollWrapper', this.$().closest('.entry-preview-content'));
this._scrollWrapper = this.$().closest('.entry-preview-content');
this.adjustScrollPosition(this.get('scrollPosition'));
Ember.run.scheduleOnce('afterRender', this, this.dropzoneHandler);
},
@ -23,7 +25,7 @@ export default Ember.Component.extend({
},
adjustScrollPosition: function (scrollPosition) {
var scrollWrapper = this.get('scrollWrapper');
var scrollWrapper = this._scrollWrapper;
if (scrollWrapper) {
scrollWrapper.scrollTop(scrollPosition);

View file

@ -1,4 +1,3 @@
/* global md5 */
import Ember from 'ember';
/**
@ -27,6 +26,12 @@ export default Ember.Component.extend({
ghostPaths: Ember.inject.service('ghost-paths'),
displayGravatar: Ember.computed.notEmpty('validEmail'),
init: function () {
this._super(...arguments);
// Fire this immediately in case we're initialized with a valid email
this.trySetValidEmail();
},
defaultImage: Ember.computed('ghostPaths', function () {
const url = this.get('ghostPaths.url').asset('/shared/img/user-image.png');
return Ember.String.htmlSafe(`background-image: url(${url})`);
@ -50,7 +55,7 @@ export default Ember.Component.extend({
let style = '';
if (email) {
let url = `http://www.gravatar.com/avatar/${md5(email)}?s=${size}&d=blank`;
let url = `http://www.gravatar.com/avatar/${window.md5(email)}?s=${size}&d=blank`;
style = `background-image: url(${url})`;
}
return Ember.String.htmlSafe(style);
@ -60,9 +65,6 @@ export default Ember.Component.extend({
var size = this.get('size'),
uploadElement = this.$('.js-file-input');
// Fire this immediately in case we're initialized with a valid email
this.trySetValidEmail();
// while theoretically the 'add' and 'processalways' functions could be
// added as properties of the hash passed to fileupload(), for some reason
// they needed to be placed in an on() call for the add method to work correctly

View file

@ -15,7 +15,7 @@ export default EmberSelectizeComponent.extend({
var openOnFocus = this.get('openOnFocus');
if (!openOnFocus) {
Ember.run.next(this, function () {
Ember.run.schedule('afterRender', this, function () {
var selectize = this._selectize;
if (selectize) {
selectize.on('dropdown_open', function () {

View file

@ -14,20 +14,17 @@ PostModel.eachAttribute(function (name) {
export default Ember.Mixin.create({
postSettingsMenuController: Ember.inject.controller('post-settings-menu'),
autoSaveId: null,
timedSaveId: null,
_autoSaveId: null,
_timedSaveId: null,
editor: null,
submitting: false,
notifications: Ember.inject.service(),
init: function () {
var self = this;
this._super();
window.onbeforeunload = function () {
return self.get('hasDirtyAttributes') ? self.unloadDirtyMessage() : null;
this._super(...arguments);
window.onbeforeunload = () => {
return this.get('hasDirtyAttributes') ? this.unloadDirtyMessage() : null;
};
},
@ -47,10 +44,10 @@ export default Ember.Mixin.create({
};
timedSaveId = Ember.run.throttle(this, 'send', 'save', saveOptions, 60000, false);
this.set('timedSaveId', timedSaveId);
this._timedSaveId = timedSaveId;
autoSaveId = Ember.run.debounce(this, 'send', 'save', saveOptions, 3000);
this.set('autoSaveId', autoSaveId);
this._autoSaveId = autoSaveId;
}
}),
@ -254,8 +251,8 @@ export default Ember.Mixin.create({
var status,
prevStatus = this.get('model.status'),
isNew = this.get('model.isNew'),
autoSaveId = this.get('autoSaveId'),
timedSaveId = this.get('timedSaveId'),
autoSaveId = this._autoSaveId,
timedSaveId = this._timedSaveId,
self = this,
psmController = this.get('postSettingsMenuController'),
promise;
@ -280,12 +277,12 @@ export default Ember.Mixin.create({
if (autoSaveId) {
Ember.run.cancel(autoSaveId);
this.set('autoSaveId', null);
this._autoSaveId = null;
}
if (timedSaveId) {
Ember.run.cancel(timedSaveId);
this.set('timedSaveId', null);
this._timedSaveId = null;
}
// Set the properties that are indirected