compare/results component

This commit is contained in:
Matthew Dillon 2015-11-11 20:29:50 -07:00
parent 268ab18cf6
commit aeb3206fd9
8 changed files with 113 additions and 63 deletions

View file

@ -3,9 +3,20 @@ import Ember from 'ember';
const { Controller } = Ember; const { Controller } = Ember;
export default Controller.extend({ export default Controller.extend({
selectedStrains: null,
selectedCharacteristics: null,
actions: { actions: {
search: function(query) { search: function(query) {
this.transitionToRoute('protected.compare.results', { queryParams: query }); this.transitionToRoute('protected.compare.results', { queryParams: query });
}, },
updateStrainSelection: function(selection) {
this.set('selectedStrains', selection);
},
updateCharacteristicSelection: function(selection) {
this.set('selectedCharacteristics', selection);
},
} }
}); });

View file

@ -1,31 +1,8 @@
import Ember from 'ember'; import Ember from 'ember';
export default Ember.Controller.extend({ const { Controller } = Ember;
export default Controller.extend({
queryParams: ['strain_ids', 'characteristic_ids'], queryParams: ['strain_ids', 'characteristic_ids'],
csvLink: function() {
let token = encodeURIComponent(this.get('session.secure.token'));
return `${this.get('globals.apiURL')}/api/${this.get('globals.genus')}/` +
`compare?token=${token}&strain_ids=${this.get('strain_ids')}&` +
`characteristic_ids=${this.get('characteristic_ids')}&mimeType=csv`;
}.property('strain_ids', 'characteristic_ids').readOnly(),
strains: function() {
let strains = [];
let strain_ids = this.get('strain_ids').split(',');
strain_ids.forEach((id) => {
strains.push(this.store.peekRecord('strain', id));
});
return strains;
}.property('strain_ids'),
characteristics: function() {
let characteristics = [];
let characteristic_ids = this.get('characteristic_ids').split(',');
characteristic_ids.forEach((id) => {
characteristics.push(this.store.peekRecord('characteristic', id));
});
return characteristics;
}.property('characteristic_ids'),
}); });

View file

@ -0,0 +1,19 @@
import Ember from 'ember';
const { Component, computed, inject: { service } } = Ember;
export default Component.extend({
session: service(),
strains: null,
characteristics: null,
strain_ids: null,
characteristic_ids: null,
csvLink: computed('strain_ids', 'characteristic_ids', function() {
const token = encodeURIComponent(this.get('session.data.authenticated.access_token'));
return `${this.get('globals.apiURL')}/api/${this.get('globals.genus')}/` +
`compare?token=${token}&strain_ids=${this.get('strain_ids')}&` +
`characteristic_ids=${this.get('characteristic_ids')}&mimeType=csv`;
}),
});

View file

@ -0,0 +1,25 @@
<table class="flakes-table">
<thead>
<tr>
<th>Characteristic</th>
{{#each strains as |strain|}}
<th>
{{#link-to 'protected.strains.show' strain.id classBinding="data.typeStrain:type-strain"}}
{{strain.fullNameMU}}
{{/link-to}}
</th>
{{/each}}
</tr>
</thead>
<tbody>
{{#each characteristics as |row|}}
<tr>
{{#each row key="@index" as |col|}}
<td>{{col}}</td>
{{/each}}
</tr>
{{/each}}
</tbody>
</table>
<hr>
<a href="{{csvLink}}" download>Download as CSV</a>

View file

@ -1,8 +1,10 @@
import Ember from 'ember'; import Ember from 'ember';
import ajaxRequest from '../../../../utils/ajax-request'; import ajaxRequest from '../../../../utils/ajax-request';
export default Ember.Route.extend({ const { Route, $: { isEmptyObject }, inject: { service } } = Ember;
session: Ember.inject.service('session'),
export default Route.extend({
session: service(),
queryParams: { queryParams: {
strain_ids: { strain_ids: {
@ -15,8 +17,9 @@ export default Ember.Route.extend({
beforeModel: function(transition) { beforeModel: function(transition) {
this._super(transition); this._super(transition);
if (Ember.$.isEmptyObject(transition.queryParams.strain_ids) || const strain_ids = transition.queryParams.strain_ids;
Ember.$.isEmptyObject(transition.queryParams.characteristic_ids)) { const characteristic_ids = transition.queryParams.characteristic_ids;
if (isEmptyObject(strain_ids) || isEmptyObject(characteristic_ids)) {
this.transitionTo('protected.compare'); this.transitionTo('protected.compare');
} }
}, },
@ -26,12 +29,12 @@ export default Ember.Route.extend({
this.transitionTo('protected.compare'); this.transitionTo('protected.compare');
} }
let compare = this.controllerFor('protected.compare'); const compare = this.controllerFor('protected.compare');
compare.set('selectedStrains', params.strain_ids); compare.set('selectedStrains', params.strain_ids);
compare.set('selectedCharacteristics', params.characteristic_ids); compare.set('selectedCharacteristics', params.characteristic_ids);
let url = `${this.get('globals.apiURL')}/api/${this.get('globals.genus')}/compare`; const url = `${this.get('globals.apiURL')}/api/${this.get('globals.genus')}/compare`;
let options = { const options = {
method: 'GET', method: 'GET',
data: params, data: params,
}; };
@ -40,9 +43,26 @@ export default Ember.Route.extend({
setupController: function(controller, model) { setupController: function(controller, model) {
model.forEach((m, i) => { model.forEach((m, i) => {
let c = this.store.peekRecord('characteristic', m[0]); const c = this.store.peekRecord('characteristic', m[0]);
model[i][0] = c.get('characteristicName'); model[i][0] = c.get('characteristicName');
}); });
const compare = this.controllerFor('protected.compare');
const strains = [];
const strain_ids = compare.get('selectedStrains').split(',');
strain_ids.forEach((id) => {
strains.push(this.store.peekRecord('strain', id));
});
controller.set('strains', strains);
const characteristics = [];
const characteristic_ids = compare.get('selectedCharacteristics').split(',');
characteristic_ids.forEach((id) => {
characteristics.push(this.store.peekRecord('characteristic', id));
});
controller.set('characteristics', characteristics);
controller.set('model', model); controller.set('model', model);
}, },

View file

@ -1,25 +1,7 @@
<table class="flakes-table"> {{
<thead> protected/compare/results/results-table
<tr> strains=strains
<th>Characteristic</th> characteristics=model
{{#each strains as |strain|}} strain_ids=strain_ids
<th> characteristic_ids=characteristic_ids
{{#link-to 'protected.strains.show' strain.id classBinding="data.typeStrain:type-strain"}} }}
{{strain.fullNameMU}}
{{/link-to}}
</th>
{{/each}}
</tr>
</thead>
<tbody>
{{#each model as |row|}}
<tr>
{{#each row key="@index" as |col|}}
<td>{{col}}</td>
{{/each}}
</tr>
{{/each}}
</tbody>
</table>
<hr>
<a href="{{csvLink}}" download>Download as CSV</a>

View file

@ -7,10 +7,22 @@ export default Component.extend({
strains: null, strains: null,
"on-search": null, "on-search": null,
"update-strains": null,
"update-characteristics": null,
selectedStrains: null, selectedStrains: null,
selectedCharacteristics: null, selectedCharacteristics: null,
updateStrains: function(selection) {
this.set('selectedStrains', selection);
this.attrs['update-strains'](this.get('selectedStrains'));
},
updateCharacteristics: function(selection) {
this.set('selectedCharacteristics', selection);
this.attrs['update-characteristics'](this.get('selectedCharacteristics'));
},
actions: { actions: {
search: function() { search: function() {
const query = { const query = {
@ -26,11 +38,11 @@ export default Component.extend({
strains.forEach((strain) => { strains.forEach((strain) => {
strain_ids.push(strain.get('id')); strain_ids.push(strain.get('id'));
}); });
this.set('selectedStrains', strain_ids.join(",")); this.updateStrains(strain_ids.join(","));
}, },
deselectAllStrains: function() { deselectAllStrains: function() {
this.set('selectedStrains', ''); this.updateStrains("");
}, },
selectAllCharacteristics: function() { selectAllCharacteristics: function() {
@ -39,11 +51,11 @@ export default Component.extend({
chars.forEach((char) => { chars.forEach((char) => {
char_ids.push(char.get('id')); char_ids.push(char.get('id'));
}); });
this.set('selectedCharacteristics', char_ids.join(",")); this.updateCharacteristics(char_ids.join(","));
}, },
deselectAllCharacteristics: function() { deselectAllCharacteristics: function() {
this.set('selectedCharacteristics', ''); this.updateCharacteristics("");
}, },
}, },
}); });

View file

@ -4,7 +4,11 @@
protected/compare/select-form protected/compare/select-form
characteristics=characteristics characteristics=characteristics
strains=strains strains=strains
selectedStrains=selectedStrains
selectedCharacteristics=selectedCharacteristics
on-search=(action "search") on-search=(action "search")
update-strains=(action "updateStrainSelection")
update-characteristics=(action "updateCharacteristicSelection")
}} }}
{{outlet}} {{outlet}}