Location models

- region
- site
- municipal location
- study location
- storage location
This commit is contained in:
Matthew Ryan Dillon 2016-01-28 14:34:26 -07:00
parent 31a9f87848
commit 3ee15528e8
8 changed files with 245 additions and 78 deletions

View file

11
ccdb/locations/admin.py Normal file
View file

@ -0,0 +1,11 @@
from django.contrib import admin
from .models import Region, Site, MunicipalLocation, \
StudyLocation, StorageLocation
admin.site.register(Region)
admin.site.register(Site)
admin.site.register(MunicipalLocation)
admin.site.register(StudyLocation)
admin.site.register(StorageLocation)

View file

@ -0,0 +1,105 @@
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
from django.db import migrations, models
import autoslug.fields
class Migration(migrations.Migration):
dependencies = [
]
operations = [
migrations.CreateModel(
name='MunicipalLocation',
fields=[
('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)),
('name', models.CharField(max_length=100)),
('code', models.CharField(max_length=10, blank=True)),
('municipal_location_type', models.CharField(max_length=50, blank=True)),
('description', models.CharField(max_length=255, blank=True)),
('sort_order', models.IntegerField(null=True, blank=True)),
('slug', autoslug.fields.AutoSlugField(populate_from='name', editable=False)),
],
options={
'ordering': ['sort_order'],
},
),
migrations.CreateModel(
name='Region',
fields=[
('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)),
('name', models.CharField(max_length=100)),
('code', models.CharField(max_length=10, blank=True)),
('sort_order', models.IntegerField(null=True, blank=True)),
('slug', autoslug.fields.AutoSlugField(populate_from='name', editable=False)),
],
options={
'ordering': ['sort_order'],
},
),
migrations.CreateModel(
name='Site',
fields=[
('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)),
('name', models.CharField(max_length=100)),
('code', models.CharField(max_length=10, blank=True)),
('description', models.CharField(max_length=255, blank=True)),
('sort_order', models.IntegerField(null=True, blank=True)),
('slug', autoslug.fields.AutoSlugField(populate_from='name', editable=False)),
('region', models.ForeignKey(to='locations.Region', null=True, blank=True)),
],
options={
'ordering': ['sort_order'],
},
),
migrations.CreateModel(
name='StorageLocation',
fields=[
('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)),
('facility', models.CharField(max_length=100)),
('building', models.CharField(max_length=100)),
('room', models.CharField(max_length=50, blank=True)),
('freezer', models.CharField(max_length=50, blank=True)),
('temp_c', models.IntegerField(null=True, blank=True)),
('description', models.CharField(max_length=255, blank=True)),
('sort_order', models.IntegerField(null=True, blank=True)),
],
options={
'ordering': ['sort_order'],
},
),
migrations.CreateModel(
name='StudyLocation',
fields=[
('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)),
('name', models.CharField(max_length=100)),
('code', models.CharField(max_length=10, blank=True)),
('study_location_type', models.CharField(max_length=50, blank=True)),
('treatment_type', models.CharField(max_length=100, blank=True)),
('collecting_location', models.BooleanField(default=False)),
('description', models.CharField(max_length=255, blank=True)),
('sort_order', models.IntegerField(null=True, blank=True)),
('slug', autoslug.fields.AutoSlugField(populate_from='name', editable=False)),
('municipal_location', models.ForeignKey(to='locations.MunicipalLocation', null=True, blank=True)),
('site', models.ForeignKey(to='locations.Site', null=True, blank=True)),
],
options={
'ordering': ['sort_order'],
},
),
migrations.AlterUniqueTogether(
name='region',
unique_together=set([('name', 'code')]),
),
migrations.AddField(
model_name='municipallocation',
name='site',
field=models.ForeignKey(to='locations.Site'),
),
migrations.AlterUniqueTogether(
name='studylocation',
unique_together=set([('site', 'name')]),
),
]

View file

94
ccdb/locations/models.py Normal file
View file

@ -0,0 +1,94 @@
from django.db import models
from autoslug import AutoSlugField
class Region(models.Model):
name = models.CharField(max_length=100)
code = models.CharField(max_length=10, blank=True)
sort_order = models.IntegerField(blank=True, null=True)
slug = AutoSlugField(populate_from='name')
def __str__(self):
return self.name
class Meta:
unique_together = ('name', 'code')
ordering = ['sort_order']
class Site(models.Model):
region = models.ForeignKey(Region, blank=True, null=True)
name = models.CharField(max_length=100)
code = models.CharField(max_length=10, blank=True)
description = models.CharField(max_length=255, blank=True)
sort_order = models.IntegerField(blank=True, null=True)
slug = AutoSlugField(populate_from='name')
def __str__(self):
return self.name
class Meta:
ordering = ['sort_order']
class MunicipalLocation(models.Model):
site = models.ForeignKey(Site)
name = models.CharField(max_length=100)
code = models.CharField(max_length=10, blank=True)
municipal_location_type = models.CharField(max_length=50, blank=True)
description = models.CharField(max_length=255, blank=True)
sort_order = models.IntegerField(blank=True, null=True)
slug = AutoSlugField(populate_from='name')
def __str__(self):
return self.name
class Meta:
ordering = ['sort_order']
class StudyLocation(models.Model):
site = models.ForeignKey(Site, blank=True, null=True)
name = models.CharField(max_length=100)
code = models.CharField(max_length=10, blank=True)
study_location_type = models.CharField(max_length=50, blank=True)
treatment_type = models.CharField(max_length=100, blank=True)
municipal_location = models.ForeignKey(MunicipalLocation,
blank=True, null=True)
collecting_location = models.BooleanField(default=False)
description = models.CharField(max_length=255, blank=True)
sort_order = models.IntegerField(blank=True, null=True)
slug = AutoSlugField(populate_from='name')
def __str__(self):
return self.name
class Meta:
unique_together = ('site', 'name')
ordering = ['sort_order']
class StorageLocation(models.Model):
facility = models.CharField(max_length=100)
building = models.CharField(max_length=100)
room = models.CharField(max_length=50, blank=True)
freezer = models.CharField(max_length=50, blank=True)
temp_c = models.IntegerField(blank=True, null=True)
description = models.CharField(max_length=255, blank=True)
sort_order = models.IntegerField(blank=True, null=True)
def __str__(self):
bldg = "".join(e[0].upper() for e in self.building.split())
temp_c = '20'
if self.temp_c:
temp_c = self.temp_c
freezer = 'No Freezer'
if self.freezer:
freezer = self.freezer
return " ".join([bldg, str(temp_c)+'C', str(freezer)])
class Meta:
ordering = ['sort_order']

View file

@ -9,6 +9,8 @@ from ccdb.utils.data_import import setup_sqlite
from ccdb.projects.models import Project, Grant, GrantReport
from ccdb.misc.models import MeasurementUnit, MeasurementType, Container, \
Material, Color
from ccdb.locations.models import Region, Site, MunicipalLocation, \
StudyLocation, StorageLocation
class Command(BaseCommand):
@ -104,3 +106,35 @@ def _import_data():
color_id=r[4], material_id=r[5], volume=r[6],
measurement_unit_id=r[7], sort_order=r[8])
cl.save()
# Regions
for r in c.execute('SELECT * FROM tbl_lu_regions;'):
re = Region(id=r[0], name=r[1], code=r[2], sort_order=r[3])
re.save()
# Site
for r in c.execute('SELECT * FROM tbl_lu_sites;'):
s = Site(region_id=r[0], id=r[1], name=r[2], code=r[3],
description=r[4], sort_order=r[5])
s.save()
# Municipal Locations
for r in c.execute('SELECT * FROM tbl_lu_municipal_locations;'):
ml = MunicipalLocation(site_id=r[0], id=r[1], name=r[2], code=r[3],
municipal_location_type=r[4], description=r[5], sort_order=r[6])
ml.save()
# Study Locations
for r in c.execute('SELECT * FROM tbl_lu_study_locations;'):
sl = StudyLocation(site_id=r[0], id=r[1], name=r[2], code=r[3],
study_location_type=r[4], treatment_type=r[5],
municipal_location_id=r[6], collecting_location=r[7],
description=r[13], sort_order=r[14])
sl.save()
# Storage Location
for r in c.execute('SELECT * FROM tbl_lu_storage_locations;'):
sl = StorageLocation(id=r[0], facility=r[1], building=r[2],
room=r[3], freezer=r[4], temp_c=r[5],
description=r[6], sort_order=r[7])
sl.save()