diff --git a/app/pods/application/adapter.js b/app/pods/application/adapter.js
index e979dec..c4b405b 100644
--- a/app/pods/application/adapter.js
+++ b/app/pods/application/adapter.js
@@ -5,10 +5,13 @@ export default DS.RESTAdapter.extend({
namespace: function() {
return 'api/' + this.get('globals.genus');
}.property(),
+
host: function() {
return this.get('globals.apiURL');
}.property(),
+
coalesceFindRequests: true,
+
ajaxError: function(jqXHR) {
// http://stackoverflow.com/a/24027443
var error = this._super(jqXHR);
@@ -22,8 +25,13 @@ export default DS.RESTAdapter.extend({
});
}
return new DS.InvalidError(errors);
+ } else if (jqXHR && jqXHR.status === 500) {
+ var response = Ember.$.parseJSON(jqXHR.responseText);
+ if (response.error !== undefined) {
+ return new DS.InvalidError(response.error);
+ }
} else {
return error;
}
- }
+ },
});
diff --git a/app/pods/components/species-details/component.js b/app/pods/components/species-details/component.js
deleted file mode 100644
index 6070141..0000000
--- a/app/pods/components/species-details/component.js
+++ /dev/null
@@ -1,20 +0,0 @@
-import Ember from 'ember';
-import userCanEdit from '../../../utils/user-can-edit';
-
-export default Ember.Component.extend({
- classNames: ['grid-1'],
- isEditing: false,
-
- canEdit: function() {
- return userCanEdit(this.get('session.currentUser'), this.get('species.createdBy'));
- }.property('session.currentUser', 'species.createdBy').readOnly(),
-
- actions: {
- save: function() {
- this.sendAction('save');
- },
- cancel: function() {
- this.sendAction('cancel');
- },
- }
-});
diff --git a/app/pods/components/species-details/template.hbs b/app/pods/components/species-details/template.hbs
deleted file mode 100644
index 813ada2..0000000
--- a/app/pods/components/species-details/template.hbs
+++ /dev/null
@@ -1,89 +0,0 @@
-
-
-
diff --git a/app/pods/species/edit/controller.js b/app/pods/species/edit/controller.js
new file mode 100644
index 0000000..d0925e2
--- /dev/null
+++ b/app/pods/species/edit/controller.js
@@ -0,0 +1,18 @@
+import Ember from 'ember';
+
+export default Ember.Controller.extend({
+ actions: {
+ save: function() {
+ let species = this.get('species');
+ if (species.get('isDirty')) {
+ species.save().then((species) => {
+ this.transitionToRoute('species.show', species.get('id'));
+ }, (err) => {
+ this.get('flashMessages').error(err.message);
+ });
+ } else {
+ this.transitionToRoute('species.show', species.get('id'));
+ }
+ },
+ }
+});
diff --git a/app/pods/species/edit/route.js b/app/pods/species/edit/route.js
new file mode 100644
index 0000000..b73792b
--- /dev/null
+++ b/app/pods/species/edit/route.js
@@ -0,0 +1,14 @@
+import Ember from 'ember';
+import AuthenticatedRouteMixin from 'simple-auth/mixins/authenticated-route-mixin';
+
+export default Ember.Route.extend(AuthenticatedRouteMixin, {
+ model: function(params) {
+ return Ember.RSVP.hash({
+ species: this.store.find('species', params.species_id),
+ });
+ },
+
+ setupController: function(controller, model) {
+ controller.setProperties(model);
+ },
+});
diff --git a/app/pods/species/edit/template.hbs b/app/pods/species/edit/template.hbs
new file mode 100644
index 0000000..39d135d
--- /dev/null
+++ b/app/pods/species/edit/template.hbs
@@ -0,0 +1,37 @@
+
+
+
+ Save
+
diff --git a/app/pods/species/index/route.js b/app/pods/species/index/route.js
index d2ab490..b0968ba 100644
--- a/app/pods/species/index/route.js
+++ b/app/pods/species/index/route.js
@@ -5,10 +5,11 @@ export default Ember.Route.extend(AuthenticatedRouteMixin, {
model: function() {
return Ember.RSVP.hash({
species: this.store.findAll('species'),
+ strains: this.store.findAll('strain'),
});
},
- setupController: function(controller, model) {
- controller.setProperties(model);
+ setupController: function(controller, models) {
+ controller.setProperties(models);
},
});
diff --git a/app/pods/species/index/template.hbs b/app/pods/species/index/template.hbs
index 00454fb..225fa79 100644
--- a/app/pods/species/index/template.hbs
+++ b/app/pods/species/index/template.hbs
@@ -11,17 +11,18 @@
- {{#each sortedSpecies as |row|}}
+ {{#each sortedSpecies as |species|}}
- {{#link-to 'species.show' row}}
- {{row.speciesName}}
+ {{!-- use species.id to call show model hook --}}
+ {{#link-to 'species.show' species.id}}
+ {{species.speciesName}}
{{/link-to}}
|
- {{#each row.strains as |strain index|}}
+ {{#each species.strains as |strain index|}}
{{if index ","}}
{{#link-to 'strains.show' strain.id}}
{{{strain.strainNameMU}}}
diff --git a/app/pods/species/show/route.js b/app/pods/species/show/route.js
index b3f843f..b73792b 100644
--- a/app/pods/species/show/route.js
+++ b/app/pods/species/show/route.js
@@ -1,4 +1,14 @@
import Ember from 'ember';
import AuthenticatedRouteMixin from 'simple-auth/mixins/authenticated-route-mixin';
-export default Ember.Route.extend(AuthenticatedRouteMixin, {});
+export default Ember.Route.extend(AuthenticatedRouteMixin, {
+ model: function(params) {
+ return Ember.RSVP.hash({
+ species: this.store.find('species', params.species_id),
+ });
+ },
+
+ setupController: function(controller, model) {
+ controller.setProperties(model);
+ },
+});
diff --git a/app/pods/species/show/template.hbs b/app/pods/species/show/template.hbs
index b242fc5..0d1c47a 100644
--- a/app/pods/species/show/template.hbs
+++ b/app/pods/species/show/template.hbs
@@ -1,7 +1,57 @@
-{{
- species-details
- species=model
- isEditing=isEditing
- save="save"
- cancel="cancel"
-}}
+
+
+
+
+
diff --git a/app/router.js b/app/router.js
index 27112b6..6f43b21 100644
--- a/app/router.js
+++ b/app/router.js
@@ -15,6 +15,7 @@ Router.map(function() {
this.route('species', function() {
this.route('new');
this.route('show', { path: ':species_id' });
+ this.route('edit', { path: ':species_id/edit' });
});
this.route('strains', function() {
this.route('new');
|