compare/results component
This commit is contained in:
parent
268ab18cf6
commit
aeb3206fd9
8 changed files with 113 additions and 63 deletions
|
@ -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);
|
||||||
|
},
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -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'),
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
|
@ -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`;
|
||||||
|
}),
|
||||||
|
});
|
|
@ -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>
|
|
@ -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);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
@ -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>
|
|
||||||
|
|
|
@ -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("");
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
|
@ -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}}
|
||||||
|
|
Reference in a new issue