diff --git a/app/models/strain.js b/app/models/strain.js
index 12c7196..8a46bfd 100644
--- a/app/models/strain.js
+++ b/app/models/strain.js
@@ -1,5 +1,4 @@
import DS from 'ember-data';
-import Ember from 'ember';
export default DS.Model.extend({
measurements: DS.hasMany('measurements', { async: true }),
@@ -17,7 +16,14 @@ export default DS.Model.extend({
updatedBy: DS.attr('number'),
deletedBy: DS.attr('number'),
totalMeasurements: DS.attr('number'),
- fullName: Ember.computed('species.speciesName', 'strainName', function() {
- return this.get('species.speciesName') + ' (strain ' + this.get('strainName') + ')';
- })
+ strainNameMU: function() {
+ let type = this.get('typeStrain') ? 'T' : '';
+ return `${this.get('strainName')}${type}`;
+ }.property('strainName', 'typeStrain').readOnly(),
+ fullName: function() {
+ return `${this.get('species.speciesName')} (strain ${this.get('strainName')})`;
+ }.property('species', 'strainName').readOnly(),
+ fullNameMU: function() {
+ return `${this.get('species.speciesName')} ${this.get('strainNameMU')}`;
+ }.property('species', 'strainNameMU').readOnly(),
});
diff --git a/app/pods/components/genus-name/component.js b/app/pods/components/genus-name/component.js
index bae8cb9..ce66e93 100644
--- a/app/pods/components/genus-name/component.js
+++ b/app/pods/components/genus-name/component.js
@@ -4,5 +4,5 @@ export default Ember.Component.extend({
tagName: 'em',
genus: function() {
return this.get('globals.genus').capitalize();
- }.property(),
+ }.property().readOnly(),
});
diff --git a/app/pods/components/measurement-index-row/component.js b/app/pods/components/measurement-index-row/component.js
deleted file mode 100644
index f48ea57..0000000
--- a/app/pods/components/measurement-index-row/component.js
+++ /dev/null
@@ -1,5 +0,0 @@
-import Ember from 'ember';
-
-export default Ember.Component.extend({
- tagName: 'tr',
-});
diff --git a/app/pods/components/measurement-index-row/template.hbs b/app/pods/components/measurement-index-row/template.hbs
deleted file mode 100644
index fe9a6b6..0000000
--- a/app/pods/components/measurement-index-row/template.hbs
+++ /dev/null
@@ -1,9 +0,0 @@
-
- {{scientific-name strain=data.strain}}
- |
-
- {{data.characteristic.characteristicName}}
- |
-
- {{{data.value}}}
- |
diff --git a/app/pods/components/measurement-search-table/component.js b/app/pods/components/measurement-search-table/component.js
deleted file mode 100644
index 693dd17..0000000
--- a/app/pods/components/measurement-search-table/component.js
+++ /dev/null
@@ -1,32 +0,0 @@
-import Ember from 'ember';
-
-export default Ember.Component.extend({
- isLoading: false,
- actions: {
- search: function() {
- this.set('isLoading', true);
- let strain = this.get('selectedStrain');
- let characteristic = this.get('selectedCharacteristic');
- if ((strain === 'all') && (characteristic === 'all')) {
- this.store.findAll('measurement').then((measurements)=>{
- this.set('measurements', measurements);
- });
- this.set('isLoading', false);
- console.log(this.get('isLoading'));
- return false;
- }
- let search = {};
- if (strain !== 'all') {
- search['strain'] = strain;
- }
- if (characteristic !== 'all') {
- search['characteristic'] = characteristic;
- }
- this.store.find('measurement', search).then((measurements)=>{
- this.set('measurements', measurements);
- });
- this.set('isLoading', false);
- return false;
- }
- },
-});
diff --git a/app/pods/components/measurement-search-table/template.hbs b/app/pods/components/measurement-search-table/template.hbs
deleted file mode 100644
index 667312e..0000000
--- a/app/pods/components/measurement-search-table/template.hbs
+++ /dev/null
@@ -1,29 +0,0 @@
-
-
- {{search-button isLoading=isLoading action='search'}}
-
-
-
-
-
Total matching measurements: {{measurements.length}}
-
-
-
-{{#if isLoading}}
- {{loading-panel}}
-{{else}}
-
-
-
- Strain |
- Characteristic |
- Value |
-
-
-
- {{#each measurements as |measurement|}}
- {{measurement-index-row data=measurement}}
- {{/each}}
-
-
-{{/if}}
diff --git a/app/pods/components/scientific-name/component.js b/app/pods/components/scientific-name/component.js
deleted file mode 100644
index 40bf39c..0000000
--- a/app/pods/components/scientific-name/component.js
+++ /dev/null
@@ -1,6 +0,0 @@
-import Ember from 'ember';
-
-export default Ember.Component.extend({
- tagName: 'span',
- strain: null, // passed in
-});
diff --git a/app/pods/components/scientific-name/template.hbs b/app/pods/components/scientific-name/template.hbs
deleted file mode 100644
index 1f3609e..0000000
--- a/app/pods/components/scientific-name/template.hbs
+++ /dev/null
@@ -1 +0,0 @@
-{{strain.species.speciesName}} (strain {{strain-name strain=strain}})
diff --git a/app/pods/components/species-details/template.hbs b/app/pods/components/species-details/template.hbs
index 756a6a0..813ada2 100644
--- a/app/pods/components/species-details/template.hbs
+++ b/app/pods/components/species-details/template.hbs
@@ -18,7 +18,7 @@
{{#each species.strains as |strain index|}}
{{if index ","}}
{{#link-to 'strains.show' strain.id}}
- {{strain-name strain=strain}}
+ {{{strain.strainNameMU}}}
{{/link-to}}
{{/each}}
{{#unless species.isNew}}
diff --git a/app/pods/components/species-index-row/template.hbs b/app/pods/components/species-index-row/template.hbs
index e3455a7..e86113a 100644
--- a/app/pods/components/species-index-row/template.hbs
+++ b/app/pods/components/species-index-row/template.hbs
@@ -9,7 +9,7 @@
{{#each data.strains as |strain index|}}
{{if index ","}}
{{#link-to 'strains.show' strain.id}}
- {{strain-name strain=strain}}
+ {{{strain.strainNameMU}}}
{{/link-to}}
{{/each}}
diff --git a/app/pods/components/strain-index-row/template.hbs b/app/pods/components/strain-index-row/template.hbs
index 4d64b0b..f512924 100644
--- a/app/pods/components/strain-index-row/template.hbs
+++ b/app/pods/components/strain-index-row/template.hbs
@@ -1,6 +1,6 @@
{{#link-to 'strains.show' data.id classBinding="data.typeStrain:type-strain"}}
- {{scientific-name strain=data}}
+ {{{data.fullNameMU}}}
{{/link-to}}
|
diff --git a/app/pods/components/strain-name/component.js b/app/pods/components/strain-name/component.js
deleted file mode 100644
index ced0374..0000000
--- a/app/pods/components/strain-name/component.js
+++ /dev/null
@@ -1,5 +0,0 @@
-import Ember from 'ember';
-
-export default Ember.Component.extend({
- tagName: 'span',
-});
diff --git a/app/pods/components/strain-name/template.hbs b/app/pods/components/strain-name/template.hbs
deleted file mode 100644
index 3082ce7..0000000
--- a/app/pods/components/strain-name/template.hbs
+++ /dev/null
@@ -1 +0,0 @@
-{{strain.strainName}}{{{if strain.typeStrain 'T'}}}
diff --git a/app/pods/measurements/controller.js b/app/pods/measurements/controller.js
new file mode 100644
index 0000000..8bb7819
--- /dev/null
+++ b/app/pods/measurements/controller.js
@@ -0,0 +1,15 @@
+import Ember from 'ember';
+
+export default Ember.Controller.extend({
+ actions: {
+ search: function() {
+ let search = {
+ strain: this.get('selectedStrains'),
+ characteristic: this.get('selectedCharacteristics'),
+ };
+ this.store.find('measurement', search).then((measurements)=>{
+ this.set('measurements', measurements);
+ });
+ }
+ },
+});
diff --git a/app/pods/measurements/route.js b/app/pods/measurements/route.js
index 9dbfd63..d460d65 100644
--- a/app/pods/measurements/route.js
+++ b/app/pods/measurements/route.js
@@ -4,46 +4,28 @@ import AuthenticatedRouteMixin from 'simple-auth/mixins/authenticated-route-mixi
export default Ember.Route.extend(AuthenticatedRouteMixin, {
model: function() {
return Ember.RSVP.hash({
- species: this.store.findAll('species'),
+ species: this.store.findAll('species'), // need this bc async
strains: this.store.findAll('strain'),
characteristics: this.store.findAll('characteristic'),
});
},
setupController: function(controller, models) {
- var tableAttrs = [
- { name: 'Strain', attr: 'strain.strainName' },
- { name: 'Characteristic', attr: 'characteristic.characteristicName' },
- { name: 'Value', attr: 'computedValue'}
- ];
- controller.set('tableAttrs', tableAttrs);
- controller.set('row', 'measurement-index-row');
- controller.set('measurements', []);
-
// Set up search parameters
- models.strains = models.strains.sortBy('fullName');
- let strains = models.strains.map((strain)=>{
- return Ember.Object.create({
- val: strain.get('id'),
- lab: strain.get('fullName'),
- });
- });
- strains.unshiftObjects(Ember.Object.create({
- val: 'all',
- lab: 'All Strains',
- }));
- controller.set('strains', strains);
+ let selects = [
+ { model: 'strains', id: 'id', text: 'fullName' },
+ { model: 'characteristics', id: 'id', text: 'characteristicName' },
+ ];
- models.characteristics = models.characteristics.sortBy('characteristicName');
- let characteristics = models.characteristics.map((characteristic)=>{
- return Ember.Object.create({
- val: characteristic.get('id'),
- lab: characteristic.get('characteristicName'),
+ selects.forEach((item, index, enumerable) => {
+ models[item.model] = models[item.model].sortBy(item.text);
+ let temp = models[item.model].map((data) => {
+ return Ember.Object.create({
+ id: data.get(item.id),
+ text: data.get(item.text),
+ });
});
+ controller.set(item.model, temp);
});
- characteristics.unshiftObjects(Ember.Object.create({
- val: 'all',
- lab: 'All Characteristics',
- }));
- controller.set('characteristics', characteristics);
+
},
});
diff --git a/app/pods/measurements/template.hbs b/app/pods/measurements/template.hbs
index 87b6327..fe3922c 100644
--- a/app/pods/measurements/template.hbs
+++ b/app/pods/measurements/template.hbs
@@ -1,31 +1,61 @@
{{genus-name}} Measurements
-
-
- Strains
-
-
- {{
- view "select"
- content=strains
- optionValuePath="content.val"
- optionLabelPath="content.lab"
- value=selectedStrain
- }}
-
-
-
-
- Characteristics
-
-
- {{
- view "select"
- content=characteristics
- optionValuePath="content.val"
- optionLabelPath="content.lab"
- value=selectedCharacteristic
- }}
+
-{{measurement-search-table}}
+
+
+ Total matching measurements: {{measurements.length}}
+
+
+
+
+
+
+ Strain |
+ Characteristic |
+ Value |
+
+
+
+ {{#each measurements as |measurement|}}
+
+ {{{measurement.strain.fullNameMU}}} |
+ {{measurement.characteristic.characteristicName}} |
+ {{{measurement.value}}} |
+
+ {{/each}}
+
+
diff --git a/app/styles/app.css b/app/styles/app.css
index b5d48ca..ff245dd 100644
--- a/app/styles/app.css
+++ b/app/styles/app.css
@@ -2,6 +2,10 @@
padding: 2em 0em 0em 0em;
}
+.select2-container {
+ width: 100%;
+}
+
.flakes-table thead tr th span {
cursor: pointer;
}
diff --git a/bower.json b/bower.json
index bb963a8..6b573d8 100644
--- a/bower.json
+++ b/bower.json
@@ -14,6 +14,7 @@
"qunit": "~1.17.1",
"flakes": "~1.0.0",
"ember-simple-auth": "~0.8.0-beta.3",
- "moment": "~2.9.0"
+ "moment": "~2.9.0",
+ "select2": "3.5.2"
}
}
diff --git a/config/environment.js b/config/environment.js
index c1ece05..3ce0d37 100644
--- a/config/environment.js
+++ b/config/environment.js
@@ -41,7 +41,7 @@ module.exports = function(environment) {
'font-src': "'self'",
'connect-src': "'self' http://127.0.0.1:4200",
'img-src': "'self'",
- 'style-src': "'self'",
+ 'style-src': "'self' 'unsafe-inline'",
'media-src': "'self'"
}
}
diff --git a/package.json b/package.json
index 1dcc597..d2dc24b 100644
--- a/package.json
+++ b/package.json
@@ -37,6 +37,7 @@
"ember-data": "1.0.0-beta.18",
"ember-disable-proxy-controllers": "^1.0.0",
"ember-export-application-global": "^1.0.2",
+ "ember-select-2": "1.3.0",
"express": "^4.12.4",
"glob": "^4.5.3",
"jsonwebtoken": "^5.0.0",
diff --git a/tests/unit/components/display-error-test.js b/tests/unit/components/display-error-test.js
deleted file mode 100644
index e81245a..0000000
--- a/tests/unit/components/display-error-test.js
+++ /dev/null
@@ -1,21 +0,0 @@
-import {
- moduleForComponent,
- test
-} from 'ember-qunit';
-
-moduleForComponent('display-error', {
- // Specify the other units that are required for this test
- // needs: ['component:foo', 'helper:bar']
-});
-
-test('it renders', function(assert) {
- assert.expect(2);
-
- // Creates the component instance
- var component = this.subject();
- assert.equal(component._state, 'preRender');
-
- // Renders the component to the page
- this.render();
- assert.equal(component._state, 'inDOM');
-});
diff --git a/tests/unit/components/genus-name-test.js b/tests/unit/components/genus-name-test.js
deleted file mode 100644
index 8993325..0000000
--- a/tests/unit/components/genus-name-test.js
+++ /dev/null
@@ -1,21 +0,0 @@
-import {
- moduleForComponent,
- test
-} from 'ember-qunit';
-
-moduleForComponent('genus-name', {
- // Specify the other units that are required for this test
- // needs: ['component:foo', 'helper:bar']
-});
-
-test('it renders', function(assert) {
- assert.expect(2);
-
- // Creates the component instance
- var component = this.subject();
- assert.equal(component._state, 'preRender');
-
- // Renders the component to the page
- this.render();
- assert.equal(component._state, 'inDOM');
-});
diff --git a/tests/unit/components/measurements/measurement-row-test.js b/tests/unit/components/measurements/measurement-row-test.js
deleted file mode 100644
index 1664fcd..0000000
--- a/tests/unit/components/measurements/measurement-row-test.js
+++ /dev/null
@@ -1,21 +0,0 @@
-import {
- moduleForComponent,
- test
-} from 'ember-qunit';
-
-moduleForComponent('measurements/measurement-row', {
- // specify the other units that are required for this test
- // needs: ['component:foo', 'helper:bar']
-});
-
-test('it renders', function(assert) {
- assert.expect(2);
-
- // creates the component instance
- var component = this.subject();
- assert.equal(component._state, 'preRender');
-
- // renders the component to the page
- this.render();
- assert.equal(component._state, 'inDOM');
-});
diff --git a/tests/unit/components/scientific-name-test.js b/tests/unit/components/scientific-name-test.js
deleted file mode 100644
index b6a7957..0000000
--- a/tests/unit/components/scientific-name-test.js
+++ /dev/null
@@ -1,21 +0,0 @@
-import {
- moduleForComponent,
- test
-} from 'ember-qunit';
-
-moduleForComponent('scientific-name', {
- // specify the other units that are required for this test
- // needs: ['component:foo', 'helper:bar']
-});
-
-test('it renders', function(assert) {
- assert.expect(2);
-
- // creates the component instance
- var component = this.subject();
- assert.equal(component._state, 'preRender');
-
- // renders the component to the page
- this.render();
- assert.equal(component._state, 'inDOM');
-});
diff --git a/tests/unit/components/species/species-details-test.js b/tests/unit/components/species/species-details-test.js
deleted file mode 100644
index b3c5c67..0000000
--- a/tests/unit/components/species/species-details-test.js
+++ /dev/null
@@ -1,21 +0,0 @@
-import {
- moduleForComponent,
- test
-} from 'ember-qunit';
-
-moduleForComponent('species/species-details', {
- // Specify the other units that are required for this test
- // needs: ['component:foo', 'helper:bar']
-});
-
-test('it renders', function(assert) {
- assert.expect(2);
-
- // Creates the component instance
- var component = this.subject();
- assert.equal(component._state, 'preRender');
-
- // Renders the component to the page
- this.render();
- assert.equal(component._state, 'inDOM');
-});
diff --git a/tests/unit/components/strains/strain-details-test.js b/tests/unit/components/strains/strain-details-test.js
deleted file mode 100644
index a52c33c..0000000
--- a/tests/unit/components/strains/strain-details-test.js
+++ /dev/null
@@ -1,21 +0,0 @@
-import {
- moduleForComponent,
- test
-} from 'ember-qunit';
-
-moduleForComponent('strains/strain-details', {
- // Specify the other units that are required for this test
- // needs: ['component:foo', 'helper:bar']
-});
-
-test('it renders', function(assert) {
- assert.expect(2);
-
- // Creates the component instance
- var component = this.subject();
- assert.equal(component._state, 'preRender');
-
- // Renders the component to the page
- this.render();
- assert.equal(component._state, 'inDOM');
-});
diff --git a/tests/unit/pods/components/measurement-index-row/component-test.js b/tests/unit/pods/components/measurement-index-row/component-test.js
deleted file mode 100644
index af52af6..0000000
--- a/tests/unit/pods/components/measurement-index-row/component-test.js
+++ /dev/null
@@ -1,18 +0,0 @@
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('measurement-index-row', 'Unit | Component | measurement index row', {
- // Specify the other units that are required for this test
- // needs: ['component:foo', 'helper:bar']
-});
-
-test('it renders', function(assert) {
- assert.expect(2);
-
- // Creates the component instance
- var component = this.subject();
- assert.equal(component._state, 'preRender');
-
- // Renders the component to the page
- this.render();
- assert.equal(component._state, 'inDOM');
-});
diff --git a/tests/unit/pods/components/measurement-search-table/component-test.js b/tests/unit/pods/components/measurement-search-table/component-test.js
deleted file mode 100644
index 6ec5359..0000000
--- a/tests/unit/pods/components/measurement-search-table/component-test.js
+++ /dev/null
@@ -1,19 +0,0 @@
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('measurement-search-table', 'Unit | Component | measurement search table', {
- // Specify the other units that are required for this test
- // needs: ['component:foo', 'helper:bar'],
- unit: true
-});
-
-test('it renders', function(assert) {
- assert.expect(2);
-
- // Creates the component instance
- var component = this.subject();
- assert.equal(component._state, 'preRender');
-
- // Renders the component to the page
- this.render();
- assert.equal(component._state, 'inDOM');
-});
diff --git a/tests/unit/pods/components/strain-name/component-test.js b/tests/unit/pods/components/strain-name/component-test.js
deleted file mode 100644
index 3874bf8..0000000
--- a/tests/unit/pods/components/strain-name/component-test.js
+++ /dev/null
@@ -1,19 +0,0 @@
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('strain-name', 'Unit | Component | strain name', {
- // Specify the other units that are required for this test
- // needs: ['component:foo', 'helper:bar'],
- unit: true
-});
-
-test('it renders', function(assert) {
- assert.expect(2);
-
- // Creates the component instance
- var component = this.subject();
- assert.equal(component._state, 'preRender');
-
- // Renders the component to the page
- this.render();
- assert.equal(component._state, 'inDOM');
-});
diff --git a/tests/unit/pods/measurements/controller-test.js b/tests/unit/pods/measurements/controller-test.js
new file mode 100644
index 0000000..f20328f
--- /dev/null
+++ b/tests/unit/pods/measurements/controller-test.js
@@ -0,0 +1,12 @@
+import { moduleFor, test } from 'ember-qunit';
+
+moduleFor('controller:measurements', {
+ // Specify the other units that are required for this test.
+ // needs: ['controller:foo']
+});
+
+// Replace this with your real tests.
+test('it exists', function(assert) {
+ var controller = this.subject();
+ assert.ok(controller);
+});
|