Relink – post, asi done?
This commit is contained in:
		
							parent
							
								
									cdc1472595
								
							
						
					
					
						commit
						e3771f865d
					
				
					 16 changed files with 209 additions and 241 deletions
				
			
		
							
								
								
									
										20
									
								
								galerie/migrations/0012_soustredeni_relink.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								galerie/migrations/0012_soustredeni_relink.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,20 @@ | |||
| # Generated by Django 4.2.11 on 2024-05-01 13:07 | ||||
| 
 | ||||
| from django.db import migrations, models | ||||
| import django.db.models.deletion | ||||
| 
 | ||||
| 
 | ||||
| class Migration(migrations.Migration): | ||||
| 
 | ||||
|     dependencies = [ | ||||
|         ('soustredeni', '0001_split_from_seminar'), | ||||
|         ('galerie', '0011_pre_split_soustredeni'), | ||||
|     ] | ||||
| 
 | ||||
|     operations = [ | ||||
|         migrations.AlterField( | ||||
|             model_name='galerie', | ||||
|             name='soustredeni', | ||||
|             field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.PROTECT, to='soustredeni.soustredeni'), | ||||
|         ), | ||||
|     ] | ||||
							
								
								
									
										14
									
								
								galerie/migrations/0013_post_split_soustredeni.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								galerie/migrations/0013_post_split_soustredeni.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,14 @@ | |||
| # Generated by Django 4.2.11 on 2024-05-01 13:35 | ||||
| 
 | ||||
| from django.db import migrations | ||||
| 
 | ||||
| 
 | ||||
| class Migration(migrations.Migration): | ||||
| 
 | ||||
|     dependencies = [ | ||||
|         ('galerie', '0012_soustredeni_relink'), | ||||
|         ('soustredeni', '0003_post_split_soustredeni'), | ||||
|     ] | ||||
| 
 | ||||
|     operations = [ | ||||
|     ] | ||||
|  | @ -7,7 +7,7 @@ from imagekit.processors import ResizeToFit, Transpose | |||
| 
 | ||||
| import os | ||||
| 
 | ||||
| from seminar.models import Soustredeni | ||||
| from soustredeni.models import Soustredeni | ||||
| 
 | ||||
| VZDY=0 | ||||
| ORG=1 | ||||
|  |  | |||
							
								
								
									
										20
									
								
								prednasky/migrations/0017_soustredeni_relink.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								prednasky/migrations/0017_soustredeni_relink.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,20 @@ | |||
| # Generated by Django 4.2.11 on 2024-05-01 13:07 | ||||
| 
 | ||||
| from django.db import migrations, models | ||||
| import django.db.models.deletion | ||||
| 
 | ||||
| 
 | ||||
| class Migration(migrations.Migration): | ||||
| 
 | ||||
|     dependencies = [ | ||||
|         ('soustredeni', '0001_split_from_seminar'), | ||||
|         ('prednasky', '0016_pre_split_soustredeni'), | ||||
|     ] | ||||
| 
 | ||||
|     operations = [ | ||||
|         migrations.AlterField( | ||||
|             model_name='seznam', | ||||
|             name='soustredeni', | ||||
|             field=models.ForeignKey(default=None, null=True, on_delete=django.db.models.deletion.PROTECT, to='soustredeni.soustredeni'), | ||||
|         ), | ||||
|     ] | ||||
							
								
								
									
										14
									
								
								prednasky/migrations/0018_post_split_soustredeni.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								prednasky/migrations/0018_post_split_soustredeni.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,14 @@ | |||
| # Generated by Django 4.2.11 on 2024-05-01 13:35 | ||||
| 
 | ||||
| from django.db import migrations | ||||
| 
 | ||||
| 
 | ||||
| class Migration(migrations.Migration): | ||||
| 
 | ||||
|     dependencies = [ | ||||
|         ('prednasky', '0017_soustredeni_relink'), | ||||
|         ('soustredeni', '0003_post_split_soustredeni'), | ||||
|     ] | ||||
| 
 | ||||
|     operations = [ | ||||
|     ] | ||||
|  | @ -2,7 +2,7 @@ | |||
| 
 | ||||
| from django.db import models | ||||
| 
 | ||||
| from seminar.models import Soustredeni | ||||
| from soustredeni.models import Soustredeni | ||||
| from personalni.models import Organizator | ||||
| 
 | ||||
| STAV_NAVRH = 1 | ||||
|  |  | |||
							
								
								
									
										67
									
								
								seminar/migrations/0124_remove_sous_from_seminar.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								seminar/migrations/0124_remove_sous_from_seminar.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,67 @@ | |||
| # Generated by Django 4.2.11 on 2024-05-01 13:13 | ||||
| 
 | ||||
| from django.db import migrations | ||||
| 
 | ||||
| 
 | ||||
| class Migration(migrations.Migration): | ||||
| 
 | ||||
|     dependencies = [ | ||||
|         ('seminar', '0123_soustredeni_unmanage'), | ||||
|         ('soustredeni', '0001_split_from_seminar'), | ||||
|         ('galerie', '0012_soustredeni_relink'), | ||||
|         ('prednasky', '0017_soustredeni_relink'), | ||||
|     ] | ||||
| 
 | ||||
|     operations = [ | ||||
|         migrations.RemoveField( | ||||
|             model_name='konfery_ucastnici', | ||||
|             name='konfera', | ||||
|         ), | ||||
|         migrations.RemoveField( | ||||
|             model_name='konfery_ucastnici', | ||||
|             name='resitel', | ||||
|         ), | ||||
|         migrations.RemoveField( | ||||
|             model_name='soustredeni', | ||||
|             name='organizatori', | ||||
|         ), | ||||
|         migrations.RemoveField( | ||||
|             model_name='soustredeni', | ||||
|             name='rocnik', | ||||
|         ), | ||||
|         migrations.RemoveField( | ||||
|             model_name='soustredeni', | ||||
|             name='ucastnici', | ||||
|         ), | ||||
|         migrations.RemoveField( | ||||
|             model_name='soustredeni_organizatori', | ||||
|             name='organizator', | ||||
|         ), | ||||
|         migrations.RemoveField( | ||||
|             model_name='soustredeni_organizatori', | ||||
|             name='soustredeni', | ||||
|         ), | ||||
|         migrations.RemoveField( | ||||
|             model_name='soustredeni_ucastnici', | ||||
|             name='resitel', | ||||
|         ), | ||||
|         migrations.RemoveField( | ||||
|             model_name='soustredeni_ucastnici', | ||||
|             name='soustredeni', | ||||
|         ), | ||||
|         migrations.DeleteModel( | ||||
|             name='Konfera', | ||||
|         ), | ||||
|         migrations.DeleteModel( | ||||
|             name='Konfery_Ucastnici', | ||||
|         ), | ||||
|         migrations.DeleteModel( | ||||
|             name='Soustredeni', | ||||
|         ), | ||||
|         migrations.DeleteModel( | ||||
|             name='Soustredeni_Organizatori', | ||||
|         ), | ||||
|         migrations.DeleteModel( | ||||
|             name='Soustredeni_Ucastnici', | ||||
|         ), | ||||
|     ] | ||||
							
								
								
									
										14
									
								
								seminar/migrations/0125_post_split_soustredeni.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								seminar/migrations/0125_post_split_soustredeni.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,14 @@ | |||
| # Generated by Django 4.2.11 on 2024-05-01 13:35 | ||||
| 
 | ||||
| from django.db import migrations | ||||
| 
 | ||||
| 
 | ||||
| class Migration(migrations.Migration): | ||||
| 
 | ||||
|     dependencies = [ | ||||
|         ('seminar', '0124_remove_sous_from_seminar'), | ||||
|         ('soustredeni', '0003_post_split_soustredeni'), | ||||
|     ] | ||||
| 
 | ||||
|     operations = [ | ||||
|     ] | ||||
|  | @ -1,10 +1,13 @@ | |||
| from .tvorba import * | ||||
| from .odevzdavatko import * | ||||
| from .base import * | ||||
| from .soustredeni import * | ||||
| from .pomocne import * | ||||
| from .treenode import * | ||||
| from .novinky import * | ||||
| 
 | ||||
| from various.models import Nastaveni | ||||
| from personalni.models import Organizator, Resitel, Skola, Prijemce, Osoba | ||||
| from soustredeni.models import Soustredeni, Soustredeni_Ucastnici, Soustredeni_Organizatori, Konfera, Konfery_Ucastnici | ||||
| 
 | ||||
| # Kvůli migr. 0041 | ||||
| from soustredeni.models import generate_filename_konfera | ||||
|  |  | |||
|  | @ -1,231 +0,0 @@ | |||
| # -*- coding: utf-8 -*- | ||||
| import logging | ||||
| import os | ||||
| 
 | ||||
| from django.db import models | ||||
| from django.urls import reverse | ||||
| from reversion import revisions as reversion | ||||
| 
 | ||||
| from django.conf import settings | ||||
| 
 | ||||
| from personalni.models import Resitel, Organizator | ||||
| 
 | ||||
| from .base import SeminarModelBase | ||||
| from seminar.models import tvorba as am | ||||
| 
 | ||||
| logger = logging.getLogger(__name__) | ||||
| 
 | ||||
| 
 | ||||
| @reversion.register(ignore_duplicates=True) | ||||
| class Soustredeni(SeminarModelBase): | ||||
| 
 | ||||
| 	class Meta: | ||||
| 		managed = False | ||||
| 		db_table = 'seminar_soustredeni' | ||||
| 		verbose_name = 'Soustředění' | ||||
| 		verbose_name_plural = 'Soustředění' | ||||
| 		ordering = ['-rocnik__rocnik', '-datum_zacatku'] | ||||
| 
 | ||||
| 	# Interní ID | ||||
| 	id = models.AutoField(primary_key = True) | ||||
| 
 | ||||
| 	rocnik = models.ForeignKey(am.Rocnik, verbose_name='ročník', related_name='soustredeni_old', | ||||
| 		on_delete=models.PROTECT) | ||||
| 
 | ||||
| 	datum_zacatku = models.DateField('datum začátku', blank=True, null=True, | ||||
| 		help_text='První den soustředění') | ||||
| 
 | ||||
| 	datum_konce = models.DateField('datum konce', blank=True, null=True, | ||||
| 		help_text='Poslední den soustředění') | ||||
| 
 | ||||
| 	verejne_db = models.BooleanField('soustředění zveřejněno', db_column='verejne', default=False) | ||||
| 
 | ||||
| 	misto = models.CharField('místo soustředění', max_length=256, blank=True, default='', | ||||
| 		help_text='Místo (název obce, volitelně též objektu') | ||||
| 
 | ||||
| 	ucastnici = models.ManyToManyField(Resitel, verbose_name='účastníci soustředění', | ||||
| 		related_name='soustredeni_old', | ||||
| 		help_text='Seznam účastníků soustředění', through='Soustredeni_Ucastnici') | ||||
| 
 | ||||
| 	organizatori = models.ManyToManyField(Organizator, | ||||
| 			related_name='soustredeni_old', | ||||
| 			verbose_name='Organizátoři soustředění', | ||||
| 			help_text='Seznam organizátorů soustředění', | ||||
| 			through='Soustredeni_Organizatori') | ||||
| 
 | ||||
| 	text = models.TextField('text k soustředění (HTML)', blank=True, default='') | ||||
| 
 | ||||
| 	TYP_JARNI = 'jarni' | ||||
| 	TYP_PODZIMNI = 'podzimni' | ||||
| 	TYP_VIKEND = 'vikend' | ||||
| 	TYP_VYLET = 'vylet' | ||||
| 	TYP_CHOICES = [ | ||||
| 		(TYP_JARNI, 'Jarní soustředění'), | ||||
| 		(TYP_PODZIMNI, 'Podzimní soustředění'), | ||||
| 		(TYP_VIKEND, 'Víkendový sraz'), | ||||
| 		(TYP_VYLET, 'Výlet'), | ||||
| 		] | ||||
| 	typ = models.CharField('typ akce', max_length=16, choices=TYP_CHOICES, blank=False, default=TYP_PODZIMNI) | ||||
| 
 | ||||
| 	exportovat = models.BooleanField('export do AESOPa', db_column='exportovat', default=False, | ||||
| 			help_text='Exportuje se jen podle tohoto flagu (ne veřejnosti)') | ||||
| 
 | ||||
| 	def __str__(self): | ||||
| 		return '{} ({})'.format(self.misto, self.datum_zacatku) | ||||
| 
 | ||||
| 	def verejne(self): | ||||
| 		return self.verejne_db | ||||
| 	verejne.boolean = True | ||||
| 
 | ||||
| 	def verejne_url(self): | ||||
| 		#return reverse('seminar_soustredeni', kwargs={'pk': self.id}) | ||||
| 		return reverse('seminar_seznam_soustredeni') | ||||
| 
 | ||||
| 
 | ||||
| @reversion.register(ignore_duplicates=True) | ||||
| class Soustredeni_Ucastnici(SeminarModelBase): | ||||
| # zmena dedicnosti z models.Model na SeminarModelBase, potencialni vznik bugu | ||||
| 
 | ||||
| 	class Meta: | ||||
| 		managed = False | ||||
| 		db_table = 'seminar_soustredeni_ucastnici' | ||||
| 		verbose_name = 'Účast na soustředění' | ||||
| 		verbose_name_plural = 'Účasti na soustředění' | ||||
| 		ordering = ['soustredeni', 'resitel'] | ||||
| 
 | ||||
| 	# Interní ID | ||||
| 	id = models.AutoField(primary_key = True) | ||||
| 
 | ||||
| 	resitel = models.ForeignKey(Resitel, verbose_name='řešitel', | ||||
| 		related_name='sous_ucastnici', | ||||
| 		 on_delete=models.PROTECT) | ||||
| 
 | ||||
| 	soustredeni = models.ForeignKey(Soustredeni, verbose_name='soustředění', | ||||
| 		related_name='sous_ucastnici', | ||||
| 		on_delete=models.PROTECT) | ||||
| 
 | ||||
| 	poznamka = models.TextField('neveřejná poznámka', blank=True, | ||||
| 		help_text='Neveřejná poznámka k účasti (plain text)') | ||||
| 
 | ||||
| 	def __str__(self): | ||||
| 		return '{} na {}'.format(self.resitel, self.soustredeni) | ||||
| 		# NOTE: Poteciální DB HOG bez select_related | ||||
| 
 | ||||
| 
 | ||||
| @reversion.register(ignore_duplicates=True) | ||||
| class Soustredeni_Organizatori(SeminarModelBase): | ||||
| # zmena dedicnosti z models.Model na SeminarModelBase, potencialni vznik bugu | ||||
| 
 | ||||
| 	class Meta: | ||||
| 		managed = False | ||||
| 		db_table = 'seminar_soustredeni_organizatori' | ||||
| 		verbose_name = 'Účast organizátorů na soustředění' | ||||
| 		verbose_name_plural = 'Účasti organizátorů na soustředění' | ||||
| 		ordering = ['soustredeni', 'organizator'] | ||||
| 
 | ||||
| 	# Interní ID | ||||
| 	id = models.AutoField(primary_key = True) | ||||
| 
 | ||||
| 	organizator = models.ForeignKey(Organizator, verbose_name='organizátor', | ||||
| 		related_name='sous_orgove', | ||||
| 		on_delete=models.PROTECT) | ||||
| 
 | ||||
| 	soustredeni = models.ForeignKey(Soustredeni, verbose_name='soustředění', | ||||
| 		related_name='sous_orgove', | ||||
| 		on_delete=models.PROTECT) | ||||
| 
 | ||||
| 	poznamka = models.TextField('neveřejná poznámka', blank=True, | ||||
| 		help_text='Neveřejná poznámka k účasti organizátora (plain text)') | ||||
| 
 | ||||
| 	def __str__(self): | ||||
| 		return '{} na {}'.format(self.organizator, self.soustredeni) | ||||
| 		# NOTE: Poteciální DB HOG bez select_related | ||||
| 
 | ||||
| 
 | ||||
| # FIXME cycle import | ||||
| 
 | ||||
| 
 | ||||
| # Django neumí jednoduše serializovat partial nebo třídu s __call__ | ||||
| # (https://docs.djangoproject.com/en/1.8/topics/migrations/), | ||||
| # neprojdou pak migrace. Takže rozlišení funkcí generujících názvy souboru | ||||
| # podle adresáře řešíme takto. | ||||
| 
 | ||||
| ## | ||||
| def generate_filename_konfera(self, filename): | ||||
| 	return os.path.join( | ||||
| 		settings.SEMINAR_KONFERY_DIR, | ||||
| 		am.aux_generate_filename(self, filename) | ||||
| 	) | ||||
| 
 | ||||
| ## | ||||
| 
 | ||||
| @reversion.register(ignore_duplicates=True) | ||||
| class Konfera(am.Problem): | ||||
| 	class Meta: | ||||
| 		managed = False | ||||
| 		db_table = 'seminar_konfera' | ||||
| 		verbose_name = 'Konfera' | ||||
| 		verbose_name_plural = 'Konfery' | ||||
| 
 | ||||
| 	problem_ptr_old = models.OneToOneField(am.Problem, parent_link=True, related_name='konfera_old', on_delete=models.PROTECT, primary_key=True) | ||||
| 
 | ||||
| 	anotace = models.TextField('anotace', blank=True, | ||||
| 							   help_text='Popis, o čem bude konfera.') | ||||
| 
 | ||||
| 	abstrakt = models.TextField('abstrakt', blank=True, | ||||
| 								help_text='Abstrakt konfery tak, jak byl uveden ve sborníku') | ||||
| 
 | ||||
| 	# FIXME: Umíme omezit jen na účastníky daného soustřeďka? | ||||
| 	ucastnici = models.ManyToManyField(Resitel, verbose_name='účastníci konfery', | ||||
| 									related_name='konfera_old', | ||||
| 									   help_text='Seznam účastníků konfery', through='Konfery_Ucastnici') | ||||
| 
 | ||||
| 	soustredeni = models.ForeignKey(Soustredeni, verbose_name='soustředění', | ||||
| 									related_name='konfery_old', on_delete = models.SET_NULL, null=True) | ||||
| 
 | ||||
| 	TYP_VELETRH = 'veletrh' | ||||
| 	TYP_PREZENTACE = 'prezentace' | ||||
| 	TYP_CHOICES = [ | ||||
| 		(TYP_VELETRH, 'Veletrh (postery)'), | ||||
| 		(TYP_PREZENTACE, 'Prezentace (přednáška)'), | ||||
| 	] | ||||
| 	typ_prezentace = models.CharField('typ prezentace', max_length=16, choices=TYP_CHOICES, | ||||
| 									  blank=False, default=TYP_VELETRH) | ||||
| 
 | ||||
| 	prezentace = models.FileField('prezentace',help_text = 'Prezentace nebo fotka posteru', | ||||
| 								  upload_to = generate_filename_konfera, blank=True) | ||||
| 
 | ||||
| 	materialy = models.FileField('materialy', | ||||
| 								 help_text = 'Další materiály ke konfeře zabalené do jednoho souboru', | ||||
| 								 upload_to = generate_filename_konfera, blank=True) | ||||
| 
 | ||||
| 	def __str__(self): | ||||
| 		return "{}: ({})".format(self.nazev, self.soustredeni) | ||||
| 
 | ||||
| 	def cislo_node(self): | ||||
| 		return None | ||||
| 
 | ||||
| 
 | ||||
| @reversion.register(ignore_duplicates=True) | ||||
| class Konfery_Ucastnici(models.Model): | ||||
| 
 | ||||
| 	class Meta: | ||||
| 		managed = False | ||||
| 		db_table = 'seminar_konfery_ucastnici' | ||||
| 		verbose_name = 'Účast na konfeře' | ||||
| 		verbose_name_plural = 'Účasti na konfeře' | ||||
| 		ordering = ['konfera', 'resitel'] | ||||
| 
 | ||||
| 	# Interní ID | ||||
| 	id = models.AutoField(primary_key = True) | ||||
| 
 | ||||
| 	resitel = models.ForeignKey(Resitel, verbose_name='řešitel', on_delete=models.PROTECT, related_name='konf_uc') | ||||
| 
 | ||||
| 	konfera = models.ForeignKey(Konfera, verbose_name='konfera', on_delete=models.CASCADE, related_name='konf_uc') | ||||
| 
 | ||||
| 	poznamka = models.TextField('neveřejná poznámka', blank=True, | ||||
| 		help_text='Neveřejná poznámka k účasti (plain text)') | ||||
| 
 | ||||
| 	def __str__(self): | ||||
| 		return '{} na {}'.format(self.resitel, self.konfera) | ||||
| 		# NOTE: Poteciální DB HOG bez select_related | ||||
|  | @ -2,7 +2,7 @@ from django.contrib import admin | |||
| from django.forms import widgets | ||||
| from django.db import models | ||||
| 
 | ||||
| from seminar.models import soustredeni as m | ||||
| import soustredeni.models as m | ||||
| 
 | ||||
| 
 | ||||
| class SoustredeniUcastniciInline(admin.TabularInline): | ||||
|  |  | |||
|  | @ -37,7 +37,8 @@ class Migration(migrations.Migration): | |||
|                 ('typ_prezentace', models.CharField(choices=[('veletrh', 'Veletrh (postery)'), ('prezentace', 'Prezentace (přednáška)')], default='veletrh', max_length=16, verbose_name='typ prezentace')), | ||||
|                 ('prezentace', models.FileField(blank=True, help_text='Prezentace nebo fotka posteru', upload_to=soustredeni.models.generate_filename_konfera, verbose_name='prezentace')), | ||||
|                 ('materialy', models.FileField(blank=True, help_text='Další materiály ke konfeře zabalené do jednoho souboru', upload_to=soustredeni.models.generate_filename_konfera, verbose_name='materialy')), | ||||
|                 ('soustredeni', models.ForeignKey(to='soustredeni.soustredeni', verbose_name='soustředění', on_delete=models.PROTECT)), | ||||
|                 ('soustredeni', models.ForeignKey(to='soustredeni.soustredeni', verbose_name='soustředění', on_delete=models.SET_NULL, null=True, related_name='konfery')), | ||||
|                 ('ucastnici', models.ManyToManyField(help_text='Seznam účastníků konfery', through='soustredeni.Konfery_Ucastnici', to='personalni.resitel', verbose_name='účastníci konfery')), | ||||
|             ], | ||||
|             options={ | ||||
|                 'verbose_name': 'Konfera', | ||||
|  | @ -75,6 +76,8 @@ class Migration(migrations.Migration): | |||
|                 ('typ', models.CharField(choices=[('jarni', 'Jarní soustředění'), ('podzimni', 'Podzimní soustředění'), ('vikend', 'Víkendový sraz'), ('vylet', 'Výlet')], default='podzimni', max_length=16, verbose_name='typ akce')), | ||||
|                 ('exportovat', models.BooleanField(db_column='exportovat', default=False, help_text='Exportuje se jen podle tohoto flagu (ne veřejnosti)', verbose_name='export do AESOPa')), | ||||
|                 ('rocnik', models.ForeignKey(to='seminar.rocnik', verbose_name='ročník', related_name='soustredeni', on_delete=models.PROTECT)), | ||||
|                 ('organizatori', models.ManyToManyField(help_text='Seznam organizátorů soustředění', through='soustredeni.Soustredeni_Organizatori', to='personalni.organizator', verbose_name='Organizátoři soustředění')), | ||||
|                 ('ucastnici', models.ManyToManyField(help_text='Seznam účastníků soustředění', through='soustredeni.Soustredeni_Ucastnici', to='personalni.resitel', verbose_name='účastníci soustředění')), | ||||
|             ], | ||||
|             options={ | ||||
|                 'verbose_name': 'Soustředění', | ||||
|  |  | |||
							
								
								
									
										34
									
								
								soustredeni/migrations/0002_manage_soustredeni.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								soustredeni/migrations/0002_manage_soustredeni.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,34 @@ | |||
| # Generated by Django 4.2.11 on 2024-05-01 13:18 | ||||
| 
 | ||||
| from django.db import migrations | ||||
| 
 | ||||
| 
 | ||||
| class Migration(migrations.Migration): | ||||
| 
 | ||||
|     dependencies = [ | ||||
|         ('soustredeni', '0001_split_from_seminar'), | ||||
|         ('seminar', '0124_remove_sous_from_seminar'), | ||||
|     ] | ||||
| 
 | ||||
|     operations = [ | ||||
|         migrations.AlterModelOptions( | ||||
|             name='konfera', | ||||
|             options={'verbose_name': 'Konfera', 'verbose_name_plural': 'Konfery'}, | ||||
|         ), | ||||
|         migrations.AlterModelOptions( | ||||
|             name='konfery_ucastnici', | ||||
|             options={'ordering': ['konfera', 'resitel'], 'verbose_name': 'Účast na konfeře', 'verbose_name_plural': 'Účasti na konfeře'}, | ||||
|         ), | ||||
|         migrations.AlterModelOptions( | ||||
|             name='soustredeni', | ||||
|             options={'ordering': ['-rocnik__rocnik', '-datum_zacatku'], 'verbose_name': 'Soustředění', 'verbose_name_plural': 'Soustředění'}, | ||||
|         ), | ||||
|         migrations.AlterModelOptions( | ||||
|             name='soustredeni_organizatori', | ||||
|             options={'ordering': ['soustredeni', 'organizator'], 'verbose_name': 'Účast organizátorů na soustředění', 'verbose_name_plural': 'Účasti organizátorů na soustředění'}, | ||||
|         ), | ||||
|         migrations.AlterModelOptions( | ||||
|             name='soustredeni_ucastnici', | ||||
|             options={'ordering': ['soustredeni', 'resitel'], 'verbose_name': 'Účast na soustředění', 'verbose_name_plural': 'Účasti na soustředění'}, | ||||
|         ), | ||||
|     ] | ||||
							
								
								
									
										13
									
								
								soustredeni/migrations/0003_post_split_soustredeni.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								soustredeni/migrations/0003_post_split_soustredeni.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,13 @@ | |||
| # Generated by Django 4.2.11 on 2024-05-01 13:35 | ||||
| 
 | ||||
| from django.db import migrations | ||||
| 
 | ||||
| 
 | ||||
| class Migration(migrations.Migration): | ||||
| 
 | ||||
|     dependencies = [ | ||||
|         ('soustredeni', '0002_manage_soustredeni'), | ||||
|     ] | ||||
| 
 | ||||
|     operations = [ | ||||
|     ] | ||||
|  | @ -20,7 +20,6 @@ logger = logging.getLogger(__name__) | |||
| class Soustredeni(SeminarModelBase): | ||||
| 
 | ||||
| 	class Meta: | ||||
| 		managed = False | ||||
| 		db_table = 'seminar_soustredeni' | ||||
| 		verbose_name = 'Soustředění' | ||||
| 		verbose_name_plural = 'Soustředění' | ||||
|  | @ -85,7 +84,6 @@ class Soustredeni_Ucastnici(SeminarModelBase): | |||
| # zmena dedicnosti z models.Model na SeminarModelBase, potencialni vznik bugu | ||||
| 
 | ||||
| 	class Meta: | ||||
| 		managed = False | ||||
| 		db_table = 'seminar_soustredeni_ucastnici' | ||||
| 		verbose_name = 'Účast na soustředění' | ||||
| 		verbose_name_plural = 'Účasti na soustředění' | ||||
|  | @ -112,7 +110,6 @@ class Soustredeni_Organizatori(SeminarModelBase): | |||
| # zmena dedicnosti z models.Model na SeminarModelBase, potencialni vznik bugu | ||||
| 
 | ||||
| 	class Meta: | ||||
| 		managed = False | ||||
| 		db_table = 'seminar_soustredeni_organizatori' | ||||
| 		verbose_name = 'Účast organizátorů na soustředění' | ||||
| 		verbose_name_plural = 'Účasti organizátorů na soustředění' | ||||
|  | @ -155,7 +152,6 @@ def generate_filename_konfera(self, filename): | |||
| @reversion.register(ignore_duplicates=True) | ||||
| class Konfera(am.Problem): | ||||
| 	class Meta: | ||||
| 		managed = False | ||||
| 		db_table = 'seminar_konfera' | ||||
| 		verbose_name = 'Konfera' | ||||
| 		verbose_name_plural = 'Konfery' | ||||
|  | @ -200,7 +196,6 @@ class Konfera(am.Problem): | |||
| class Konfery_Ucastnici(models.Model): | ||||
| 
 | ||||
| 	class Meta: | ||||
| 		managed = False | ||||
| 		db_table = 'seminar_konfery_ucastnici' | ||||
| 		verbose_name = 'Účast na konfeře' | ||||
| 		verbose_name_plural = 'Účasti na konfeře' | ||||
|  |  | |||
|  | @ -3,5 +3,7 @@ Prostě zkopírovat vedle, s původními (=správnými) related names. | |||
| makemigrations | ||||
| ! Doplnit hack kolem content-types (jako první operace při migraci) | ||||
| ! Doplnit ForeignKeys (Vypadá to, že se dá vesměs zkopírovat předpis z models.py, jen místo prvního fieldu dát `to='app.model'. Dokonce asi funguje použít už novou aplikaci pro vazby v rámci aplikace.) | ||||
| 	To samé s ManyToManyFieldy (through= musí taky být 'app.model') | ||||
| (Zdá se, že jde dobastlit tuhle migraci polozpětně – doplnit co chybělo až podle toho, co vygeneruje migrace po zamanagování nového modelu.) | ||||
| doplnit závislost na unmanage | ||||
| migrate | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Pavel "LEdoian" Turinsky
						Pavel "LEdoian" Turinsky