did you take a look at the scripts I provided? it seems that this might solve your problem.
another thing: my question was not about doing a CMS, it´s about combining and displaying different types of content on portal-like pages (which, of course, might be part of a CMS). and it´s also not about "small company websites", but about bigger sites with lots of different content-types and at least a couple of different editors. when reading reviews about django - esp. when django is compared with rails - it seems that django should suit these type of sites very well. and, as I´ve mentioned before, there _are_ a couple of bigger newspaper-sites out there. on the other hand, I haven´t seen a nice solution for this so far. I´m just wondering how people actually do these overview-sites (sorry, but I don´t have a better word for it ...). thanks, patrick Am 07.06.2007 um 15:16 schrieb omat: > > I am also in need of such a flexible yet easy to manage content > system, mostly for small company websites. > > In my primitive prototype, I have pages that are built-up of sections. > Each section has its own template and can hold text, images, etc. > Also, I am planning to add the ability to display data dynamically > form another application. > > I am not willing to write the content administration part, but this > flexibility makes it very hard to manage content using the built-in > admin application. For example, a 50 page website with 10 sections per > page on average shows up as a list of 500 sections, which is not very > practical to manage. > > That's why I am not very satisfied with my application and would like > to hear from others about this. > > > There is nothing fancy about my model but just for reference, here it > is: > > > class SectionType(models.Model): > name = models.CharField(maxlength = 50) > > def __str__(self): > return self.name > > class Admin: > pass > > > class Section(models.Model): > type = models.ForeignKey(SectionType) > title = models.CharField(maxlength = 150, > blank = True) > body = models.TextField(blank = True, > null = True) > > def __str__(self): > return '%s (%s)' % (self.title, > self.type) > > class Admin: > pass > > > class SectionImage(models.Model): > section = models.ForeignKey(Section, > edit_inline = models.STACKED, > null = True) > image = models.ImageField(upload_to = 'section/image/') > > class Admin: > pass > > > class Page(models.Model): > title = models.CharField( > maxlength = 100, > core = True, > db_index = True) > slug = models.SlugField(prepopulate_from = ('title',)) > body = models.TextField(blank = True, > null = True) > sections = models.ManyToManyField(Section, > blank = True, > null = True) > > parent = models.ForeignKey('self', > blank = True, > null = True) > > order = models.PositiveSmallIntegerField(blank = True, > null = True) > > related_pages = models.ManyToManyField('self', > blank = True, > null = True) > > def __str__(self): > parents = '' > parent = self.parent > while parent: > parents = '%s :: %s' % (parent.title, > parents,) > parent = parent.parent > return '%s%s (%s)' % (parents, > self.title, > self.slug) > > def get_absolute_url(self): > return '%s/' % (self.slug) > > class Admin: > pass > > > > > On 7 Haziran, 10:39, "patrick k." <[EMAIL PROTECTED]> wrote: >> this is just another request for feedback. I know that there are some >> newspaper-sites out there, made with django. so, I assume, they´ve >> solved this issue. It´d be great to know how they make/construct the >> overview- resp. front-pages (in a way to make changes easily for >> editors). >> >> thanks, >> patrick >> >> Am 03.06.2007 um 19:28 schrieb oggie rob: >> >> >> >>> Ahh, yeah, I suppose so! I didn't really think the rendered text >>> through, and you're right that it has the same flexibility. >> >>> -rob >> >>> On Jun 3, 2:40 am, "patrick k." <[EMAIL PROTECTED]> wrote: >>>> actually, I don´t have to change the view for whatever layout I >>>> want >>>> to have with my approach ... >> >>>> patrick >> >>>> Am 03.06.2007 um 00:40 schrieb oggie rob: >> >>>>> The advantage is you get to organize your additions in the base >>>>> template (which is where you should strive to manage layout & >>>>> L&F as >>>>> much as possible). Your solution works fine for a row-by-row >>>>> example, >>>>> but is less flexible for a more complex layout. For example, if >>>>> you >>>>> want to have a two- or three-column view, it is easier to manage >>>>> this >>>>> by changing it once in the base template than trying to tweak the >>>>> view >>>>> function. What's more, portals are often associated with "skins" >>>>> - it >>>>> would be much more flexible to have the choice of a few "base" >>>>> templates (representing different skins) with completely different >>>>> layouts for the "sub" templates. If you were looking for a generic >>>>> solution, I think you should consider that. >> >>>>> Not sure about how the "specific template" would fit in there >>>>> though... but I don't see major limitations with the approach I >>>>> described vs. your original proposal. In a case where you can't >>>>> generalize the view you probably want to save it as an html >>>>> snippet in >>>>> the database, I suppose. >> >>>>> -rob >> >>>>> On Jun 2, 11:16 am, "patrick k." <[EMAIL PROTECTED]> >>>>> wrote: >>>>>> what´s the advantage of including the sub-templates in the >>>>>> template >>>>>> instead of rendering them in the view? >>>>>> rendering the templates in the view seems to be a bit more >>>>>> flexible >>>>>> when it comes to caching, I guess. >> >>>>>> besides, a custom entry could have its own specific template - >>>>>> so, I >>>>>> ´m not sure how you´d deal with this. >> >>>>>> thanks, >>>>>> patrick >> >>>>>> Am 02.06.2007 um 20:07 schrieb oggie rob: >> >>>>>>> Using the "include" tag, you can provide the template through a >>>>>>> variable >>>>>>> e.g. {% include template1 %} instead of {% include 'mysite/ >>>>>>> movies.html' %} >>>>>>> so you can pass this stuff from the view. >>>>>>> What's more, the include template uses the context from the >>>>>>> "parent" >>>>>>> template. So you can also pass all this information from the >>>>>>> view. >>>>>>> For example, your view could work as follows (code is littered >>>>>>> with >>>>>>> mistakes but you should get the idea): >>>>>>> def my_portal(request, user_id): >>>>>>> template_list = get_portal_template_list(user_id) # returns >>>>>>> list >>>>>>> of strings, representing template names >>>>>>> data = {'templates':template_list} >>>>>>> for template in template_list: >>>>>>> data.update(get_template_data(template, user_id)) >>>>>>> render_to_response(data, "base_template.html") >> >>>>>>> in base_template.html >>>>>>> {% for item in template_list %} >>>>>>> {% include item %} >>>>>>> {% endfor %} >> >>>>>>> You may also organize & test a little more using the "with" tag >>>>>>> (it >>>>>>> appears to works alongside "include"). e.g (with a modified >>>>>>> view): >>>>>>> {% for item in template_list %} >>>>>>> {% with item.data as data %} >>>>>>> {% include item.template %} >>>>>>> {% endwith %} >>>>>>> {% endfor %} >> >>>>>>> then in the included template: >>>>>>> {{ data.field1 }} >>>>>>> {{ data.field2 }} >> >>>>>>> HTH, >>>>>>> -rob >> >>>>>>> On Jun 2, 4:51 am, patrickk <[EMAIL PROTECTED]> wrote: >>>>>>>> This is a problem we´re having with every webpage we did with >>>>>>>> django >>>>>>>> so far. >>>>>>>> Now, I´d like to make this more generic and write a tutorial >>>>>>>> for >>>>>>>> how >>>>>>>> aportal-like page could be done using django. >> >>>>>>>> As an example, let´s say we have a database with movies, stars >>>>>>>> (actors, writers, directors ...), cinemas/theatres, interviews, >>>>>>>> image- >>>>>>>> galleries, trailers, filmfestivals, ... >>>>>>>> Now, the editors should be able to "build" a page (e.g. the >>>>>>>> front- >>>>>>>> page) with different blocks of content like: >>>>>>>> 1. a single object (e.g. a movie, star, interview ...) >>>>>>>> 2. combined objects: a combination of x objects (e.g. "godard- >>>>>>>> special" with a relation to a star (godard), a cinema where the >>>>>>>> special takes place and several movies) >>>>>>>> 3. pre-defined blocks (like "recent comments", "recent >>>>>>>> interviews", >>>>>>>> "most discussed movies" ...) >>>>>>>> 4. custom entries >> >>>>>>>> ### 1 and 4 is easy: for 1, we can use a generic foreign key. >>>>>>>> for 4, >>>>>>>> we´re using a second table ("custom entries") and also a >>>>>>>> generic >>>>>>>> foreign key - so 1 and 4 is basically the same. >>>>>>>> ### For 2, we could also use the table "custom entries", but >>>>>>>> with a >>>>>>>> second table "custom entries item" for the (multiple) generic >>>>>>>> relations. >>>>>>>> ### for 3, we could either use template-tags or custom methods. >> >>>>>>>> The models are here:http://dpaste.com/hold/11537/ >>>>>>>> And the view is here:http://dpaste.com/hold/11538/ >> >>>>>>>> So, the question are: >>>>>>>> 1) Could this be done easier or more generic? >>>>>>>> 2) How and where to define the custom methods? >> >>>>>>>> With the given models, we could construct a page like this: >>>>>>>> #1 Movie Nr. 1234 >>>>>>>> #2 custom method "Recent Comments" >>>>>>>> #3 Interview Nr. 3456 >>>>>>>> #4 Custom Entry "Godard-Special" (a custom entry with relations >>>>>>>> to a >>>>>>>> star, a cinema and several movies) >>>>>>>> #5 custom method "Get Banner" >>>>>>>> #6 Star Nr. 789 >> >>>>>>>> Note: The templates could be saved to the database for making >>>>>>>> editing >>>>>>>> easier (although I personally don´t like storing templates >>>>>>>> within a >>>>>>>> database). >> >>>>>>>> It´d be nice to see this issue solved in a resusable manner. >>>>>>>> To me, >>>>>>>> it seems a bit complicated the way we´re doing it right now. >>>>>>>> Comments and Feedback is much appreciated ... >> >>>>>>>> Thanks, >>>>>>>> Patrick > > > > --~--~---------~--~----~------------~-------~--~----~ 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 -~----------~----~----~----~------~----~------~--~---