Question, why do you need to create a folder for every pet? Why not throw all pet photos in one folder?That would solve your problem as well.
On Wed, Sep 3, 2008 at 2:49 PM, flynnguy <[EMAIL PROTECTED]> wrote: > > I looked at the save_m2m but I don't have any many to many fields so > that wouldn't do me any good. The problem seems to lie in the fact > that when I save the image, I need to know the pet ID so it can save > it in the petid directory. Ie. os.path.join(settings.MEDIA_ROOT, > 'pet_photos', pet_id, image_filename) so setting null=True for the > petid still doesn't help me. > > I think what I've decided to do is abandon the ModelForm and instead > use a regular form. (forms.Form) The downside is I have to handle the > instance creation and saving the file myself but the upside is I can > do anything I want with the file upload. I have it mostly working, I > just have to add a few validation checks and such. When I'm done I'll > post me snippets here in case anyone else has the same problem. Of > course, I'm open to any alternatives. I may try the initial keyword, I > somehow couldn't find it in all the documentation. > -Chris > > On Sep 3, 3:58 am, TiNo <[EMAIL PROTECTED]> wrote: > > Set .pet and .type null=True, save with commit=True, add the values, and > > save again? > > also seehttp:// > www.djangoproject.com/documentation/modelforms/#the-save-methodon > > save_m2m after commit=False. > > > > And default does not work indeed, 'initial' does however; you pass it > when > > creating the form instance. > > > > On Tue, Sep 2, 2008 at 7:49 PM, flynnguy <[EMAIL PROTECTED]> wrote: > > > > > Ok, some experimentation has yielded that the problem lies here: > > > def photoDir(self, filename): > > > "Callable method used to set directory of media below" > > > return os.path.join('pet_photos', str(self.pet.id), filename) > > > Basically what seems to be happening is that it tries to save the file > > > and then continue on to the post save(commit=False) bits. > > > Unfortunately in my case, when saving the file, it looks at the pet.id > > > so I can save the image in say /media/pet_photos/1/ so I have all the > > > photos related to a pet in the same directory but I haven't set it > > > yet. > > > > > Anyone have any suggestions on a way around this? I was thinking of > > > having a hidden field but still changing it post save(commit=False) to > > > avoid a user changing it but that just seems unelegant and I also > > > can't see a way to set the default value for the hidden field. (adding > > > defalt=whatever on the forms.CharField() doesn't seem to work) > > > -Chris > > > > > On Sep 2, 12:35 pm, flynnguy <[EMAIL PROTECTED]> wrote: > > > > I tried the id thing which didn't seem to work but then when I tried > > > > the null thing I think I found out what is going on. It looks like > the > > > > callable save bit for the photo is not getting a pet id so it doesn't > > > > know where to save it. Of course this is just a guess and I have no > > > > proof... some more fiddling is needed. > > > > -Chris > > > > > > On Sep 2, 12:21 pm, Daniel Roseman <[EMAIL PROTECTED]> > > > > wrote: > > > > > > > On Sep 2, 4:04 pm, flynnguy <[EMAIL PROTECTED]> wrote: > > > > > > > > Found out what was causing the error but not why... > > > > > > > > It seems that when I tell my model to not exclude the "pet" > field, > > > > > > that everything works fine. (ie, I select a pet from the > dropdown) > > > > > > When I add it to the exclude list and try to set it manually I > get an > > > > > > error. > > > > > > > > What seems to work is allowing the pet selection but then setting > it > > > > > > after I do save(commit=False). I'm trying to set it up as a > hidden > > > > > > field but I keep getting that it's a required field. I can't seem > to > > > > > > figure out how to set a default value. Any ideas why this might > be > > > > > > happening? > > > > > > -Chris > > > > > > > You could try this; > > > > > added_photo.pet_id = pet.id > > > > > > > That might work. Otherwise, try allowing null=True in the pet FK > > > > > field, and doing form.save() then adding the pet then saving again. > > > > > -- > > > > > DR > > > --~--~---------~--~----~------------~-------~--~----~ 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 -~----------~----~----~----~------~----~------~--~---