Init models

This commit is contained in:
Götz 2018-06-08 22:30:22 +02:00
parent c2fa630acf
commit 8ac52bd600
2 changed files with 100 additions and 0 deletions

View File

@ -1,3 +1,13 @@
from django.contrib import admin from django.contrib import admin
from .models import Staff, Room, RoomType, BookingGroup, Booking, Equipment, Location, Buildings, NumEquipment
# Register your models here. # Register your models here.
admin.site.register(Staff)
admin.site.register(Room)
admin.site.register(RoomType)
admin.site.register(BookingGroup)
admin.site.register(Booking)
admin.site.register(Equipment)
admin.site.register(Location)
admin.site.register(Buildings)
admin.site.register(NumEquipment)

View File

@ -1,3 +1,93 @@
from django.db import models from django.db import models
from django.contrib.auth.models import User
# Create your models here. # Create your models here.
class Location(models.Model):
name = models.CharField(max_length=16)
def __str__(self):
return '{}'.format(self.name)
class Buildings(models.Model):
name = models.CharField(max_length=16)
location = models.ForeignKey(Location, on_delete=models.CASCADE)
def __str__(self):
return '{}'.format(self.name)
class RoomType(models.Model):
type = models.CharField(max_length=32)
def __str__(self):
return '{}'.format(self.type)
class BookingGroup(models.Model):
name = models.CharField(max_length=64)
def __str__(self):
return '{}'.format(self.name)
class Staff(models.Model):
booking_group = models.ManyToManyField(BookingGroup)
# username = personal_id
user = models.OneToOneField(User, on_delete=models.CASCADE)
def __str__(self):
return '{}'.format(self.user.username)
class Room(models.Model):
building = models.ForeignKey(Buildings, on_delete=models.CASCADE)
room_number = models.CharField(max_length=16)
capacity = models.IntegerField()
seating = models.BooleanField()
barrier_free = models.BooleanField()
cooling = models.BooleanField()
room_type = models.ForeignKey(RoomType, on_delete=models.PROTECT)
floor = models.SmallIntegerField()
admin = models.ForeignKey(BookingGroup, on_delete=models.SET_DEFAULT, default=1)
service_staff = models.ForeignKey(Staff, on_delete=models.PROTECT)
def __str__(self):
return '{} - {}'.format(self.building.name, self.room_number)
class Equipment(models.Model):
name = models.CharField(max_length=32)
def __str__(self):
return '{}'.format(self.name)
class NumEquipment(models.Model):
room = models.ForeignKey(Room, on_delete=models.CASCADE)
equipment = models.ForeignKey(Equipment, on_delete=models.CASCADE)
count = models.SmallIntegerField()
def __str__(self):
return '{} - {} - {}'.format(self.room.room_number, self.equipment.name, self.count)
class Booking(models.Model):
DAY = 0
WEEK = 1
EVERY_TWO_WEEKS = 2
MONTH = 3
TYPE_CHOICES = ((DAY, 'DAY'), (WEEK, 'WEEK'), (EVERY_TWO_WEEKS, 'EVERY_TWO_WEEKS'), (MONTH, 'MONTH'))
room = models.ForeignKey(Room, on_delete=models.CASCADE)
staff = models.ForeignKey(Staff, on_delete=models.CASCADE)
start_date = models.DateField()
end_date = models.DateField()
start_time = models.TimeField()
end_time = models.TimeField()
intervall = models.IntegerField(choices=TYPE_CHOICES)
def __str__(self):
return '{} - {} - {}'.format(self.room.room_number, self.start_date.strftime('%Y - %m - %d'),
self.end_date.strftime('%Y - %m - %d'))