Friday, March 19, 2021

Re: View / Query Set not showing with filter

my friend,

I'm checking your code, and I can't continue without seeing the template and how you make the request.

However I will try to make a dissection of the code to evaluate what happens, so I will forward your code to you in the pastebin link with some notes: https://pastebin.com/QbxqcTrh

Note: if you are doing an ajax request you should not return a template,  https://docs.djangoproject.com/en/3.1/ref/request-response/#jsonresponse-objects

So I would return a template with the context: https://pastebin.com/BYre4Dig
and so I would return it in an ajax request: https://pastebin.com/CJ2YA8gz


El vie, 19 mar 2021 a las 16:29, Manuel Buri (<manuel.buri@gmail.com>) escribió:
Booking Model
from django.db import models
from django.utils import timezone
from users.models import Account
from organization.models import Organization, Office


class Booking(models.Model):
    LOCATION_OPTIONS = (
            ('H', 'Home Office'),
            ('O', 'Office'),
            ('N', 'Not indicated'),
    )
    account             = models.ForeignKey(Account, on_delete=models.CASCADE)
    organization        = models.ForeignKey(Organization, on_delete=models.CASCADE)
    office              = models.ForeignKey(Office, on_delete=models.CASCADE)
    booking_time        = models.DateTimeField(default=timezone.now)
    location            = models.CharField(max_length=1, choices=LOCATION_OPTIONS)
    class Meta:
            unique_together = ('account', 'booking_time',)

View
def overview_view(request):

    context = {}

    if request.method == 'GET':
        start_date = None
        end_date = None
        if request.is_ajax():
            booking_times = request.GET.get('day')
            start_date = datetime.strptime(booking_times, "%Y-%m-%d")
            end_date = start_date + timedelta(days=4)
            start_date = start_date.replace(hour=0, minute=0, second=0, microsecond=0, tzinfo=pytz.utc)
            end_date = end_date.replace(hour=0, minute=0, second=0, microsecond=0, tzinfo=pytz.utc)

        context['bookings']=Booking.objects.filter( Q(organization_id=request.user.organization_id), Q(booking_time__range = (start_date, end_date))
        context['office'] = Office.objects.filter(organization_id__exact=request.user.organization_id)
       
        return render(request, 'overview/overview.html', context)
return render(request, 'overview/overview.html', context)

haha sorry for not using pastebin before :D

Thank you so much.

Best wishes,

Manuel



Manuel Buri
T:  +41 79 933 01 11 


On Fri, 19 Mar 2021 at 23:22, Héctor Alonso Lozada Echezuría <imatsu@gmail.com> wrote:
Can you share your "Booking" model and the view (function or class) that renders the template?, and I beg you, please use pastebin.com for share your code :D

El vie, 19 mar 2021 a las 16:17, Manuel Buri (<manuel.buri@gmail.com>) escribió:
@anornymous99@gmail.com and imatsu@gmail.com
your suggestion is unfortunately not working too

@All:
So as said my queryset is not empty, meaning that the query works.
However, the results is not in the rendered HTML file.
This would imply that with my template is something wrong, don't you think?

{% for office in office.all %}
<small>{{ office.office_name }}</small>
{% for booking in bookings %}
<div class="client-item">
<div class="client-text">
<p class="name">{{ booking.account.first_name }} {{ booking.account.last_name }}</p>
{% if booking.get_location_display == 'House' %}
<p class="sub-title">🏢 {{ booking.get_location_display }}</p>
{% elif booking.get_location_display == 'Home' %}
<p class="sub-title">🏠 {{ booking.get_location_display }}</p>
{% else %}
<p class="sub-title">🤔 {{ booking.get_location_display }}</p>
{% endif %}
</div>
</div>
{% endfor %}
{% endfor %}

What do you think?

Thank you so much for your help !!!!!

Best wishes,

Manuel



Manuel Buri
T:  +41 79 933 01 11 


On Fri, 19 Mar 2021 at 22:51, Thomas Lockhart <tlockhart1976@gmail.com> wrote:
Why use Q? afaict simple filter syntax should get you what you want.

Booking.objects.filter(organization_id=request.user.organization_id, booking_time__range= (start_date, end_date))

Not sure if this will get you closer to the query you expect.

You might also find it useful to use "./manage.py shell" to test the queries by hand. Import a few models, put in "11" for the organization_id, and see what happens.

- Tom

> On Mar 19, 2021, at 2:11 PM, Manuel Buri <manuel.buri@gmail.com> wrote:
>
> I want to fetch all bookings for the users organization_id between start_date and end_date.
> I am achieving this via this queryset, however, as soon as I add the second filter (bold), it is not rendered in the template anymore and I, therefore, do not see it in my HTML file.
> context['bookings']=Booking.objects.filter( Q(organization_id=request.user.organization_id), Q(booking_time__range= (start_date, end_date)))
>
> Thank you so much for your help.
> Best wishes,
>
> Manuel
>
>
>
> Manuel Buri
> T:  +41 79 933 01 11
> M: manuel.buri@gmail.com
> W: www.manuelburi.com
>
>
> On Fri, 19 Mar 2021 at 22:07, Anornymous u <anornymous99@gmail.com> wrote:
> I mean what you want to fetch and the conditions
>
> On Fri, Mar 19, 2021, 16:01 Manuel Buri <manuel.buri@gmail.com> wrote:
> Hi,
>
> I am having this query set in my view:
> context['bookings']=Booking.objects.filter( Q(organization_id=request.user.organization_id), Q(booking_time__range= (start_date, end_date)))
>
> It produces a non-empty query set!
> However, I am NOT able to display it in my template.
>
> If I get rid of Q(booking_time__range= (start_date, end_date) and only do:
> context['bookings']=Booking.objects.filter( Q(organization_id=request.user.organization_id))
> then it is also non-empty AND it is displaying it in my template.
>
> What am I missing here?
>
> Thank you for your help.
>
> Manuel
>
> --
> You received this message because you are subscribed to the Google Groups "Django users" group.
> To unsubscribe from this group and stop receiving emails from it, send an email to django-users+unsubscribe@googlegroups.com.
> To view this discussion on the web visit https://groups.google.com/d/msgid/django-users/76f85c72-19f9-4ad3-a39b-01dc60aa6da5n%40googlegroups.com.
>
> --
> You received this message because you are subscribed to a topic in the Google Groups "Django users" group.
> To unsubscribe from this topic, visit https://groups.google.com/d/topic/django-users/2DC9EY75yuM/unsubscribe.
> To unsubscribe from this group and all its topics, send an email to django-users+unsubscribe@googlegroups.com.
> To view this discussion on the web visit https://groups.google.com/d/msgid/django-users/CAMXTB%3DcsfYRqGPbhXncaHNTjKqVhgskST8BDEAY-2fYonemfdg%40mail.gmail.com.
>
> --
> You received this message because you are subscribed to the Google Groups "Django users" group.
> To unsubscribe from this group and stop receiving emails from it, send an email to django-users+unsubscribe@googlegroups.com.
> To view this discussion on the web visit https://groups.google.com/d/msgid/django-users/CACx7KOQEEWWNu6hQwMXdEP_nZ6%2Bex9HZ9KEiVubrvd89%3DTP%3DuQ%40mail.gmail.com.

--
You received this message because you are subscribed to a topic in the Google Groups "Django users" group.
To unsubscribe from this topic, visit https://groups.google.com/d/topic/django-users/2DC9EY75yuM/unsubscribe.
To unsubscribe from this group and all its topics, send an email to django-users+unsubscribe@googlegroups.com.
To view this discussion on the web visit https://groups.google.com/d/msgid/django-users/7C87F855-5ECE-4470-A8CA-916B64F7CFF5%40gmail.com.

--
You received this message because you are subscribed to the Google Groups "Django users" group.
To unsubscribe from this group and stop receiving emails from it, send an email to django-users+unsubscribe@googlegroups.com.
To view this discussion on the web visit https://groups.google.com/d/msgid/django-users/CACx7KOS-9b1UP%3D4t4jUOHgn8co_19W2CCRCQWR%3DCWwLHWR%2BsFQ%40mail.gmail.com.


--
Héctor Alonso Lozada Echezuría

--
You received this message because you are subscribed to a topic in the Google Groups "Django users" group.
To unsubscribe from this topic, visit https://groups.google.com/d/topic/django-users/2DC9EY75yuM/unsubscribe.
To unsubscribe from this group and all its topics, send an email to django-users+unsubscribe@googlegroups.com.
To view this discussion on the web visit https://groups.google.com/d/msgid/django-users/CADTS2YzEw3jqctmHaWfhhZagmy0VW8-XvppHQtHTCAzmSf3v-Q%40mail.gmail.com.

--
You received this message because you are subscribed to the Google Groups "Django users" group.
To unsubscribe from this group and stop receiving emails from it, send an email to django-users+unsubscribe@googlegroups.com.
To view this discussion on the web visit https://groups.google.com/d/msgid/django-users/CACx7KORxjdPeqw_UZoTC0eRp92ngZa-bX%3DDUd3sf3-59PY4kYg%40mail.gmail.com.


--
Héctor Alonso Lozada Echezuría

--
You received this message because you are subscribed to the Google Groups "Django users" group.
To unsubscribe from this group and stop receiving emails from it, send an email to django-users+unsubscribe@googlegroups.com.
To view this discussion on the web visit https://groups.google.com/d/msgid/django-users/CADTS2YxaFc9OnJCXJqm_a800Oxn5494860N4ugQD_qf0jQJ%3DHw%40mail.gmail.com.

No comments:

Post a Comment