diff --git a/app/adapters/ssh-key.coffee b/app/adapters/ssh-key.coffee index 68c47949..f4bad312 100644 --- a/app/adapters/ssh-key.coffee +++ b/app/adapters/ssh-key.coffee @@ -4,11 +4,21 @@ Adapter = ApplicationAdapter.extend namespace: 'settings' + find: (store, type, id, record) -> + @ajax(this.urlPrefix() + '/ssh_key/' + id, 'GET') + + deleteRecord: (store, type, record) -> + id = Ember.get(record, 'id') + + @ajax(this.urlPrefix() + '/ssh_key/' + id, "DELETE"); + createRecord: (store, type, record) -> data = {}; serializer = store.serializerFor(type.typeKey); serializer.serializeIntoHash(data, type, record, { includeId: true }); - this.ajax(this.buildURL(type.typeKey, null, record), "POST", { data: data }) + id = Ember.get(record, 'id') + + this.ajax(this.urlPrefix() + '/ssh_key/' + id, "PATCH", { data: data }) `export default Adapter` diff --git a/app/controllers/ssh-key.coffee b/app/controllers/ssh-key.coffee index d2b32f54..152ba3d9 100644 --- a/app/controllers/ssh-key.coffee +++ b/app/controllers/ssh-key.coffee @@ -18,7 +18,12 @@ Controller = Ember.ObjectController.extend Validations, actions: add: -> - model = Travis.SshKey.create(id: @get('repo.id')) + id = @get('repo.id') + model = @store.recordForId('sshKey', id) + if model.get('currentState.stateName') == 'root.empty' + @store.dematerializeRecord(model) + + model = @store.createRecord('sshKey', id: id) @set('model', model) @set('isEditing', true) @@ -30,10 +35,10 @@ Controller = Ember.ObjectController.extend Validations, @get('model').save().then => @set('isEditing', false) @set('isSaving', false) - , (xhr) => + , (error) => @set('isSaving', false) - if xhr.status == 422 - @addErrorsFromResponse(JSON.parse(xhr.response)['errors']) + if error.errors + @addErrorsFromResponse(error.errors) else @set('isSaving', false) @@ -43,18 +48,18 @@ Controller = Ember.ObjectController.extend Validations, deletingDone = => @set('isDeleting', false) - # because of the bug in ember model reference is not cleared after - # deleting the record, so I'm doing it manually here - delete @get('model').constructor._referenceCache[parseInt(@get('model.id'))] - - @get('model').deleteRecord().then(deletingDone, deletingDone).then => + @get('model').deleteRecord() + @get('model').save().then(deletingDone, deletingDone).then => @set('model', null) cancel: -> if model = @get('model') - if model.get('isNew') - @set('model', null) - @set('isEditing', false) + if model.get('currentState.stateName') == 'root.empty' || + model.get('currentState.stateName').indexOf('root.loaded.created') != -1 + @store.dematerializeRecord(model) + + @set('model', null) + @set('isEditing', false) edit: -> @set('isEditing', true) diff --git a/app/helpers/travis-errors.coffee b/app/helpers/travis-errors.coffee index 34763a00..030cb535 100644 --- a/app/helpers/travis-errors.coffee +++ b/app/helpers/travis-errors.coffee @@ -7,11 +7,12 @@ ErrorsView = Ember.View.extend classNameBindings: ['codes', 'show'] codes: (-> @get('errors').mapBy('code') - ).property('@errors') + ).property('@errors', 'errors.length') show: Ember.computed.notEmpty('errors.[]') fn = (name, options) -> errors = @get('errors').for(name) + window[name + 'Errors'] = errors view = ErrorsView.create( controller: this errors: errors diff --git a/app/templates/helpers/travis-errors.hbs b/app/templates/helpers/travis-errors.hbs index 741f5583..1f8c68c6 100644 --- a/app/templates/helpers/travis-errors.hbs +++ b/app/templates/helpers/travis-errors.hbs @@ -1 +1 @@ -{{#each erorr in view.errors}}{{error.message}}{{/each}} +{{#each error in view.errors}}{{error.message}}{{/each}} diff --git a/app/templates/repos/show/actions.hbs b/app/templates/repos/show/actions.hbs index 41cc5609..c262912b 100644 --- a/app/templates/repos/show/actions.hbs +++ b/app/templates/repos/show/actions.hbs @@ -2,12 +2,14 @@