mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-24 17:32:48 +00:00
Workflow helper object added to Template API, for use in new 2.1 Portlets.
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@5538 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -31,17 +31,20 @@ import freemarker.template.TemplateDateModel;
|
||||
import freemarker.template.TemplateMethodModelEx;
|
||||
import freemarker.template.TemplateModelException;
|
||||
import freemarker.template.TemplateNumberModel;
|
||||
import freemarker.template.TemplateScalarModel;
|
||||
|
||||
/**
|
||||
* @author Kevin Roast
|
||||
*
|
||||
* Custom FreeMarker Template language method.
|
||||
* <p>
|
||||
* Compare two dates to see if they differ by the specified number of miliseconds
|
||||
* Perform a test to see how two dates compare, optionally offset by a specified number of milliseconds.
|
||||
* <p>
|
||||
* Usage:
|
||||
* dateCompare(dateA, dateB) - 1 if dateA if greater than dateB
|
||||
* dateCompare(dateA, dateB, millis) - 1 if dateA is greater than dateB by at least millis, else 0
|
||||
* dateCompare(dateA, dateB, millis) - 1 if dateA is greater than dateB by at least millis, else 0
|
||||
* dateCompare(dateA, dateB, millis, test) - same as above, but the 'test' variable is one of the
|
||||
* following strings ">", "<", "==" - greater than, less than or equal - as the test to perform.
|
||||
*/
|
||||
public class DateCompareMethod extends BaseTemplateProcessorExtension implements TemplateMethodModelEx
|
||||
{
|
||||
@@ -66,13 +69,71 @@ public class DateCompareMethod extends BaseTemplateProcessorExtension implements
|
||||
diff = number.longValue();
|
||||
}
|
||||
}
|
||||
String test = null;
|
||||
if (args.size() == 4)
|
||||
{
|
||||
Object arg3 = args.get(3);
|
||||
if (arg3 instanceof TemplateScalarModel)
|
||||
{
|
||||
test = ((TemplateScalarModel)arg3).getAsString();
|
||||
}
|
||||
}
|
||||
if (arg0 instanceof TemplateDateModel && arg1 instanceof TemplateDateModel)
|
||||
{
|
||||
Date dateA = (Date)((TemplateDateModel)arg0).getAsDate();
|
||||
Date dateB = (Date)((TemplateDateModel)arg1).getAsDate();
|
||||
if (dateA.getTime() > (dateB.getTime() - diff))
|
||||
Date dateA = (Date)(((TemplateDateModel)arg0).getAsDate()).clone();
|
||||
Date dateB = (Date)(((TemplateDateModel)arg1).getAsDate()).clone();
|
||||
switch (((TemplateDateModel)arg0).getDateType())
|
||||
{
|
||||
result = 1;
|
||||
case TemplateDateModel.DATE:
|
||||
// clear time part
|
||||
dateA.setHours(0);
|
||||
dateA.setMinutes(0);
|
||||
dateA.setSeconds(0);
|
||||
dateA = new Date(dateA.getTime() / 1000L * 1000L);
|
||||
break;
|
||||
case TemplateDateModel.TIME:
|
||||
// clear date part
|
||||
dateA.setDate(1);
|
||||
dateA.setMonth(0);
|
||||
dateA.setYear(0);
|
||||
break;
|
||||
}
|
||||
switch (((TemplateDateModel)arg1).getDateType())
|
||||
{
|
||||
case TemplateDateModel.DATE:
|
||||
// clear time part
|
||||
dateB.setHours(0);
|
||||
dateB.setMinutes(0);
|
||||
dateB.setSeconds(0);
|
||||
dateB = new Date(dateB.getTime() / 1000L * 1000L);
|
||||
break;
|
||||
case TemplateDateModel.TIME:
|
||||
// clear date part
|
||||
dateB.setDate(1);
|
||||
dateB.setMonth(0);
|
||||
dateB.setYear(0);
|
||||
break;
|
||||
}
|
||||
if (test == null || test.equals(">"))
|
||||
{
|
||||
if (dateA.getTime() > (dateB.getTime() - diff))
|
||||
{
|
||||
result = 1;
|
||||
}
|
||||
}
|
||||
else if (test.equals("<"))
|
||||
{
|
||||
if (dateA.getTime() < (dateB.getTime() - diff))
|
||||
{
|
||||
result = 1;
|
||||
}
|
||||
}
|
||||
else if (test.equals("=="))
|
||||
{
|
||||
if (dateA.getTime() == (dateB.getTime() - diff))
|
||||
{
|
||||
result = 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user