2015-12-01 23:24:21 +01:00
|
|
|
import os
|
2015-12-01 22:18:28 +01:00
|
|
|
from django.db import models
|
2024-11-11 07:46:34 +01:00
|
|
|
from django.urls import reverse
|
2015-12-01 23:24:21 +01:00
|
|
|
from django.utils import timezone
|
|
|
|
from django.conf import settings
|
2015-12-24 15:34:20 +01:00
|
|
|
from django.core.exceptions import ObjectDoesNotExist
|
2022-03-07 20:49:48 +01:00
|
|
|
from django.utils.functional import cached_property
|
2016-09-03 21:52:08 +02:00
|
|
|
from django.utils.text import get_valid_filename
|
2015-12-01 23:24:21 +01:00
|
|
|
|
2024-03-19 22:47:45 +01:00
|
|
|
from personalni.models import Organizator
|
2016-08-25 08:35:45 +02:00
|
|
|
|
2015-12-05 01:19:49 +01:00
|
|
|
import subprocess
|
2016-01-09 17:03:40 +01:00
|
|
|
from reversion import revisions as reversion
|
2015-12-01 23:24:21 +01:00
|
|
|
|
2016-08-29 15:05:23 +02:00
|
|
|
from unidecode import unidecode
|
|
|
|
|
2016-08-29 14:59:10 +02:00
|
|
|
|
2015-12-01 23:24:21 +01:00
|
|
|
def generate_filename(self, filename):
|
2022-02-15 17:48:16 +01:00
|
|
|
""" vyrobí jméno souboru podle původního jména a času nahrátí """
|
2019-05-11 01:15:05 +02:00
|
|
|
clean = get_valid_filename(
|
|
|
|
unidecode(
|
|
|
|
filename.replace('/', '-').replace('\0', '').replace(":", "_")
|
|
|
|
)
|
|
|
|
)
|
|
|
|
fname = "%s_%s" % (
|
|
|
|
timezone.now().strftime('%Y-%m-%d-%H_%M'),
|
|
|
|
clean)
|
|
|
|
return os.path.join(settings.KOREKTURY_PDF_DIR, fname)
|
2015-12-01 23:24:21 +01:00
|
|
|
|
2018-08-20 22:30:16 +02:00
|
|
|
#@reversion.register(ignore_duplicates=True)
|
2015-12-01 23:24:21 +01:00
|
|
|
class KorekturovanePDF(models.Model):
|
2019-05-11 01:15:05 +02:00
|
|
|
class Meta:
|
|
|
|
ordering = ['-cas']
|
|
|
|
db_table = 'korekturovane_cislo'
|
|
|
|
verbose_name = u'PDF k opravám'
|
|
|
|
verbose_name_plural = u'PDF k opravám'
|
|
|
|
|
|
|
|
#Interní ID
|
2019-05-11 02:00:41 +02:00
|
|
|
id = models.AutoField(primary_key = True)
|
2019-05-11 01:15:05 +02:00
|
|
|
|
|
|
|
cas = models.DateTimeField(u'čas vložení PDF',default=timezone.now,help_text = 'Čas vložení PDF')
|
|
|
|
|
2023-06-19 21:41:59 +02:00
|
|
|
nazev = models.CharField(u'název PDF',blank = False,max_length=50, help_text='Název (např. `22.1 | analyza v4` nebo `propagace | letacek v0`) korekturovaného PDF')
|
2019-05-11 01:15:05 +02:00
|
|
|
|
|
|
|
komentar = models.TextField(u'komentář k PDF',blank = True, help_text='Komentář ke korekturovanému PDF (např. na co se zaměřit)')
|
|
|
|
|
|
|
|
pdf = models.FileField(u'PDF', upload_to = generate_filename)
|
|
|
|
|
2024-06-12 02:02:37 +02:00
|
|
|
orgove = models.ManyToManyField(Organizator, blank=True,
|
|
|
|
help_text='Zodpovědní organizátoři za obsah (chodí jim maily o nových korekturách)',
|
|
|
|
default=None)
|
2019-05-11 01:15:05 +02:00
|
|
|
|
|
|
|
stran = models.IntegerField(u'počet stran', help_text='Počet stran PDF',
|
|
|
|
default=0)
|
|
|
|
STATUS_PRIDAVANI = 'pridavani'
|
|
|
|
STATUS_ZANASENI = 'zanaseni'
|
|
|
|
STATUS_ZASTARALE = 'zastarale'
|
|
|
|
STATUS_CHOICES = (
|
|
|
|
(STATUS_PRIDAVANI, u'Přidávání korektur'),
|
|
|
|
(STATUS_ZANASENI, u'Korektury jsou zanášeny'),
|
|
|
|
(STATUS_ZASTARALE, u'Stará verze, nekorigovat'),
|
|
|
|
)
|
|
|
|
status = models.CharField(u'stav PDF',max_length=16, choices=STATUS_CHOICES, blank=False,
|
|
|
|
default = STATUS_PRIDAVANI)
|
2019-05-11 02:00:41 +02:00
|
|
|
|
2021-12-06 00:05:57 +01:00
|
|
|
poslat_mail = models.BooleanField('Poslat mail o novém PDF', default=True,
|
|
|
|
help_text='Určuje, zda se má o nově nahraném PDF poslat e-mail do mam-org. Při upravování existujícího souboru už nemá žádný vliv.',
|
|
|
|
)
|
|
|
|
|
2019-05-11 02:00:41 +02:00
|
|
|
|
2019-05-11 01:15:05 +02:00
|
|
|
#TODO Nepovinný foreign key k číslu
|
|
|
|
|
|
|
|
def get_prefix(self):
|
|
|
|
"""Vrať řetězec, ke kterému se připojí číslo a .png"""
|
|
|
|
# vrátíme jméno souboru bez cesty
|
|
|
|
return os.path.basename(self.pdf.file.name)
|
|
|
|
|
|
|
|
def convert(self):
|
|
|
|
"""Vytvoří jedno png za každou stranu pdf a uloží se"""
|
|
|
|
dirname = os.path.join(settings.MEDIA_ROOT, settings.KOREKTURY_IMG_DIR)
|
|
|
|
if not os.path.exists(dirname):
|
|
|
|
os.mkdir(dirname)
|
|
|
|
self.stran = 0
|
|
|
|
while True:
|
|
|
|
res = subprocess.call([
|
2020-08-19 09:03:58 +02:00
|
|
|
#Parametry inspirovány chybovou hláškou imagemagicku
|
|
|
|
"gs",
|
|
|
|
"-sstdout=%stderr",
|
|
|
|
"-dSAFER",
|
|
|
|
"-dNOPAUSE",
|
|
|
|
"-dBATCH",
|
|
|
|
"-dNOPROMPT",
|
|
|
|
"-sDEVICE=pngalpha",
|
|
|
|
"-r180x180",
|
|
|
|
"-dFirstPage=%d" % (self.stran+1),
|
|
|
|
"-dLastPage=%d" % (self.stran+1),
|
|
|
|
"-sOutputFile="+os.path.join(
|
2019-05-11 01:15:05 +02:00
|
|
|
dirname,
|
2020-08-19 09:03:58 +02:00
|
|
|
"%s-%d.png" % (self.get_prefix(), self.stran)),
|
|
|
|
"-f%s" % (self.pdf.path)
|
2019-05-11 01:15:05 +02:00
|
|
|
])
|
2020-08-19 09:03:58 +02:00
|
|
|
if not os.path.exists(os.path.join(
|
|
|
|
dirname,
|
|
|
|
"%s-%d.png" % (self.get_prefix(), self.stran))):
|
2019-05-11 01:15:05 +02:00
|
|
|
break
|
|
|
|
self.stran += 1
|
|
|
|
# Změnil se počet stran, ukládáme
|
|
|
|
super(KorekturovanePDF, self).save()
|
|
|
|
|
2020-09-07 23:17:36 +02:00
|
|
|
def save(self, **kwargs):
|
2019-05-11 01:15:05 +02:00
|
|
|
# Pokud se nezmenilo PDF, tak nepregenerovavej nahledy
|
|
|
|
try:
|
|
|
|
original = KorekturovanePDF.objects.get(pk=self.pk)
|
|
|
|
if original.pdf == self.pdf:
|
|
|
|
super(KorekturovanePDF, self).save()
|
|
|
|
return
|
|
|
|
except ObjectDoesNotExist:
|
|
|
|
pass
|
|
|
|
# uložíme nahrávané pdf
|
2020-09-07 23:17:36 +02:00
|
|
|
super(KorekturovanePDF, self).save(kwargs)
|
2019-05-11 01:15:05 +02:00
|
|
|
|
|
|
|
# uložíme png a změněný počet stran
|
|
|
|
self.convert()
|
2015-12-01 23:24:21 +01:00
|
|
|
|
2022-03-07 20:49:48 +01:00
|
|
|
@cached_property
|
2021-09-25 15:32:51 +02:00
|
|
|
def cislo_a_tema(self):
|
|
|
|
nazev_split = self.nazev.split()
|
|
|
|
try:
|
2021-09-25 15:37:38 +02:00
|
|
|
return nazev_split[0] # + " " + nazev_split[2]
|
2021-09-25 15:32:51 +02:00
|
|
|
except IndexError:
|
|
|
|
return self.nazev
|
2024-11-11 07:46:34 +01:00
|
|
|
|
|
|
|
def get_absolute_url(self):
|
|
|
|
return reverse('korektury', kwargs={'pdf': self.id})
|
2021-09-25 15:32:51 +02:00
|
|
|
|
|
|
|
|
2018-08-20 22:30:16 +02:00
|
|
|
@reversion.register(ignore_duplicates=True)
|
2015-12-01 23:24:21 +01:00
|
|
|
class Oprava(models.Model):
|
2019-05-11 01:15:05 +02:00
|
|
|
class Meta:
|
|
|
|
db_table = 'opravy'
|
|
|
|
verbose_name = u'Oprava'
|
|
|
|
verbose_name_plural = u'Opravy'
|
|
|
|
ordering = ['y','x']
|
|
|
|
|
|
|
|
#Interní ID
|
2019-05-11 02:00:41 +02:00
|
|
|
id = models.AutoField(primary_key = True)
|
2019-05-11 01:15:05 +02:00
|
|
|
|
2019-06-10 23:55:45 +02:00
|
|
|
pdf = models.ForeignKey(KorekturovanePDF, default=-1, on_delete=models.PROTECT)
|
2019-05-11 01:15:05 +02:00
|
|
|
|
|
|
|
strana = models.IntegerField(u'strana s opravou', help_text='Strana s opravou (od 0)')
|
|
|
|
|
|
|
|
x = models.IntegerField(u'x-ová souřadnice bugu')
|
|
|
|
y = models.IntegerField(u'y-ová souřadnice bugu')
|
|
|
|
|
|
|
|
STATUS_K_OPRAVE = 'k_oprave'
|
|
|
|
STATUS_OPRAVENO = 'opraveno'
|
|
|
|
STATUS_NENI_CHYBA = 'neni_chyba'
|
|
|
|
STATUS_K_ZANESENI = 'k_zaneseni'
|
|
|
|
STATUS_CHOICES = (
|
|
|
|
(STATUS_K_OPRAVE, u'K opravě'),
|
|
|
|
(STATUS_OPRAVENO, u'Opraveno'),
|
|
|
|
(STATUS_NENI_CHYBA, u'Není chyba'),
|
|
|
|
(STATUS_K_ZANESENI, u'K zanesení do TeXu'),
|
|
|
|
)
|
|
|
|
status = models.CharField(u'stav opravy',max_length=16, choices=STATUS_CHOICES, blank=False,
|
|
|
|
default = STATUS_K_OPRAVE)
|
|
|
|
|
|
|
|
autor = models.ForeignKey(Organizator, blank = True,
|
|
|
|
help_text='Autor opravy',
|
2019-06-10 23:55:45 +02:00
|
|
|
null = True, on_delete=models.SET_NULL)
|
2019-05-11 01:15:05 +02:00
|
|
|
|
|
|
|
text = models.TextField(u'text opravy',blank = True, help_text='Text opravy')
|
2015-12-01 23:24:21 +01:00
|
|
|
|
2019-05-11 02:00:41 +02:00
|
|
|
# def __init__(self,dictionary):
|
|
|
|
# for k,v in dictionary.items():
|
|
|
|
# setattr(self,k,v)
|
2015-12-01 23:24:21 +01:00
|
|
|
|
2019-05-11 01:15:05 +02:00
|
|
|
def __str__(self):
|
2019-05-19 10:22:00 +02:00
|
|
|
return '{} od {}: {}'.format(self.status,self.autor,self.text)
|
2015-12-01 23:24:21 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
2018-08-20 22:30:16 +02:00
|
|
|
@reversion.register(ignore_duplicates=True)
|
2015-12-03 00:07:23 +01:00
|
|
|
class Komentar(models.Model):
|
2019-05-11 01:15:05 +02:00
|
|
|
class Meta:
|
|
|
|
db_table = 'komentare'
|
|
|
|
verbose_name = u'Komentář k opravě'
|
|
|
|
verbose_name_plural = u'Komentáře k opravě'
|
|
|
|
ordering = ['cas']
|
|
|
|
|
|
|
|
#Interní ID
|
2019-05-11 02:00:41 +02:00
|
|
|
id = models.AutoField(primary_key = True)
|
2019-05-11 01:15:05 +02:00
|
|
|
|
|
|
|
cas = models.DateTimeField(u'čas komentáře',default=timezone.now,help_text = 'Čas zadání komentáře')
|
|
|
|
|
2019-06-10 23:55:45 +02:00
|
|
|
oprava = models.ForeignKey(Oprava, on_delete=models.CASCADE)
|
2019-05-11 01:15:05 +02:00
|
|
|
autor = models.ForeignKey(Organizator, blank = True,
|
|
|
|
help_text = u'Autor komentáře',
|
2019-06-10 23:55:45 +02:00
|
|
|
null = True, on_delete=models.SET_NULL)
|
2019-05-11 01:15:05 +02:00
|
|
|
|
|
|
|
text = models.TextField(u'text komentáře',blank = True, help_text='Text komentáře')
|
|
|
|
|
|
|
|
def __str__(self):
|
2019-05-19 10:22:00 +02:00
|
|
|
return '{} od {}: {}'.format(self.cas,self.autor,self.text)
|
2015-12-01 23:24:21 +01:00
|
|
|
|
|
|
|
|
2015-12-01 22:18:28 +01:00
|
|
|
|