Rough in characteristic types, add meas optgroups
This commit is contained in:
parent
f17707fb6d
commit
3c1fca43b8
9 changed files with 126 additions and 20 deletions
12
app/models/characteristic-type.js
Normal file
12
app/models/characteristic-type.js
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
import DS from 'ember-data';
|
||||||
|
|
||||||
|
export default DS.Model.extend({
|
||||||
|
characteristicTypeName: DS.attr('string'),
|
||||||
|
characteristics: DS.hasMany('characteristic', { async: true }),
|
||||||
|
createdAt: DS.attr('date'),
|
||||||
|
updatedAt: DS.attr('date'),
|
||||||
|
deletedAt: DS.attr('date'),
|
||||||
|
createdBy: DS.attr('number'),
|
||||||
|
updatedBy: DS.attr('number'),
|
||||||
|
deletedBy: DS.attr('number')
|
||||||
|
});
|
|
@ -2,7 +2,7 @@ import DS from 'ember-data';
|
||||||
|
|
||||||
export default DS.Model.extend({
|
export default DS.Model.extend({
|
||||||
characteristicName: DS.attr('string'),
|
characteristicName: DS.attr('string'),
|
||||||
characteristicType: DS.attr('string'),
|
characteristicType: DS.belongsTo('characteristicType', { async: true }),
|
||||||
strains : DS.hasMany('strain', { async: true }),
|
strains : DS.hasMany('strain', { async: true }),
|
||||||
measurements : DS.hasMany('measurements', { async: true }),
|
measurements : DS.hasMany('measurements', { async: true }),
|
||||||
createdAt : DS.attr('date'),
|
createdAt : DS.attr('date'),
|
||||||
|
|
|
@ -3,14 +3,17 @@ import AuthenticatedRouteMixin from 'simple-auth/mixins/authenticated-route-mixi
|
||||||
|
|
||||||
export default Ember.Route.extend(AuthenticatedRouteMixin, {
|
export default Ember.Route.extend(AuthenticatedRouteMixin, {
|
||||||
model: function() {
|
model: function() {
|
||||||
return this.store.findAll('characteristic');
|
return Ember.RSVP.hash({
|
||||||
|
characteristicTypes: this.store.findAll('characteristic-type'),
|
||||||
|
characteristics: this.store.findAll('characteristic'),
|
||||||
|
});
|
||||||
},
|
},
|
||||||
setupController: function(controller, model) {
|
setupController: function(controller, models) {
|
||||||
var tableAttrs = [
|
var tableAttrs = [
|
||||||
{ name: 'Name', attr: 'characteristicName' },
|
{ name: 'Name', attr: 'characteristicName' },
|
||||||
{ name: 'Type', attr: 'characteristicType' }
|
{ name: 'Type', attr: 'characteristicType.characteristicTypeName' }
|
||||||
];
|
];
|
||||||
controller.set('model', model);
|
controller.set('model', models.characteristics);
|
||||||
controller.set('tableAttrs', tableAttrs);
|
controller.set('tableAttrs', tableAttrs);
|
||||||
controller.set('row', 'characteristic-index-row');
|
controller.set('row', 'characteristic-index-row');
|
||||||
controller.set('sort', ['characteristicName']);
|
controller.set('sort', ['characteristicName']);
|
||||||
|
|
|
@ -2,5 +2,5 @@
|
||||||
{{data.characteristicName}}
|
{{data.characteristicName}}
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
{{data.characteristicType}}
|
{{data.characteristicType.characteristicTypeName}}
|
||||||
</td>
|
</td>
|
||||||
|
|
|
@ -4,25 +4,35 @@ import AuthenticatedRouteMixin from 'simple-auth/mixins/authenticated-route-mixi
|
||||||
export default Ember.Route.extend(AuthenticatedRouteMixin, {
|
export default Ember.Route.extend(AuthenticatedRouteMixin, {
|
||||||
model: function() {
|
model: function() {
|
||||||
return Ember.RSVP.hash({
|
return Ember.RSVP.hash({
|
||||||
species: this.store.findAll('species'), // need this bc async
|
species: this.store.findAll('species'),
|
||||||
strains: this.store.findAll('strain'),
|
strains: this.store.findAll('strain'),
|
||||||
|
characteristicTypes: this.store.findAll('characteristic-type'),
|
||||||
characteristics: this.store.findAll('characteristic'),
|
characteristics: this.store.findAll('characteristic'),
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
setupController: function(controller, models) {
|
setupController: function(controller, models) {
|
||||||
// Set up search parameters
|
// Set up search parameters
|
||||||
let selects = [
|
let selects = [
|
||||||
{ model: 'strains', id: 'id', text: 'fullName' },
|
{ model: 'species', id: 'id', text: 'speciesName',
|
||||||
{ model: 'characteristics', id: 'id', text: 'characteristicName' },
|
children: 'strains', cid: 'id', ctext: 'fullName' },
|
||||||
|
{ model: 'characteristicTypes', id: 'id', text: 'characteristicTypeName',
|
||||||
|
children: 'characteristics', cid: 'id', ctext: 'characteristicName' },
|
||||||
];
|
];
|
||||||
|
|
||||||
selects.forEach((item /*, index, enumerable*/) => {
|
selects.forEach((item /*, index, enumerable*/) => {
|
||||||
|
models[item.model] = models[item.model].filter((i) => {
|
||||||
|
if (!Ember.isEmpty(i.get(item.children))) { return true; }
|
||||||
|
});
|
||||||
models[item.model] = models[item.model].sortBy(item.text);
|
models[item.model] = models[item.model].sortBy(item.text);
|
||||||
let temp = models[item.model].map((data) => {
|
let temp = models[item.model].map((data) => {
|
||||||
return Ember.Object.create({
|
let temp_children = [];
|
||||||
id: data.get(item.id),
|
data.get(item.children).forEach((child) => {
|
||||||
text: data.get(item.text),
|
temp_children.push({id: child.get(item.cid), text: child.get(item.ctext)});
|
||||||
});
|
});
|
||||||
|
return {
|
||||||
|
text: data.get(item.text),
|
||||||
|
children: temp_children,
|
||||||
|
};
|
||||||
});
|
});
|
||||||
controller.set(item.model, temp);
|
controller.set(item.model, temp);
|
||||||
});
|
});
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
{{
|
{{
|
||||||
select-2
|
select-2
|
||||||
multiple=true
|
multiple=true
|
||||||
content=strains
|
content=species
|
||||||
value=selectedStrains
|
value=selectedStrains
|
||||||
optionValuePath="id"
|
optionValuePath="id"
|
||||||
placeholder="All strains"
|
placeholder="All strains"
|
||||||
|
@ -20,7 +20,7 @@
|
||||||
{{
|
{{
|
||||||
select-2
|
select-2
|
||||||
multiple=true
|
multiple=true
|
||||||
content=characteristics
|
content=characteristicTypes
|
||||||
value=selectedCharacteristics
|
value=selectedCharacteristics
|
||||||
optionValuePath="id"
|
optionValuePath="id"
|
||||||
placeholder="All characteristics"
|
placeholder="All characteristics"
|
||||||
|
|
|
@ -42,6 +42,6 @@
|
||||||
"express": "^4.12.4",
|
"express": "^4.12.4",
|
||||||
"glob": "^4.5.3",
|
"glob": "^4.5.3",
|
||||||
"jsonwebtoken": "^5.0.0",
|
"jsonwebtoken": "^5.0.0",
|
||||||
"morgan": "^1.5.3"
|
"morgan": "^1.6.0"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
81
server/mocks/characteristic-types.js
Normal file
81
server/mocks/characteristic-types.js
Normal file
|
@ -0,0 +1,81 @@
|
||||||
|
module.exports = function(app) {
|
||||||
|
var express = require('express');
|
||||||
|
var characteristicTypesRouter = express.Router();
|
||||||
|
|
||||||
|
var CHARACTERISTIC_TYPES = [
|
||||||
|
{
|
||||||
|
id: 1,
|
||||||
|
characteristicTypeName: 'Type 1',
|
||||||
|
characteristics: [1,4],
|
||||||
|
createdAt: "0001-01-01T00:00:00Z",
|
||||||
|
updatedAt: "0001-01-01T00:00:00Z",
|
||||||
|
deletedAt: null,
|
||||||
|
createdBy: 1,
|
||||||
|
updatedBy: 1,
|
||||||
|
deletedBy: null
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 2,
|
||||||
|
characteristicTypeName: 'Type 2',
|
||||||
|
characteristics: [2,5],
|
||||||
|
createdAt: "0001-01-01T00:00:00Z",
|
||||||
|
updatedAt: "0001-01-01T00:00:00Z",
|
||||||
|
deletedAt: null,
|
||||||
|
createdBy: 1,
|
||||||
|
updatedBy: 1,
|
||||||
|
deletedBy: null
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 3,
|
||||||
|
characteristicTypeName: 'Type 3',
|
||||||
|
characteristics: [3],
|
||||||
|
createdAt: "0001-01-01T00:00:00Z",
|
||||||
|
updatedAt: "0001-01-01T00:00:00Z",
|
||||||
|
deletedAt: null,
|
||||||
|
createdBy: 1,
|
||||||
|
updatedBy: 1,
|
||||||
|
deletedBy: null
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
characteristicTypesRouter.get('/', function(req, res) {
|
||||||
|
var characteristics;
|
||||||
|
if (req.query.ids) {
|
||||||
|
characteristic_types = CHARACTERISTIC_TYPES.filter(function(c) {
|
||||||
|
return req.query.ids.indexOf(c.id.toString()) > -1;
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
characteristic_types = CHARACTERISTIC_TYPES;
|
||||||
|
}
|
||||||
|
res.send({
|
||||||
|
'characteristicTypes': characteristic_types
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
characteristicTypesRouter.post('/', function(req, res) {
|
||||||
|
res.status(201).end();
|
||||||
|
});
|
||||||
|
|
||||||
|
characteristicTypesRouter.get('/:id', function(req, res) {
|
||||||
|
var characteristic_type = CHARACTERISTIC_TYPES.filter(function(c) {
|
||||||
|
return c.id == req.params.id;
|
||||||
|
});
|
||||||
|
res.send({
|
||||||
|
'characteristicType': characteristic_type
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
characteristicTypesRouter.put('/:id', function(req, res) {
|
||||||
|
res.send({
|
||||||
|
'characteristicTypes': {
|
||||||
|
id: req.params.id
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
characteristicTypesRouter.delete('/:id', function(req, res) {
|
||||||
|
res.status(204).end();
|
||||||
|
});
|
||||||
|
|
||||||
|
app.use('/api/hymenobacter/characteristicTypes', characteristicTypesRouter);
|
||||||
|
};
|
|
@ -6,7 +6,7 @@ module.exports = function(app) {
|
||||||
{
|
{
|
||||||
id: 1,
|
id: 1,
|
||||||
characteristicName: 'α-fucosidase (API ZYM)',
|
characteristicName: 'α-fucosidase (API ZYM)',
|
||||||
characteristicType: 'Type 1',
|
characteristicType: 1,
|
||||||
strains: [1,2],
|
strains: [1,2],
|
||||||
measurements: [1,6],
|
measurements: [1,6],
|
||||||
createdAt: "0001-01-01T00:00:00Z",
|
createdAt: "0001-01-01T00:00:00Z",
|
||||||
|
@ -19,7 +19,7 @@ module.exports = function(app) {
|
||||||
{
|
{
|
||||||
id: 2,
|
id: 2,
|
||||||
characteristicName: 'α-glucosidase',
|
characteristicName: 'α-glucosidase',
|
||||||
characteristicType: 'Type 2',
|
characteristicType: 2,
|
||||||
strains: [1,2],
|
strains: [1,2],
|
||||||
measurements: [2,7],
|
measurements: [2,7],
|
||||||
createdAt: "0001-01-01T00:00:00Z",
|
createdAt: "0001-01-01T00:00:00Z",
|
||||||
|
@ -32,7 +32,7 @@ module.exports = function(app) {
|
||||||
{
|
{
|
||||||
id: 3,
|
id: 3,
|
||||||
characteristicName: 'Chloramphenicol',
|
characteristicName: 'Chloramphenicol',
|
||||||
characteristicType: 'Type 3',
|
characteristicType: 3,
|
||||||
strains: [1,2],
|
strains: [1,2],
|
||||||
measurements: [3,8],
|
measurements: [3,8],
|
||||||
createdAt: "0001-01-01T00:00:00Z",
|
createdAt: "0001-01-01T00:00:00Z",
|
||||||
|
@ -45,7 +45,7 @@ module.exports = function(app) {
|
||||||
{
|
{
|
||||||
id: 4,
|
id: 4,
|
||||||
characteristicName: 'Bacitracin',
|
characteristicName: 'Bacitracin',
|
||||||
characteristicType: 'Type 1',
|
characteristicType: 1,
|
||||||
strains: [1,2],
|
strains: [1,2],
|
||||||
measurements: [4,9],
|
measurements: [4,9],
|
||||||
createdAt: "0001-01-01T00:00:00Z",
|
createdAt: "0001-01-01T00:00:00Z",
|
||||||
|
@ -58,7 +58,7 @@ module.exports = function(app) {
|
||||||
{
|
{
|
||||||
id: 5,
|
id: 5,
|
||||||
characteristicName: 'Indole',
|
characteristicName: 'Indole',
|
||||||
characteristicType: 'Type 2',
|
characteristicType: 2,
|
||||||
strains: [1,2],
|
strains: [1,2],
|
||||||
measurements: [5,10],
|
measurements: [5,10],
|
||||||
createdAt: "0001-01-01T00:00:00Z",
|
createdAt: "0001-01-01T00:00:00Z",
|
||||||
|
|
Reference in a new issue