web/hdabo/models.py
author ymh <ymh.work@gmail.com>
Thu, 09 Jun 2011 16:34:28 +0200
changeset 15 a9136d8f0b4a
parent 11 143ab88d17f8
child 18 65b887db0ff3
child 19 e2f27df4e17b
permissions -rw-r--r--
add commant to reorder tags and query wikipedia
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
# -*- coding: utf-8 -*-
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
from django.contrib.auth.models import User
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
from django.db import models
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
from hdabo.utils import Property
11
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
     6
from hdabo.fields import SortedManyToManyField
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
import datetime
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
class Organisation(models.Model):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
    hda_id = models.CharField(max_length=512, unique=True, blank=False, null=False)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
    name = models.CharField(max_length=512, unique=False, blank=False, null=False)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
    location = models.CharField(max_length=512, unique=False, blank=True, null=True)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
    website = models.CharField(max_length=1024, unique=False, blank=True, null=True)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
    
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
class Author(models.Model):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
    hda_id = models.CharField(max_length=512, unique=True, blank=False, null=False)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
    lastname = models.CharField(max_length=512, unique=False, blank=True, null=True)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
    firstname = models.CharField(max_length=512, unique=False, blank=True, null=True)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
class TimePeriod(models.Model):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
    TIME_PERIOD_CHOICES = (
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
        (1,u'Primaire'),
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
        (2,u'Collège'),
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
        (3,u'Lycée'),
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
    )
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
    TIME_PERIOD_DICT = {
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
        u'Primaire': 1,
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
        u'Collège': 2,
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
        u'Lycée': 3,
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
    }
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    32
    label = models.CharField(max_length=512, unique=False, blank=False, null=False)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    33
    school_period = models.IntegerField(choices=TIME_PERIOD_CHOICES)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
    
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
    class Meta:
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    36
        unique_together = ("label", "school_period")
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
    def __unicode__(self):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
        return unicode(self.label)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
class Domain(models.Model):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
    DOMAIN_PERIOD_CHOICES = (
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
        (0,u'Global'),
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
        (1,u'Primaire'),
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
        (2,u'Collège'),
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
        (3,u'Lycée'),
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
    )
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
    DOMAIN_PERIOD_DICT = {
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
        u'Global': 0,
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
        u'Primaire': 1,
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
        u'Collège': 2,
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
        u'Lycée': 3,
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
    }
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
    label = models.CharField(max_length=512, unique=False, blank=False, null=False)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
    school_period = models.IntegerField(choices=DOMAIN_PERIOD_CHOICES)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
    class Meta:
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
        unique_together = ("label", "school_period")
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
    def __unicode__(self):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
        return unicode(self.label)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
class DocumentFormat(models.Model):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
    label = models.CharField(max_length=512, unique=True, blank=False, null=False)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
    def __unicode__(self):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
        return unicode(self.label)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
class Tag(models.Model):
3
03ceed56255b add tag url status
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
    72
    TAG_URL_STATUS_CHOICES = (
15
a9136d8f0b4a add commant to reorder tags and query wikipedia
ymh <ymh.work@gmail.com>
parents: 11
diff changeset
    73
        (0,"null_result"),
3
03ceed56255b add tag url status
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
    74
        (1,"redirection"),
03ceed56255b add tag url status
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
    75
        (2,"homonyme"),
15
a9136d8f0b4a add commant to reorder tags and query wikipedia
ymh <ymh.work@gmail.com>
parents: 11
diff changeset
    76
        (3,"match"),
3
03ceed56255b add tag url status
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
    77
    )
03ceed56255b add tag url status
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
    78
    
03ceed56255b add tag url status
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
    79
    TAG_URL_STATUS_DICT = {
15
a9136d8f0b4a add commant to reorder tags and query wikipedia
ymh <ymh.work@gmail.com>
parents: 11
diff changeset
    80
        "null_result":0,
3
03ceed56255b add tag url status
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
    81
        "redirection":1,
03ceed56255b add tag url status
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
    82
        "homonyme":2,
15
a9136d8f0b4a add commant to reorder tags and query wikipedia
ymh <ymh.work@gmail.com>
parents: 11
diff changeset
    83
        "match":3,
3
03ceed56255b add tag url status
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
    84
    }
03ceed56255b add tag url status
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
    85
    
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
    label = models.CharField(max_length=1024, unique=True, blank=False, null=False)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
    original_label = models.CharField(max_length=1024, unique=False, blank=True, null=True, editable=False)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
    alias = models.CharField(max_length=1024, unique=False, blank=True, null=True)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    89
    wikipedia_url = models.URLField(verify_exists=False, max_length=512, blank=True, null=True)
15
a9136d8f0b4a add commant to reorder tags and query wikipedia
ymh <ymh.work@gmail.com>
parents: 11
diff changeset
    90
    wikipedia_pageid = models.BigIntegerField(unique=False, blank=True, null=True)
3
03ceed56255b add tag url status
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
    91
    url_status = models.IntegerField(choices=TAG_URL_STATUS_CHOICES, blank=True, null=True, default=None)
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
    dbpedia_uri = models.URLField(verify_exists=False, max_length=512, blank=True, null=True)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
    wikipedia_activated = models.BooleanField(default=False)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
class TagCategory(models.Model):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
    label = models.CharField(max_length=512, unique=True, blank=False, null=False)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    98
    
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
    def __unicode__(self):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
        return unicode(self.label)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
    
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
class Location(models.Model):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
    name = models.CharField(max_length=512, unique=False, blank=False, null=False)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
    insee = models.CharField(max_length=5, unique=True, blank=False, null=False)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   106
    def __unicode__(self):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   107
        return unicode("%s : %s"%(self.name, self.insee))
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
class Datasheet(models.Model):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
    hda_id = models.CharField(max_length=512, unique=True, blank=False, null=False)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
    author = models.ForeignKey(Author, null=True, blank=True)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   112
    organisation = models.ForeignKey(Organisation)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   113
    title = models.CharField(max_length=2048, unique=False, blank=False, null=False)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   114
    description = models.TextField(blank=True, null=True)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   115
    url = models.URLField(verify_exists=False, max_length=512, blank=True, null=True)
11
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   116
    domains = SortedManyToManyField(Domain, limit_choices_to={'school_period':Domain.DOMAIN_PERIOD_DICT[u'Global']}, related_name="datasheets")
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   117
    primary_periods = SortedManyToManyField(TimePeriod, limit_choices_to={'school_period':TimePeriod.TIME_PERIOD_DICT[u'Primaire']}, related_name="primary_periods_datasheets")
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   118
    college_periods = SortedManyToManyField(TimePeriod, limit_choices_to={'school_period':TimePeriod.TIME_PERIOD_DICT[u'Collège']}, related_name="college_periods_datasheets")
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   119
    highschool_periods = SortedManyToManyField(TimePeriod, limit_choices_to={'school_period':TimePeriod.TIME_PERIOD_DICT[u'Lycée']}, related_name="highschool_periods_datasheets")
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   120
    primary_themes = SortedManyToManyField(Domain, limit_choices_to={'school_period':Domain.DOMAIN_PERIOD_DICT[u'Primaire']}, related_name="primary_themes_datasheets")
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   121
    college_themes = SortedManyToManyField(Domain, limit_choices_to={'school_period':Domain.DOMAIN_PERIOD_DICT[u'Collège']}, related_name="college_themes_datasheets")
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   122
    highschool_themes = SortedManyToManyField(Domain, limit_choices_to={'school_period':Domain.DOMAIN_PERIOD_DICT[u'Lycée']}, related_name="highschool_themes_datasheets")
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   123
    town = models.ForeignKey(Location, null=True, blank=True)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   124
    format = models.ForeignKey(DocumentFormat, null=True, blank=True)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   125
    original_creation_date = models.DateField()
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   126
    original_modification_date = models.DateField()
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   127
    modification_datetime = models.DateTimeField(auto_now=True)
2
b380dc74b590 add import csv command + first test
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   128
    validation_date = models.DateTimeField(null=True, blank=True)
b380dc74b590 add import csv command + first test
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   129
    validated = models.BooleanField(default=False)
b380dc74b590 add import csv command + first test
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   130
    validator = models.ForeignKey(User, null=True, blank=True)
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   131
    tags = models.ManyToManyField(Tag, through='TaggedSheet')
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   132
    
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   133
    
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   134
    def validate(self, user):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   135
        self.validation_date = datetime.datetime.now()
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   136
        self.validated = True
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   137
        self.validator = user
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   138
        self.save()
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   139
    
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   140
    def unvalidate(self):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   141
        self.validation_date = datetime.datetime.min
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   142
        self.validated = False
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   143
        self.validator = None
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   144
        self.save()
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   145
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   146
    @Property
11
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   147
    def domains_list(): #@NoSelf
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   148
        def fget(self):
11
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   149
            return [d.label for d in self.domains.all()]
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   150
        
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   151
        return locals() 
11
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   152
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   153
    @Property
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   154
    def domains_text(): #@NoSelf
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   155
        def fget(self):
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   156
            return "; ".join(self.domains_list)
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   157
        
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   158
        return locals() 
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   159
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   160
    @Property
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   161
    def primary_periods_list(): #@NoSelf
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   162
        def fget(self):
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   163
            return [d.label for d in self.primary_periods.all()] 
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   164
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   165
        return locals() 
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   166
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   167
    
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   168
    @Property
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   169
    def primary_periods_text(): #@NoSelf
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   170
        def fget(self):
11
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   171
            return "; ".join(self.primary_periods_list) 
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   172
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   173
        return locals() 
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   174
11
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   175
    @Property
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   176
    def college_periods_list(): #@NoSelf
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   177
        def fget(self):
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   178
            return [d.label for d in self.college_periods.all()] 
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   179
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   180
        return locals() 
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   181
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   182
    @Property
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   183
    def college_periods_text(): #@NoSelf
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   184
        def fget(self):
11
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   185
            return "; ".join(self.college_periods_list) 
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   186
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   187
        return locals() 
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   188
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   189
    @Property
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   190
    def highschool_periods_list(): #@NoSelf
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   191
        def fget(self):
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   192
            return [d.label for d in self.highschool_periods.all()] 
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   193
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   194
        return locals() 
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   195
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   196
    @Property
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   197
    def highschool_periods_text(): #@NoSelf
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
        def fget(self):
11
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   199
            return "; ".join(self.highschool_periods_list) 
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   200
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   201
        return locals() 
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   202
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   203
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   204
    @Property
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   205
    def primary_themes_list(): #@NoSelf
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   206
        def fget(self):
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   207
            return [d.label for d in self.primary_themes.all()] 
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   208
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   209
        return locals() 
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   210
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   211
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   212
    @Property
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   213
    def primary_themes_text(): #@NoSelf
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   214
        def fget(self):
11
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   215
            return "; ".join(self.primary_themes_list) 
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   216
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   217
        return locals() 
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   218
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   219
    @Property
11
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   220
    def college_themes_list(): #@NoSelf
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   221
        def fget(self):
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   222
            return [d.label for d in self.college_themes.all()] 
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   223
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   224
        return locals() 
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   225
    
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   226
    @Property
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   227
    def college_themes_text(): #@NoSelf
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   228
        def fget(self):
11
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   229
            return "; ".join(self.college_themes_list) 
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   230
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   231
        return locals() 
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   232
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   233
    @Property
11
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   234
    def highschool_themes_list(): #@NoSelf
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   235
        def fget(self):
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   236
            return [d.label for d in self.highschool_themes.all()] 
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   237
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   238
        return locals()
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   239
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   240
    @Property
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   241
    def highschool_themes_text(): #@NoSelf
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   242
        def fget(self):
11
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   243
            return "; ".join(self.highschool_themes_list) 
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   244
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   245
        return locals()
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
    @Property
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
    def town_text(): #@NoSelf
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
        def fget(self):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
            return self.town.name if self.town else ""
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   251
        
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
        return locals()
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
11
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   254
    @Property
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   255
    def tags_text(): #@NoSelf
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   256
        def fget(self):
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   257
            return "; ".join([t.label for t in self.tags.all()])
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   258
        
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   259
        return locals()
143ab88d17f8 add ordered manytomany fields and indexing
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   260
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   261
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   262
class TaggedSheet(models.Model):
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   263
    datasheet = models.ForeignKey(Datasheet)
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   264
    tag = models.ForeignKey(Tag)
2
b380dc74b590 add import csv command + first test
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   265
    original_order = models.IntegerField(default=0)
b380dc74b590 add import csv command + first test
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   266
    order = models.IntegerField(default=0)
b380dc74b590 add import csv command + first test
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   267
    index_note = models.FloatField(default=0.0)
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   268
    categories = models.ManyToManyField(TagCategory)
3
03ceed56255b add tag url status
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   269
    
03ceed56255b add tag url status
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   270
    
0
896db0083b76 first commit
ymh <ymh.work@gmail.com>
parents:
diff changeset
   271