Thank you very much Karen -

You clearly defined that problem for me and that fixed the issue. For
others who might run into the same problem, they would do well to
remember to add either __str__ or __uinicode__ as the case warrant:s:

{% ifequal foo.bar__str__ "foobar" %}

or

{% ifequal foo.bar__unicode__ "foobar" %}

Thanks again Karen

--------------------------

For anyone else who might be confused by this.

On Jun 10, 7:08 pm, "Karen Tracey" <[EMAIL PROTECTED]> wrote:
> On Tue, Jun 10, 2008 at 5:33 PM, John Teague <[EMAIL PROTECTED]> wrote:
>
> > First the particulars:
> > Django svn rev 7610,
> > Apache 2.2.8,
> > mod_python 3.3.1,
> > Python/2.5.2
>
> > I have a template that uses django_template_utils (http://
> > code.google.com/p/django-template-utils/) to retrieve objects. The
> > following is the relevant markup/code:
> > ----------
> > {% load generic_content %}
> > {% get_latest_objects dispatcher.dispatchlog 100 as log_item %}
> > {% for log_item in log_item %}
> > <tr id="{{ log_item.id }}">
> > <td>{% ifequal log_item.id 1 %}<div class="urg3">{{ log_item.id }}{%
> > endifequal %}</td>
> > <td>{% ifequal log_item.priority_level 'High' %}<div
> > class="urg3">{{ log_item.priority_level }}</div>{% endifequal %}</td>
> > </tr>
> > {% endfor %}
> > ----------
>
> > As you can see, what I want to do is to set the appropriate extra div
> > and class based on the comparison of the hard-coded string. In the
> > first use of the ifequal on the 'id' field. I get the expected result.
> > The integer 1 matches the returned value and renders the the extra
> > div.
>
> > However, in the second example 'priority_level' field, the returned
> > value is 'High' which should match the comparison to the hard-coded
> > string 'High'. I have verified that this is a match. However, the
> > ifequal fails silently. As near as I can tell, the only difference
> > between the two fields is that the priority_value field is a
> > foreignkey. Obviously, the value of the foreign key is, in this case,
> > a pk integer, but the name is returned in what should be just a string
> > __str__.
>
> > Am I missing something simple here? Any help would be very much
> > appreciated.
>
> (You mean priority_level is a ForeignKey, right, not priority_value?)  The
> variable resolution done by ifequal isn't automatically going to call str()
> on the variable, so if you want to compare what the __str__ method returns
> against a string, then you need to include that in the comparison:
>
> {% ifequal log_item.priority_level.__str__ 'High' %}
>
> Karen
--~--~---------~--~----~------------~-------~--~----~
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
-~----------~----~----~----~------~----~------~--~---

Reply via email to