This should help you to solve almost all your multilingual problems: http://www.djangosnippets.org/snippets/51/
Regards, Aidas Bendoraitis aka Archatas On 5/15/07, Wolfram Kriesing <[EMAIL PROTECTED]> wrote: > > I have a bi-language (english and german) site. I try to hide the > multi language part as best as I can from the programmer, by > encapsulating it as best as I can in the model. > An example: > > class Tag(models.Model): > name_en = models.SlugField() > name_de = models.SlugField() > > @property > def name(self): > "Return the name depending on the users language" > if user_language=="en": # how can i get user_language? > return self.name_en > else: > return self.name_de > > This would allow me to use the Tag-model anywhere without knowing the > user's language, by accessing the property "name" and it handles the > language stuff. > This is a very much simplified example of what I actually need. > It shows that inside a template I could simply write: > {{ tag.name }} > and get the proper translation. > > The problem: > Here is the problem I don't get "user_language" without having access > to the request! :-( > > > The simple example above would solve small translation tasks, but I > have another model, that has some more complex translation logic. I > constructed this by using DB-views, and creating models that map > directly to appropriate view. > To demonstrate this: > class DataEnglish(models.Model): > id = .... > title = .... > abstract = ..... > class Meta: > db_table = "core_dataenglishview" > > class DataGerman(models.Model): > id = .... > title = .... > abstract = ..... > class Meta: > db_table = "core_datagermanview" > > To abstract the language stuff, I would like to only access a model > called "Data" which in turn maps to "DataGerman" for a german user and > to "DataEnglish" to an english user. Unfortunately I only have access > to the language via django.utils.translation.get_language_from_request > when I have the request available. > But I would like to use: > Data.objects.all() > Data.objects.filter() > inside my code, without worrying about the language setting in the > place where I read from the objects (of course for updating the > objects I have to use DataGerman or DataEnglish explicitly, and I do). > > How can I achieve this in a clean way, without passsing the request > around every time? > > > My hacky solution: > Write a middleware, that sets some "global" variable i.e. in > settings.current_language and use this as language. That would work > since every request has its thread/process that is running in apache, > but that seems quite dirty. > > Any ideas? Or have my thoughts been going a completely wrong way? > > -- > cu > > Wolfram > > > > --~--~---------~--~----~------------~-------~--~----~ You received this message because you are subscribed to the Google Groups "Django users" group. To post to this group, send email to django-users@googlegroups.com To unsubscribe from this group, send email to [EMAIL PROTECTED] For more options, visit this group at http://groups.google.com/group/django-users?hl=en -~----------~----~----~----~------~----~------~--~---