Fixed #2053 -- added an optional comparison argument to the "timesince" filter.
Added a "timeuntil" filter that works analogously. Thanks, john@sneeu.com. git-svn-id: http://code.djangoproject.com/svn/django/trunk@3185 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
c4fa8a158a
commit
239adf83d3
|
@ -345,13 +345,25 @@ def time(value, arg=None):
|
||||||
arg = settings.TIME_FORMAT
|
arg = settings.TIME_FORMAT
|
||||||
return time_format(value, arg)
|
return time_format(value, arg)
|
||||||
|
|
||||||
def timesince(value):
|
def timesince(value, arg=None):
|
||||||
'Formats a date as the time since that date (i.e. "4 days, 6 hours")'
|
'Formats a date as the time since that date (i.e. "4 days, 6 hours")'
|
||||||
from django.utils.timesince import timesince
|
from django.utils.timesince import timesince
|
||||||
if not value:
|
if not value:
|
||||||
return ''
|
return ''
|
||||||
|
if arg:
|
||||||
|
return timesince(arg, value)
|
||||||
return timesince(value)
|
return timesince(value)
|
||||||
|
|
||||||
|
def timeuntil(value, arg=None):
|
||||||
|
'Formats a date as the time until that date (i.e. "4 days, 6 hours")'
|
||||||
|
from django.utils.timesince import timesince
|
||||||
|
from datetime import datetime
|
||||||
|
if not value:
|
||||||
|
return ''
|
||||||
|
if arg:
|
||||||
|
return timesince(arg, value)
|
||||||
|
return timesince(datetime.now(), value)
|
||||||
|
|
||||||
###################
|
###################
|
||||||
# LOGIC #
|
# LOGIC #
|
||||||
###################
|
###################
|
||||||
|
@ -485,6 +497,7 @@ register.filter(stringformat)
|
||||||
register.filter(striptags)
|
register.filter(striptags)
|
||||||
register.filter(time)
|
register.filter(time)
|
||||||
register.filter(timesince)
|
register.filter(timesince)
|
||||||
|
register.filter(timeuntil)
|
||||||
register.filter(title)
|
register.filter(title)
|
||||||
register.filter(truncatewords)
|
register.filter(truncatewords)
|
||||||
register.filter(unordered_list)
|
register.filter(unordered_list)
|
||||||
|
|
|
@ -47,10 +47,11 @@ def timesince(d, now=None):
|
||||||
s += ', %d %s' % (count2, name2(count2))
|
s += ', %d %s' % (count2, name2(count2))
|
||||||
return s
|
return s
|
||||||
|
|
||||||
def timeuntil(d):
|
def timeuntil(d, now=None):
|
||||||
"""
|
"""
|
||||||
Like timesince, but returns a string measuring the time until
|
Like timesince, but returns a string measuring the time until
|
||||||
the given time.
|
the given time.
|
||||||
"""
|
"""
|
||||||
|
if now == None:
|
||||||
now = datetime.datetime.now()
|
now = datetime.datetime.now()
|
||||||
return timesince(now, d)
|
return timesince(now, d)
|
||||||
|
|
|
@ -1022,6 +1022,24 @@ timesince
|
||||||
|
|
||||||
Formats a date as the time since that date (i.e. "4 days, 6 hours").
|
Formats a date as the time since that date (i.e. "4 days, 6 hours").
|
||||||
|
|
||||||
|
Takes an optional argument that is a variable containing the date to use as
|
||||||
|
the comparison point (without the argument, the comparison point is *now*).
|
||||||
|
For example, if ``blog_date`` is a date instance representing midnight on 1
|
||||||
|
June 2006, and ``comment_date`` is a date instanace for 08:00 on 1 June 2006,
|
||||||
|
then ``{{ comment_date|timesince:blog_date }}`` would return "8 hours".
|
||||||
|
|
||||||
|
timeuntil
|
||||||
|
~~~~~~~~~
|
||||||
|
|
||||||
|
Similar to ``timesince``, except that it measures the time from now until the
|
||||||
|
given date or datetime. For example, if today is 1 June 2006 and
|
||||||
|
``conference_date`` is a date instance holding 29 June 2006, then
|
||||||
|
``{{ conference_date|timeuntil }}`` will return "28 days".
|
||||||
|
|
||||||
|
Takes an optional argument that is a variable containing the date to use as
|
||||||
|
the comparison point (instead of *now*). If ``from_date`` contains 22 June
|
||||||
|
2006, then ``{{ conference_date|timeuntil:from_date }}`` will return "7 days".
|
||||||
|
|
||||||
title
|
title
|
||||||
~~~~~
|
~~~~~
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,7 @@ from django.conf import settings
|
||||||
from django import template
|
from django import template
|
||||||
from django.template import loader
|
from django.template import loader
|
||||||
from django.utils.translation import activate, deactivate, install
|
from django.utils.translation import activate, deactivate, install
|
||||||
from datetime import datetime
|
from datetime import datetime, timedelta
|
||||||
import traceback
|
import traceback
|
||||||
|
|
||||||
#################################
|
#################################
|
||||||
|
@ -57,6 +57,9 @@ class OtherClass:
|
||||||
def method(self):
|
def method(self):
|
||||||
return "OtherClass.method"
|
return "OtherClass.method"
|
||||||
|
|
||||||
|
# NOW used by timesince tag tests.
|
||||||
|
NOW = datetime.now()
|
||||||
|
|
||||||
# SYNTAX --
|
# SYNTAX --
|
||||||
# 'template_name': ('template contents', 'context dict', 'expected string output' or Exception class)
|
# 'template_name': ('template contents', 'context dict', 'expected string output' or Exception class)
|
||||||
TEMPLATE_TESTS = {
|
TEMPLATE_TESTS = {
|
||||||
|
@ -530,6 +533,27 @@ TEMPLATE_TESTS = {
|
||||||
'now02' : ('{% now "j "n" Y"%}', {}, template.TemplateSyntaxError),
|
'now02' : ('{% now "j "n" Y"%}', {}, template.TemplateSyntaxError),
|
||||||
# 'now03' : ('{% now "j \"n\" Y"%}', {}, str(datetime.now().day) + '"' + str(datetime.now().month) + '"' + str(datetime.now().year)),
|
# 'now03' : ('{% now "j \"n\" Y"%}', {}, str(datetime.now().day) + '"' + str(datetime.now().month) + '"' + str(datetime.now().year)),
|
||||||
# 'now04' : ('{% now "j \nn\n Y"%}', {}, str(datetime.now().day) + '\n' + str(datetime.now().month) + '\n' + str(datetime.now().year))
|
# 'now04' : ('{% now "j \nn\n Y"%}', {}, str(datetime.now().day) + '\n' + str(datetime.now().month) + '\n' + str(datetime.now().year))
|
||||||
|
|
||||||
|
### TIMESINCE TAG ##################################################
|
||||||
|
# Default compare with datetime.now()
|
||||||
|
'timesince01' : ('{{ a|timesince }}', {'a':datetime.now()}, '0 minutes'),
|
||||||
|
'timesince02' : ('{{ a|timesince }}', {'a':(datetime.now() - timedelta(days=1))}, '1 day'),
|
||||||
|
'timesince03' : ('{{ a|timesince }}', {'a':(datetime.now() -
|
||||||
|
timedelta(hours=1, minutes=25))}, '1 hour, 25 minutes'),
|
||||||
|
|
||||||
|
# Compare to a given parameter
|
||||||
|
'timesince04' : ('{{ a|timesince:b }}', {'a':NOW + timedelta(days=2), 'b':NOW + timedelta(days=1)}, '1 day'),
|
||||||
|
'timesince05' : ('{{ a|timesince:b }}', {'a':NOW + timedelta(days=2), 'b':NOW + timedelta(days=2)}, '0 minutes'),
|
||||||
|
|
||||||
|
### TIMEUNTIL TAG ##################################################
|
||||||
|
# Default compare with datetime.now()
|
||||||
|
'timeuntil01' : ('{{ a|timeuntil }}', {'a':datetime.now()}, '0 minutes'),
|
||||||
|
'timeuntil02' : ('{{ a|timeuntil }}', {'a':(datetime.now() + timedelta(days=1))}, '1 day'),
|
||||||
|
'timeuntil03' : ('{{ a|timeuntil }}', {'a':(datetime.now() + timedelta(hours=8, minutes=10))}, '8 hours, 10 minutes'),
|
||||||
|
|
||||||
|
# Compare to a given parameter
|
||||||
|
'timeuntil04' : ('{{ a|timeuntil:b }}', {'a':NOW - timedelta(days=1), 'b':NOW - timedelta(days=2)}, '1 day'),
|
||||||
|
'timeuntil05' : ('{{ a|timeuntil:b }}', {'a':NOW - timedelta(days=2), 'b':NOW - timedelta(days=2)}, '0 minutes'),
|
||||||
}
|
}
|
||||||
|
|
||||||
def test_template_loader(template_name, template_dirs=None):
|
def test_template_loader(template_name, template_dirs=None):
|
||||||
|
|
Loading…
Reference in New Issue