2015-02-13 07:22:32 +03:00
|
|
|
import Ember from 'ember';
|
2014-09-16 02:46:40 +04:00
|
|
|
import uploader from 'ghost/assets/lib/uploader';
|
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
const {Component, computed, get, inject, isEmpty, run} = Ember;
|
|
|
|
|
|
|
|
export default Component.extend({
|
2014-09-16 02:46:40 +04:00
|
|
|
classNames: ['image-uploader', 'js-post-image-upload'],
|
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
config: inject.service(),
|
2015-05-26 05:10:50 +03:00
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
imageSource: computed('image', function () {
|
2015-02-09 18:57:50 +03:00
|
|
|
return this.get('image') || '';
|
|
|
|
}),
|
|
|
|
|
2015-06-03 05:56:42 +03:00
|
|
|
// removes event listeners from the uploader
|
2015-10-28 14:36:45 +03:00
|
|
|
removeListeners() {
|
|
|
|
let $this = this.$();
|
2014-10-25 01:09:50 +04:00
|
|
|
|
2014-09-16 02:46:40 +04:00
|
|
|
$this.off();
|
|
|
|
$this.find('.js-cancel').off();
|
2015-06-03 05:56:42 +03:00
|
|
|
},
|
|
|
|
|
2015-09-29 16:53:38 +03:00
|
|
|
// NOTE: because the uploader is sometimes in the same place in the DOM
|
|
|
|
// between transitions Glimmer will re-use the existing elements including
|
|
|
|
// those that arealready decorated by jQuery. The following works around
|
|
|
|
// situations where the image is changed without a full teardown/rebuild
|
2015-10-28 14:36:45 +03:00
|
|
|
didReceiveAttrs(attrs) {
|
|
|
|
let oldValue = attrs.oldAttrs && get(attrs.oldAttrs, 'image.value');
|
|
|
|
let newValue = attrs.newAttrs && get(attrs.newAttrs, 'image.value');
|
2015-09-29 16:53:38 +03:00
|
|
|
|
2015-11-15 14:06:49 +03:00
|
|
|
this._super(...arguments);
|
|
|
|
|
2015-09-29 16:53:38 +03:00
|
|
|
// always reset when we receive a blank image
|
|
|
|
// - handles navigating to populated image from blank image
|
2015-10-28 14:36:45 +03:00
|
|
|
if (isEmpty(newValue) && !isEmpty(oldValue)) {
|
|
|
|
this.$()[0].uploaderUi.reset();
|
2015-09-29 16:53:38 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// re-init if we receive a new image but the uploader is blank
|
|
|
|
// - handles back button navigating from blank image to populated image
|
2015-10-28 14:36:45 +03:00
|
|
|
if (!isEmpty(newValue) && this.$()) {
|
2015-09-29 16:53:38 +03:00
|
|
|
if (this.$('.js-upload-target').attr('src') === '') {
|
|
|
|
this.$()[0].uploaderUi.reset();
|
|
|
|
this.$()[0].uploaderUi.initWithImage();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
didInsertElement() {
|
2015-11-15 14:06:49 +03:00
|
|
|
this._super(...arguments);
|
2015-10-15 15:03:26 +03:00
|
|
|
this.send('initUploader');
|
|
|
|
},
|
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
willDestroyElement() {
|
2015-11-15 14:06:49 +03:00
|
|
|
this._super(...arguments);
|
2015-10-15 15:03:26 +03:00
|
|
|
this.removeListeners();
|
|
|
|
},
|
|
|
|
|
2015-06-13 17:34:09 +03:00
|
|
|
actions: {
|
2015-10-28 14:36:45 +03:00
|
|
|
initUploader() {
|
|
|
|
let el = this.$();
|
|
|
|
let ref = uploader.call(el, {
|
2015-06-13 17:34:09 +03:00
|
|
|
editor: true,
|
|
|
|
fileStorage: this.get('config.fileStorage')
|
|
|
|
});
|
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
el.on('uploadsuccess', (event, result) => {
|
2015-06-13 17:34:09 +03:00
|
|
|
if (result && result !== '' && result !== 'http://') {
|
2015-10-28 14:36:45 +03:00
|
|
|
run(this, function () {
|
2015-10-15 15:03:26 +03:00
|
|
|
this.sendAction('uploaded', result);
|
|
|
|
});
|
2015-06-13 17:34:09 +03:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
el.on('imagecleared', run.bind(this, 'sendAction', 'canceled'));
|
2015-06-13 17:34:09 +03:00
|
|
|
|
2015-10-08 21:57:41 +03:00
|
|
|
this.sendAction('initUploader', ref);
|
2015-06-13 17:34:09 +03:00
|
|
|
}
|
2015-06-03 05:56:42 +03:00
|
|
|
}
|
2014-09-16 02:46:40 +04:00
|
|
|
});
|