diff --git a/core/client/assets/sass/components/uploader.scss b/core/client/assets/sass/components/uploader.scss index 21ee1d7c87..fce5d1f80e 100644 --- a/core/client/assets/sass/components/uploader.scss +++ b/core/client/assets/sass/components/uploader.scss @@ -67,7 +67,6 @@ position:relative; z-index: 700; color: #fff; - padding-left:5px; } .btn-blue { margin: 0 0 0 10px; diff --git a/core/client/assets/sass/layouts/post-settings-menu.scss b/core/client/assets/sass/layouts/post-settings-menu.scss index e1750bcff3..73b34dc642 100644 --- a/core/client/assets/sass/layouts/post-settings-menu.scss +++ b/core/client/assets/sass/layouts/post-settings-menu.scss @@ -62,7 +62,11 @@ .image-uploader { padding-top: 35px; padding-bottom: 35px; - margin: 0 0 1.5rem 0; + margin: 0 0 1.6rem 0; + + input { + width: auto; + } } .form-group { @@ -76,8 +80,16 @@ .nav-list { margin-top: 3rem; } + + .pre-image-uploader { + width: auto; + min-height: 50px; + max-height: 250px; + } + } + .seo-preview { font-family: Arial, sans-serif; line-height: 1.46; diff --git a/core/client/components/gh-uploader.js b/core/client/components/gh-uploader.js new file mode 100644 index 0000000000..f0de6bfa9b --- /dev/null +++ b/core/client/components/gh-uploader.js @@ -0,0 +1,33 @@ +import uploader from 'ghost/assets/lib/uploader'; + +var PostImageUploader = Ember.Component.extend({ + classNames: ['image-uploader', 'js-post-image-upload'], + + setup: function () { + var $this = this.$(), + self = this; + + uploader.call($this, { + editor: true, + fileStorage: this.get('config.fileStorage') + }); + + $this.on('uploadsuccess', function (event, result) { + if (result && result !== '' && result !== 'http://') { + self.sendAction('uploaded', result); + } + }); + + $this.find('.js-cancel').on('click', function () { + self.sendAction('canceled'); + }); + }.on('didInsertElement'), + + removeListeners: function () { + var $this = this.$(); + $this.off(); + $this.find('.js-cancel').off(); + }.on('willDestroyElement') +}); + +export default PostImageUploader; \ No newline at end of file diff --git a/core/client/controllers/post-settings-menu.js b/core/client/controllers/post-settings-menu.js index 27c87391cc..e11193945b 100644 --- a/core/client/controllers/post-settings-menu.js +++ b/core/client/controllers/post-settings-menu.js @@ -19,7 +19,7 @@ var PostSettingsMenuController = Ember.ObjectController.extend({ selectedAuthor: null, initializeSelectedAuthor: function () { var self = this; - + return this.get('author').then(function (author) { self.set('selectedAuthor', author); return author; @@ -259,6 +259,36 @@ var PostSettingsMenuController = Ember.ObjectController.extend({ return; } + this.get('model').save(this.get('saveOptions')).catch(function (errors) { + self.showErrors(errors); + self.get('model').rollback(); + }); + }, + + setCoverImage: function (image) { + var self = this; + + this.set('image', image); + + if (this.get('isNew')) { + return; + } + + this.get('model').save(this.get('saveOptions')).catch(function (errors) { + self.showErrors(errors); + self.get('model').rollback(); + }); + }, + + clearCoverImage: function () { + var self = this; + + this.set('image', ''); + + if (this.get('isNew')) { + return; + } + this.get('model').save(this.get('saveOptions')).catch(function (errors) { self.showErrors(errors); self.get('model').rollback(); diff --git a/core/client/templates/components/gh-uploader.hbs b/core/client/templates/components/gh-uploader.hbs new file mode 100644 index 0000000000..dfd9759abf --- /dev/null +++ b/core/client/templates/components/gh-uploader.hbs @@ -0,0 +1,6 @@ + + Image Upload + + +