mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 10:59:30 +03:00
cb59388c5b
no issue - adds `eslint-plugin-sort-imports-es6-autofix` dependency - implements ESLint's base `sort-imports` rule but has a distinction in that `import {foo} from 'bar';` is considered `multiple` rather than `single` - fixes ESLint's autofix behaviour so `eslint --fix` will actually fix the sort order - updates all unordered import rules by using `eslint --fix` With the increased number of `import` statements since Ember+ecosystem started moving towards es6 modules I've found it frustrating at times trying to search through randomly ordered import statements. Recently I've been sorting imports manually when I've added new code or touched old code so I thought I'd add an ESLint rule to codify it.
103 lines
2.7 KiB
JavaScript
103 lines
2.7 KiB
JavaScript
import ModalComponent from 'ghost-admin/components/modals/base';
|
|
import cajaSanitizers from 'ghost-admin/utils/caja-sanitizers';
|
|
import computed from 'ember-computed';
|
|
import injectService from 'ember-service/inject';
|
|
import {isEmpty} from 'ember-utils';
|
|
import {task} from 'ember-concurrency';
|
|
|
|
export default ModalComponent.extend({
|
|
model: null,
|
|
|
|
url: '',
|
|
newUrl: '',
|
|
|
|
config: injectService(),
|
|
notifications: injectService(),
|
|
|
|
image: computed('model.model', 'model.imageProperty', {
|
|
get() {
|
|
let imageProperty = this.get('model.imageProperty');
|
|
|
|
return this.get(`model.model.${imageProperty}`);
|
|
},
|
|
|
|
set(key, value) {
|
|
let model = this.get('model.model');
|
|
let imageProperty = this.get('model.imageProperty');
|
|
|
|
return model.set(imageProperty, value);
|
|
}
|
|
}),
|
|
|
|
didReceiveAttrs() {
|
|
let image = this.get('image');
|
|
this.set('url', image);
|
|
this.set('newUrl', image);
|
|
},
|
|
|
|
// TODO: should validation be handled in the gh-image-uploader component?
|
|
// pro - consistency everywhere, simplification here
|
|
// con - difficult if the "save" is happening externally as it does here
|
|
//
|
|
// maybe it should be handled at the model level?
|
|
// - automatically present everywhere
|
|
// - file uploads should always result in valid urls so it should only
|
|
// affect the url input form
|
|
keyDown() {
|
|
this._setErrorState(false);
|
|
},
|
|
|
|
_setErrorState(state) {
|
|
if (state) {
|
|
this.$('.url').addClass('error');
|
|
} else {
|
|
this.$('.url').removeClass('error');
|
|
}
|
|
},
|
|
|
|
_validateUrl(url) {
|
|
if (!isEmpty(url) && !cajaSanitizers.url(url)) {
|
|
this._setErrorState(true);
|
|
return {message: 'Image URI is not valid'};
|
|
}
|
|
|
|
return true;
|
|
},
|
|
// end validation
|
|
|
|
uploadImage: task(function* () {
|
|
let model = this.get('model.model');
|
|
let newUrl = this.get('newUrl');
|
|
let result = this._validateUrl(newUrl);
|
|
let notifications = this.get('notifications');
|
|
|
|
if (result === true) {
|
|
this.set('image', newUrl);
|
|
|
|
try {
|
|
yield model.save();
|
|
} catch (e) {
|
|
notifications.showAPIError(e, {key: 'image.upload'});
|
|
} finally {
|
|
this.send('closeModal');
|
|
}
|
|
}
|
|
}).drop(),
|
|
|
|
actions: {
|
|
fileUploaded(url) {
|
|
this.set('url', url);
|
|
this.set('newUrl', url);
|
|
},
|
|
|
|
removeImage() {
|
|
this.set('url', '');
|
|
this.set('newUrl', '');
|
|
},
|
|
|
|
confirm() {
|
|
this.get('uploadImage').perform();
|
|
}
|
|
}
|
|
});
|