0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00

Merge pull request #5348 from jaswilli/es6-ajax

ES6 module version of ic-ajax instead of global
This commit is contained in:
Matt Enlow 2015-05-27 09:34:00 +02:00
commit 3ece83f68d
18 changed files with 101 additions and 122 deletions

View file

@ -6,7 +6,6 @@
"-Notification",
"$",
"validator",
"ic",
"moment"
],
"browser": true,

View file

@ -36,7 +36,6 @@ app = new EmberApp({
// 'dem Scripts
app.import('bower_components/loader.js/loader.js');
app.import('bower_components/jquery/dist/jquery.js');
app.import('bower_components/ic-ajax/dist/globals/main.js');
app.import('bower_components/ember-load-initializers/ember-load-initializers.js');
app.import('bower_components/validator-js/validator.js');
app.import('bower_components/rangyinputs/rangyinputs-jquery-src.js');

View file

@ -1,10 +1,12 @@
import Ember from 'ember';
var DeleteAllController = Ember.Controller.extend({
import {request as ajax} from 'ic-ajax';
export default Ember.Controller.extend({
actions: {
confirmAccept: function () {
var self = this;
ic.ajax.request(this.get('ghostPaths.url').api('db'), {
ajax(this.get('ghostPaths.url').api('db'), {
type: 'DELETE'
}).then(function () {
self.notifications.showSuccess('All content deleted from database.');
@ -31,5 +33,3 @@ var DeleteAllController = Ember.Controller.extend({
}
}
});
export default DeleteAllController;

View file

@ -1,5 +1,7 @@
import Ember from 'ember';
var TransferOwnerController = Ember.Controller.extend({
import {request as ajax} from 'ic-ajax';
export default Ember.Controller.extend({
actions: {
confirmAccept: function () {
var user = this.get('model'),
@ -8,7 +10,7 @@ var TransferOwnerController = Ember.Controller.extend({
self.get('dropdown').closeDropdowns();
ic.ajax.request(url, {
ajax(url, {
type: 'PUT',
data: {
owner: [{
@ -49,5 +51,3 @@ var TransferOwnerController = Ember.Controller.extend({
}
}
});
export default TransferOwnerController;

View file

@ -1,60 +1,58 @@
import Ember from 'ember';
import ajax from 'ghost/utils/ajax';
import ValidationEngine from 'ghost/mixins/validation-engine';
var ResetController = Ember.Controller.extend(ValidationEngine, {
newPassword: '',
ne2Password: '',
token: '',
submitting: false,
validationType: 'reset',
email: Ember.computed('token', function () {
// The token base64 encodes the email (and some other stuff),
// each section is divided by a '|'. Email comes second.
return atob(this.get('token')).split('|')[1];
}),
// Used to clear sensitive information
clearData: function () {
this.setProperties({
newPassword: '',
ne2Password: '',
token: ''
});
},
actions: {
submit: function () {
var credentials = this.getProperties('newPassword', 'ne2Password', 'token'),
self = this;
this.toggleProperty('submitting');
this.validate({format: false}).then(function () {
ajax({
url: self.get('ghostPaths.url').api('authentication', 'passwordreset'),
type: 'PUT',
data: {
passwordreset: [credentials]
}
}).then(function (resp) {
self.toggleProperty('submitting');
self.notifications.showSuccess(resp.passwordreset[0].message, true);
self.get('session').authenticate('simple-auth-authenticator:oauth2-password-grant', {
identification: self.get('email'),
password: credentials.newPassword
});
}).catch(function (response) {
self.notifications.showAPIError(response);
self.toggleProperty('submitting');
});
}).catch(function (error) {
self.toggleProperty('submitting');
self.notifications.showErrors(error);
});
}
}
});
export default ResetController;
import {request as ajax} from 'ic-ajax';
import ValidationEngine from 'ghost/mixins/validation-engine';
export default Ember.Controller.extend(ValidationEngine, {
newPassword: '',
ne2Password: '',
token: '',
submitting: false,
validationType: 'reset',
email: Ember.computed('token', function () {
// The token base64 encodes the email (and some other stuff),
// each section is divided by a '|'. Email comes second.
return atob(this.get('token')).split('|')[1];
}),
// Used to clear sensitive information
clearData: function () {
this.setProperties({
newPassword: '',
ne2Password: '',
token: ''
});
},
actions: {
submit: function () {
var credentials = this.getProperties('newPassword', 'ne2Password', 'token'),
self = this;
this.toggleProperty('submitting');
this.validate({format: false}).then(function () {
ajax({
url: self.get('ghostPaths.url').api('authentication', 'passwordreset'),
type: 'PUT',
data: {
passwordreset: [credentials]
}
}).then(function (resp) {
self.toggleProperty('submitting');
self.notifications.showSuccess(resp.passwordreset[0].message, true);
self.get('session').authenticate('simple-auth-authenticator:oauth2-password-grant', {
identification: self.get('email'),
password: credentials.newPassword
});
}).catch(function (response) {
self.notifications.showAPIError(response);
self.toggleProperty('submitting');
});
}).catch(function (error) {
self.toggleProperty('submitting');
self.notifications.showErrors(error);
});
}
}
});

View file

@ -1,5 +1,7 @@
import Ember from 'ember';
var LabsController = Ember.Controller.extend(Ember.Evented, {
import {request as ajax} from 'ic-ajax';
export default Ember.Controller.extend(Ember.Evented, {
needs: ['feature'],
uploadButtonText: 'Import',
@ -34,7 +36,7 @@ var LabsController = Ember.Controller.extend(Ember.Evented, {
formData.append('importfile', file);
ic.ajax.request(this.get('ghostPaths.url').api('db'), {
ajax(this.get('ghostPaths.url').api('db'), {
type: 'POST',
data: formData,
dataType: 'json',
@ -77,7 +79,7 @@ var LabsController = Ember.Controller.extend(Ember.Evented, {
sendTestEmail: function () {
var self = this;
ic.ajax.request(this.get('ghostPaths.url').api('mail', 'test'), {
ajax(this.get('ghostPaths.url').api('mail', 'test'), {
type: 'POST'
}).then(function () {
self.notifications.showSuccess('Check your email for the test message.');
@ -91,5 +93,3 @@ var LabsController = Ember.Controller.extend(Ember.Evented, {
}
}
});
export default LabsController;

View file

@ -1,8 +1,8 @@
import Ember from 'ember';
import ajax from 'ghost/utils/ajax';
import {request as ajax} from 'ic-ajax';
import ValidationEngine from 'ghost/mixins/validation-engine';
var SetupController = Ember.Controller.extend(ValidationEngine, {
export default Ember.Controller.extend(ValidationEngine, {
blogTitle: null,
name: null,
email: null,
@ -48,5 +48,3 @@ var SetupController = Ember.Controller.extend(ValidationEngine, {
}
}
});
export default SetupController;

View file

@ -1,8 +1,8 @@
import Ember from 'ember';
import ValidationEngine from 'ghost/mixins/validation-engine';
import ajax from 'ghost/utils/ajax';
import {request as ajax} from 'ic-ajax';
var SigninController = Ember.Controller.extend(ValidationEngine, {
export default Ember.Controller.extend(ValidationEngine, {
validationType: 'signin',
submitting: false,
@ -63,5 +63,3 @@ var SigninController = Ember.Controller.extend(ValidationEngine, {
}
}
});
export default SigninController;

View file

@ -1,8 +1,8 @@
import Ember from 'ember';
import ajax from 'ghost/utils/ajax';
import {request as ajax} from 'ic-ajax';
import ValidationEngine from 'ghost/mixins/validation-engine';
var SignupController = Ember.Controller.extend(ValidationEngine, {
export default Ember.Controller.extend(ValidationEngine, {
submitting: false,
// ValidationEngine settings
@ -46,5 +46,3 @@ var SignupController = Ember.Controller.extend(ValidationEngine, {
}
}
});
export default SignupController;

View file

@ -1,7 +1,7 @@
import Ember from 'ember';
import { getRequestErrorMessage } from 'ghost/utils/ajax';
import getRequestErrorMessage from 'ghost/utils/ajax';
var PaginationControllerMixin = Ember.Mixin.create({
export default Ember.Mixin.create({
// set from PaginationRouteMixin
paginationSettings: null,
@ -57,5 +57,3 @@ var PaginationControllerMixin = Ember.Mixin.create({
}
}
});
export default PaginationControllerMixin;

View file

@ -1,6 +1,6 @@
import Ember from 'ember';
import DS from 'ember-data';
import {getRequestErrorMessage} from 'ghost/utils/ajax';
import getRequestErrorMessage from 'ghost/utils/ajax';
import ValidatorExtensions from 'ghost/utils/validator-extensions';
import PostValidator from 'ghost/validators/post';
@ -61,7 +61,7 @@ function formatErrors(errors, opts) {
* It will be able to validate any properties on itself (or the model it passes to validate())
* with the use of a declared validator.
*/
var ValidationEngine = Ember.Mixin.create({
export default Ember.Mixin.create({
// these validators can be passed a model to validate when the class that
// mixes in the ValidationEngine declares a validationType equal to a key on this object.
// the model is either passed in via `this.validate({ model: object })`
@ -174,5 +174,3 @@ var ValidationEngine = Ember.Mixin.create({
});
}
});
export default ValidationEngine;

View file

@ -1,11 +1,15 @@
import Ember from 'ember';
var SlugGenerator = Ember.Object.extend({
import {request as ajax} from 'ic-ajax';
export default Ember.Object.extend({
ghostPaths: null,
slugType: null,
value: null,
toString: function () {
return this.get('value');
},
generateSlug: function (textToSlugify) {
var self = this,
url;
@ -16,14 +20,14 @@ var SlugGenerator = Ember.Object.extend({
url = this.get('ghostPaths.url').api('slugs', this.get('slugType'), encodeURIComponent(textToSlugify));
return ic.ajax.request(url, {
return ajax(url, {
type: 'GET'
}).then(function (response) {
var slug = response.slugs[0].slug;
self.set('value', slug);
return slug;
});
}
});
export default SlugGenerator;

View file

@ -1,9 +1,10 @@
import Ember from 'ember';
import DS from 'ember-data';
import {request as ajax} from 'ic-ajax';
import ValidationEngine from 'ghost/mixins/validation-engine';
import SelectiveSaveMixin from 'ghost/mixins/selective-save';
var User = DS.Model.extend(SelectiveSaveMixin, ValidationEngine, {
export default DS.Model.extend(SelectiveSaveMixin, ValidationEngine, {
validationType: 'user',
uuid: DS.attr('string'),
@ -49,7 +50,7 @@ var User = DS.Model.extend(SelectiveSaveMixin, ValidationEngine, {
saveNewPassword: function () {
var url = this.get('ghostPaths.url').api('users', 'password');
return ic.ajax.request(url, {
return ajax(url, {
type: 'PUT',
data: {
password: [{
@ -69,7 +70,7 @@ var User = DS.Model.extend(SelectiveSaveMixin, ValidationEngine, {
roles: fullUserData.roles
};
return ic.ajax.request(this.get('ghostPaths.url').api('users'), {
return ajax(this.get('ghostPaths.url').api('users'), {
type: 'POST',
data: JSON.stringify({users: [userData]}),
contentType: 'application/json'
@ -102,5 +103,3 @@ var User = DS.Model.extend(SelectiveSaveMixin, ValidationEngine, {
pending: Ember.computed.equal('status', 'invited-pending').property('status')
});
export default User;

View file

@ -1,3 +1,4 @@
import {request as ajax} from 'ic-ajax';
import AuthenticatedRoute from 'ghost/routes/authenticated';
import styleBody from 'ghost/mixins/style-body';
@ -16,7 +17,7 @@ export default AuthenticatedRoute.extend(styleBody, {
return cachedConfig;
}
return ic.ajax.request(this.get('ghostPaths.url').api('configuration'))
return ajax(this.get('ghostPaths.url').api('configuration'))
.then(function (configurationResponse) {
var configKeyValues = configurationResponse.configuration;

View file

@ -1,8 +1,9 @@
import Ember from 'ember';
import {request as ajax} from 'ic-ajax';
import Configuration from 'simple-auth/configuration';
import styleBody from 'ghost/mixins/style-body';
var SetupRoute = Ember.Route.extend(styleBody, {
export default Ember.Route.extend(styleBody, {
titleToken: 'Setup',
classNames: ['ghost-setup'],
@ -20,7 +21,7 @@ var SetupRoute = Ember.Route.extend(styleBody, {
}
// If user is not logged in, check the state of the setup process via the API
return ic.ajax.request(this.get('ghostPaths.url').api('authentication/setup'), {
return ajax(this.get('ghostPaths.url').api('authentication/setup'), {
type: 'GET'
}).then(function (result) {
var setup = result.setup[0].status;
@ -31,5 +32,3 @@ var SetupRoute = Ember.Route.extend(styleBody, {
});
}
});
export default SetupRoute;

View file

@ -1,8 +1,9 @@
import Ember from 'ember';
import {request as ajax} from 'ic-ajax';
import Configuration from 'simple-auth/configuration';
import styleBody from 'ghost/mixins/style-body';
var SignupRoute = Ember.Route.extend(styleBody, {
export default Ember.Route.extend(styleBody, {
classNames: ['ghost-signup'],
beforeModel: function () {
@ -32,7 +33,7 @@ var SignupRoute = Ember.Route.extend(styleBody, {
model.set('email', email);
model.set('token', params.token);
return ic.ajax.request({
return ajax({
url: self.get('ghostPaths.url').api('authentication', 'invitation'),
type: 'GET',
dataType: 'json',
@ -60,5 +61,3 @@ var SignupRoute = Ember.Route.extend(styleBody, {
this.controllerFor('signup').setProperties({email: '', password: '', token: ''});
}
});
export default SignupRoute;

View file

@ -1,13 +1,8 @@
import Ember from 'ember';
/* global ic */
var ajax = function () {
return ic.ajax.request.apply(null, arguments);
};
// Used in API request fail handlers to parse a standard api error
// response json for the message to display
function getRequestErrorMessage(request, performConcat) {
export default function getRequestErrorMessage(request, performConcat) {
var message,
msgDetail;
@ -47,6 +42,3 @@ function getRequestErrorMessage(request, performConcat) {
return message;
}
export {getRequestErrorMessage, ajax};
export default ajax;

View file

@ -10,7 +10,6 @@
"ember-simple-auth": "0.8.0-beta.2",
"fastclick": "1.0.6",
"google-caja": "5669.0.0",
"ic-ajax": "2.0.2",
"jquery": "1.11.2",
"jquery-file-upload": "9.5.6",
"jquery-hammerjs": "1.0.1",