From cda7d7a79d6eef7db99508188c37c862bdd0af76 Mon Sep 17 00:00:00 2001 From: Roman Date: Mon, 29 Sep 2025 00:51:13 +0200 Subject: [PATCH] Switch to single quotes across models.py for consistent string formatting --- input/models.py | 102 ++++++++++++++++++++++++------------------------ 1 file changed, 51 insertions(+), 51 deletions(-) diff --git a/input/models.py b/input/models.py index 551965f..17f4819 100755 --- a/input/models.py +++ b/input/models.py @@ -12,8 +12,8 @@ EMAIL_STATES = {'NONE': 'noch keine Mail versendet', 'END': 'alle automatischen Mails, auch surveyMail, wurden versendet'} class Volunteer(models.Model): - realname = models.CharField(max_length=200, null=True, verbose_name="Realname", - help_text="Bitte gib deinen Vornamen und deinen Nachnamen ein.", default='') + realname = models.CharField(max_length=200, null=True, verbose_name='Realname', + help_text='Bitte gib deinen Vornamen und deinen Nachnamen ein.', default='') email = models.EmailField(max_length=200, null=True, verbose_name='E-Mail-Adresse', help_text=mark_safe('Bitte gib deine E-Mail-Adresse ein, damit dich
Wikimedia Deutschland bei Rückfragen oder für
die Zusage kontaktieren kann.')) @@ -42,7 +42,7 @@ class Extern(Volunteer): ''' abstract basis class for all data entered by extern volunteers ''' username = models.CharField(max_length=200, null=True, verbose_name='Benutzer_innenname', - help_text=mark_safe("Wikimedia Benutzer_innenname")) + help_text=mark_safe('Wikimedia Benutzer_innenname')) # the following Fields are not supposed to be edited by users service_id = models.CharField(max_length=15, null=True, blank=True) @@ -62,25 +62,25 @@ class ConcreteExtern(Extern): pass class Account(models.Model): - code = models.CharField('Kostenstelle', max_length=5, default="DEF", + code = models.CharField('Kostenstelle', max_length=5, default='DEF', null=False, primary_key = True) description = models.CharField('Beschreibung', max_length=60, default='NO DESCRIPTION') - intern_notes = models.TextField(max_length=1000, blank=True, verbose_name="interne Anmerkungen") + intern_notes = models.TextField(max_length=1000, blank=True, verbose_name='interne Anmerkungen') def __str__(self): - return f"{self.code} {self.description}" + return f'{self.code} {self.description}' class Project(Volunteer): end_mail_send = models.BooleanField(default=False, verbose_name='Keine Projektabschlussmail schicken') name = models.CharField(max_length=200, verbose_name='Name des Projekts') - description = models.CharField(max_length=500, verbose_name="Kurzbeschreibung", null=True) + description = models.CharField(max_length=500, verbose_name='Kurzbeschreibung', null=True) start = models.DateField('Startdatum', null=True) end = models.DateField('Erwartetes Projektende', null=True) otrs = models.URLField(max_length=300, null=True, verbose_name='OTRS-Link') - plan = models.URLField(max_length=2000, null=True, blank=True, verbose_name="Link zum Förderplan") - page = models.URLField(max_length=2000, null=True, blank=True, verbose_name="Link zur Projektseite") - urls = models.CharField(max_length=2000, null=True, blank=True, verbose_name="Weitere Links") - group = models.CharField(max_length=2000, null=True, blank=True, verbose_name="Mitorganisierende") - location = models.CharField(max_length=2000, null=True, blank=True, verbose_name="Ort/Adresse/Location") + plan = models.URLField(max_length=2000, null=True, blank=True, verbose_name='Link zum Förderplan') + page = models.URLField(max_length=2000, null=True, blank=True, verbose_name='Link zur Projektseite') + urls = models.CharField(max_length=2000, null=True, blank=True, verbose_name='Weitere Links') + group = models.CharField(max_length=2000, null=True, blank=True, verbose_name='Mitorganisierende') + location = models.CharField(max_length=2000, null=True, blank=True, verbose_name='Ort/Adresse/Location') participants_estimated = models.IntegerField(blank=True, null=True, verbose_name='Teilnehmende angefragt') participants_real = models.IntegerField(blank=True, null=True, verbose_name='Teilnehmende ausgezählt') insurance = models.BooleanField(default=False, verbose_name='Haftpflichtversicherung') @@ -90,7 +90,7 @@ class Project(Volunteer): account = models.ForeignKey('Account', on_delete=models.CASCADE, null=True, to_field='code', db_constraint = False) granted_from = models.CharField(max_length=100,null=True,verbose_name='Bewilligt von') notes = models.TextField(max_length=1000,null=True,blank=True,verbose_name='Anmerkungen') - intern_notes = models.TextField(max_length=1000, blank=True, verbose_name="interne Anmerkungen") + intern_notes = models.TextField(max_length=1000, blank=True, verbose_name='interne Anmerkungen') # the following Fields are not supposed to be edited by users @@ -98,7 +98,7 @@ class Project(Volunteer): status = models.CharField(max_length=3,choices=(('RUN', 'läuft'),('END','beendet'),('NOT','nicht stattgefunden')),default='RUN') finance_id = models.CharField(max_length=15, null= True, blank=True) project_of_year = models.IntegerField(default=0) - end_quartal = models.CharField(max_length=15, null=True, blank=True, verbose_name="Quartal Projekt Ende") + end_quartal = models.CharField(max_length=15, null=True, blank=True, verbose_name='Quartal Projekt Ende') def save(self,*args,**kwargs): @@ -110,7 +110,7 @@ class Project(Volunteer): # but maybe there is a better solution? if not self.pk: - print ("NO PK THERE"); + print ('NO PK THERE'); generate_finance_id=True super().save() else: @@ -128,7 +128,7 @@ class Project(Volunteer): if generate_finance_id: - print ("MUST GENERATE FINANCE ID") + print ('MUST GENERATE FINANCE ID') year = self.start.year projects = Project.objects.filter(start__year=year) if not projects: @@ -136,7 +136,7 @@ class Project(Volunteer): #self.pid = str(self.start.year) + '-' + str(self.account.code) + str(self.project_of_year).zfill(3) else: # get the project of year number of latest entry - projects = projects.order_by("-project_of_year")[0] + projects = projects.order_by('-project_of_year')[0] # add one to value of latest entry self.project_of_year = int(projects.project_of_year) + 1 # self.pid = str(self.start.year) + '-' + str(self.account.code) + str(self.project_of_year).zfill(3) @@ -147,12 +147,12 @@ class Project(Volunteer): else: self.finance_id = str(self.account.code) -# print (("Current PID",self.pid)) +# print (('Current PID',self.pid)) if not self.pid: self.pid = str(self.account.code) + str(self.pk).zfill(8) # self.pid = str(self.account.code) + str(self.pk).zfill(3) - print (("Hallo Leute! Ich save jetzt mal MIT PID DANN!!!",self.pid)) + print (('Hallo Leute! Ich save jetzt mal MIT PID DANN!!!',self.pid)) if self.end: self.end_quartal = f'Q{self.end.month // 4 + 1}' @@ -161,7 +161,7 @@ class Project(Volunteer): def __str__(self): - return f"{self.pid} {self.name}" + return f'{self.pid} {self.name}' class Intern(Volunteer): @@ -180,7 +180,7 @@ class HonoraryCertificate(Intern): project = models.ForeignKey(Project, null=True, blank=True, on_delete=models.SET_NULL) def __str__(self): - return "Certificate for " + self.realname + return 'Certificate for ' + self.realname TRANSPORT_CHOICES = {'BAHN': 'Bahn', @@ -202,7 +202,7 @@ class Travel(Extern): project_name = models.CharField(max_length=50, null=True, blank=True, verbose_name='Projektname:') transport = models.CharField(max_length=5, choices=TRANSPORT_CHOICES.items(), default='BAHN', verbose_name='Transportmittel:') other_transport = models.CharField(max_length=200, null=True, blank=True, verbose_name='Sonstige Transportmittel (mit Begründung)') - travelcost = models.CharField(max_length=10, default="0", verbose_name='Fahrtkosten') + travelcost = models.CharField(max_length=10, default='0', verbose_name='Fahrtkosten') checkin = models.DateField(blank=True, null=True, verbose_name='Anreise') checkout = models.DateField(blank=True, null=True, verbose_name='Abreise') payed_for_hotel_by = models.CharField(max_length=4, choices=PAYEDBY_CHOICES.items(), blank=True, null=True, verbose_name='Kostenauslage Hotel durch') @@ -213,12 +213,12 @@ class Travel(Extern): intern_notes = models.TextField(max_length=1000, blank=True, verbose_name='interne Anmerkungen') project_end = models.DateField(blank=True, null=True, verbose_name='Projektende') # use content type model to get the end date for the project foreign key - project_end_quartal = models.CharField(max_length=15, null=True, blank=True, verbose_name="Quartal Projekt Ende") + project_end_quartal = models.CharField(max_length=15, null=True, blank=True, verbose_name='Quartal Projekt Ende') from django.db.models.signals import pre_save from django.dispatch import receiver -@receiver(pre_save, sender=Travel, dispatch_uid="get_project_end") +@receiver(pre_save, sender=Travel, dispatch_uid='get_project_end') def getProjectEnd(sender, instance, **kwargs): #instance.project_end = instance.project.end @@ -238,9 +238,9 @@ def getProjectEnd(sender, instance, **kwargs): #abstract base class for Library and IFG class Grant(Extern): cost = models.CharField(max_length=10, verbose_name='Kosten', - help_text="Bitte gib die ungefähr zu erwartenden Kosten in Euro an.") + help_text='Bitte gib die ungefähr zu erwartenden Kosten in Euro an.') notes = models.TextField(max_length=1000, blank=True, verbose_name='Anmerkungen', - help_text="Bitte gib an wofür Du das Stipendium verwenden willst.") + help_text='Bitte gib an wofür Du das Stipendium verwenden willst.') class Meta: abstract = True @@ -290,8 +290,8 @@ class Library(Grant): type = models.CharField(max_length=4, choices=LIBRARY_TYPE_CHOICES, default=TYPE_BIB) library = models.CharField(max_length=200) - duration = models.CharField(max_length=100, verbose_name="Dauer") - intern_notes = models.TextField(max_length=1000, blank=True, verbose_name="interne Anmerkungen") + duration = models.CharField(max_length=100, verbose_name='Dauer') + intern_notes = models.TextField(max_length=1000, blank=True, verbose_name='interne Anmerkungen') def __str__(self): return self.library @@ -329,25 +329,25 @@ SELFBUY_CHOICES = {'TRUE': mark_safe('Ich möchte das Werk selbst kaufen und per class Literature(Grant): info = models.CharField(max_length=500, verbose_name='Informationen zum Werk', - help_text=mark_safe("Bitte gib alle Informationen zum benötigten Werk an,
\ - die eine eindeutige Identifizierung ermöglichen (Autor, Titel, Verlag, ISBN, ...)")) + help_text=mark_safe('Bitte gib alle Informationen zum benötigten Werk an,
\ + die eine eindeutige Identifizierung ermöglichen (Autor, Titel, Verlag, ISBN, ...)')) source = models.CharField(max_length=200, verbose_name='Bezugsquelle', - help_text="Bitte gib an, wo du das Werk kaufen möchtest.") + help_text='Bitte gib an, wo du das Werk kaufen möchtest.') selfbuy = models.CharField( max_length=10, verbose_name='Selbstkauf?', choices=SELFBUY_CHOICES.items(), default='TRUE') selfbuy_give_data = models.BooleanField(verbose_name=mark_safe('Datenweitergabe erlauben'), help_text=mark_safe('Ich stimme der Weitergabe meiner Daten (Name, Postadresse) an den von mir angegebenen Anbieter/Dienstleister zu.')) selfbuy_data = models.TextField(max_length=1000, verbose_name='Persönliche Daten sowie Adresse', default='',\ - help_text=mark_safe("Bitte gib hier alle persönlichen Daten an, die wir benötigen, um das Werk
\ + help_text=mark_safe('Bitte gib hier alle persönlichen Daten an, die wir benötigen, um das Werk
\ für dich zu kaufen und es dir anschließend zu schicken (z.B. Vorname Nachname, Anschrift,
\ - Telefonnummer, E-Mail-Adresse usw.). Trenne die einzelnen Angaben durch Zeilenumbrüche.")) - intern_notes = models.TextField(max_length=1000, blank=True, verbose_name="interne Anmerkungen") + Telefonnummer, E-Mail-Adresse usw.). Trenne die einzelnen Angaben durch Zeilenumbrüche.')) + intern_notes = models.TextField(max_length=1000, blank=True, verbose_name='interne Anmerkungen') class IFG(Grant): - url = models.URLField(max_length=2000, verbose_name="URL", - help_text="Bitte gib den Link zu deiner Anfrage bei Frag den Staat an.") - intern_notes = models.TextField(max_length=1000, blank=True, verbose_name="interne Anmerkungen") + url = models.URLField(max_length=2000, verbose_name='URL', + help_text='Bitte gib den Link zu deiner Anfrage bei Frag den Staat an.') + intern_notes = models.TextField(max_length=1000, blank=True, verbose_name='interne Anmerkungen') def __str__(self): - return "IFG-Anfrage von " + self.realname + return 'IFG-Anfrage von ' + self.realname DOMAIN_CHOICES = {'PEDIA': '@wikipedia.de', 'BOOKS': '@wikibooks.de', @@ -375,17 +375,17 @@ class Email(Domain): address = models.CharField(max_length=50, choices=MAIL_CHOICES.items(), default='USERNAME', verbose_name='Adressbestandteil', - help_text=mark_safe("Bitte gib hier den gewünschten Adressbestandteil an,
der sich vor der Domain befinden soll.")) + help_text=mark_safe('Bitte gib hier den gewünschten Adressbestandteil an,
der sich vor der Domain befinden soll.')) - other = models.CharField(max_length=50,blank=True,null=True, verbose_name="Sonstiges") + other = models.CharField(max_length=50,blank=True,null=True, verbose_name='Sonstiges') adult = models.CharField( max_length=10, verbose_name='Volljährigkeit', choices=ADULT_CHOICES.items(), default='FALSE') - intern_notes = models.TextField(max_length=1000, blank=True, verbose_name="interne Anmerkungen") + intern_notes = models.TextField(max_length=1000, blank=True, verbose_name='interne Anmerkungen') class List(Domain): address = models.CharField(max_length=50, default='NO_ADDRESS', - verbose_name="Adressbestandteil für Projektmailingliste", - help_text=mark_safe("Bitte gib hier den gewünschten Adressbestandteil an,
der sich vor der Domain befinden soll.")) - intern_notes = models.TextField(max_length=1000, blank=True, verbose_name="interne Anmerkungen") + verbose_name='Adressbestandteil für Projektmailingliste', + help_text=mark_safe('Bitte gib hier den gewünschten Adressbestandteil an,
der sich vor der Domain befinden soll.')) + intern_notes = models.TextField(max_length=1000, blank=True, verbose_name='interne Anmerkungen') PROJECT_CHOICE = {'PEDIA': 'Wikipedia', 'SOURCE': 'Wikisource', @@ -406,24 +406,24 @@ class BusinessCard(Extern): help_text='Für welches Wikimedia-Projekt möchtest Du Visitenkarten?') data = models.TextField(max_length=1000, verbose_name='Persönliche Daten für die Visitenkarten', default='', - help_text=mark_safe("Bitte gib hier alle persönlichen Daten an, und zwar genau so,
\ + help_text=mark_safe('Bitte gib hier alle persönlichen Daten an, und zwar genau so,
\ wie sie (auch in der entsprechenden Reihenfolge) auf den Visitenkarten stehen sollen
\ (z.B. Vorname Nachname, Benutzer:/Benutzerin:, Benutzer-/-innenname, Anschrift,
\ Telefonnummer, E-Mail-Adresse usw.). Trenne die einzelnen Angaben durch Zeilenumbrüche.
\ Hinweis: Telefonnummern bilden wir üblicherweise im internationalen Format gemäß
\ DIN 5008 ab. Als anzugebende E-Mail-Adresse empfehlen wir dir eine Wikimedia-Projekt-
\ - Adresse, die du ebenfalls beantragen kannst, sofern du nicht bereits eine besitzt.")) + Adresse, die du ebenfalls beantragen kannst, sofern du nicht bereits eine besitzt.')) variant = models.CharField(max_length=5, choices=BC_VARIANT.items(), default='NOPIC', verbose_name='Variante', help_text=mark_safe('so sehen die Varianten aus: \ mit Bild ohne Bild' )) - url_of_pic = models.CharField(max_length=200, verbose_name='Url des Bildes', default='', help_text="Bitte gib die Wikimedia-Commons-URL des Bildes an.") + url_of_pic = models.CharField(max_length=200, verbose_name='Url des Bildes', default='', help_text='Bitte gib die Wikimedia-Commons-URL des Bildes an.') sent_to = models.TextField(max_length=1000, verbose_name='Versandadresse', - default='', help_text="Bitte gib den Namen und die vollständige Adresse ein, an welche die Visitenkarten geschickt werden sollen.") + default='', help_text='Bitte gib den Namen und die vollständige Adresse ein, an welche die Visitenkarten geschickt werden sollen.') send_data_to_print = models.BooleanField(default=False, verbose_name=mark_safe('Datenweitergabe erlauben'), help_text=mark_safe('Hiermit erlaube ich die Weitergabe meiner Daten (Name, Postadresse) an den von Wikimedia
Deutschland ausgewählten Dienstleister (z. B. wir-machen-druck.de) zum Zwecke des direkten
Versands der Druckerzeugnisse an mich.')) - intern_notes = models.TextField(max_length=1000, blank=True, verbose_name="interne Anmerkungen") + intern_notes = models.TextField(max_length=1000, blank=True, verbose_name='interne Anmerkungen') PROJECT_CATEGORIES = [ @@ -489,7 +489,7 @@ class ProjectRequest(Volunteer): ordering = ('-id',) def __str__(self): - return f"[Antrag] {self.name} ({self.realname})" + return f'[Antrag] {self.name} ({self.realname})' def clean(self): super().clean() @@ -541,7 +541,7 @@ class ProjectsDeclined(models.Model): ordering = ('-decision_date', '-id') def __str__(self): - return f"[Abgelehnt] {self.name} – {self.decision_date}" + return f'[Abgelehnt] {self.name} – {self.decision_date}' MODELS = {