summaryrefslogtreecommitdiff
path: root/bak/unused_apps/resume/models.py
blob: bac3115452cf280d9773551be0cc3de05e3d9f95 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
from django.db import models
from django.utils.encoding import force_str
from django.urls import reverse
from django.template.defaultfilters import slugify

from utils.util import markdown_to_html


class Publisher(models.Model):
    name = models.CharField(max_length=200)
    slug = models.SlugField(max_length=50)
    body_markdown = models.TextField(null=True, blank=True)
    body_html = models.TextField(null=True, blank=True)
    url = models.CharField(max_length=200, blank=True, null=True)
    payment_time = models.DecimalField(max_digits=2, decimal_places=0)
    order = models.DecimalField(max_digits=1, decimal_places=0)

    class Meta:
        ordering = ('order',)

    def __str__(self):
        return self.name

    def save(self, *args, **kwargs):
        if self.body_markdown:
            self.body_html = markdown_to_html(self.body_markdown)
        super(Publisher, self).save()


class PubItem(models.Model):
    title = models.CharField(max_length=200)
    slug = models.CharField(max_length=50)
    body_markdown = models.TextField(null=True, blank=True)
    body_html = models.TextField(null=True, blank=True)
    url = models.CharField(max_length=200, blank=True, null=True)
    pub_date = models.DateTimeField('Date published')
    publisher = models.ForeignKey(Publisher, on_delete=models.CASCADE)

    class Meta:
        ordering = ('-pub_date',)

    def __str__(self):
        return self.title

    def get_absolute_url(self):
        return reverse("resume:detail", kwargs={"publisher": self.publisher.slug, "slug": self.slug})

    def admin_link(self):
        return force_str('<a href="%s">Visit Site</a>' % (self.url))
    admin_link.allow_tags = True
    admin_link.short_description = 'Live Article'

    def save(self, *args, **kwargs):
        if self.body_markdown:
            self.body_html = markdown_to_html(self.body_markdown)
        super(PubItem, self).save()


class Job(models.Model):
    title = models.CharField(max_length=200)
    employer = models.CharField(max_length=200, blank=True)
    date_start = models.DateField('Date Start')
    date_end = models.DateField('Date End', null=True, blank=True)
    body_markdown = models.TextField(blank=True)
    body_html = models.TextField(blank=True)

    class Meta:
        ordering = ('-date_end',)

    def __str__(self):
        return '{} - {}'.format(self.title, self.employer)  # py3.1+ only

    def save(self, *args, **kwargs):
        if self.body_markdown:
            self.body_html = markdown_to_html(self.body_markdown)
        super(Job, self).save()


class Resume(models.Model):
    title = models.CharField(max_length=200)
    slug = models.CharField(max_length=50, blank=True)
    profile = models.TextField()
    profile_html = models.TextField(blank=True)
    skills = models.TextField()
    skills_html = models.TextField(blank=True)
    jobs = models.ManyToManyField(Job)

    def __str__(self):
        return self.title

    def save(self, *args, **kwargs):
        if self._state.adding and not self.slug:
            self.slug = slugify(self.title)
        if self.skills:
            self.skills_html = markdown_to_html(self.skills)
        if self.profile:
            self.profile_html = markdown_to_html(self.profile)
        super(Resume, self).save()