Difference between revisions of "IsHoliday"
From SmartWiki
Line 13: | Line 13: | ||
{ | { | ||
var cdate=dateadd(start,'D',i); | var cdate=dateadd(start,'D',i); | ||
− | if( | + | var cdatetemp=new Date(); |
− | + | var cdatearr=cdate.split("-"); | |
+ | cdatetemp.setFullYear(parseInt(cdatearr[0]),parseInt(cdatearr[1])-1,parseInt(cdatearr[2])); | ||
+ | if(isHoliday(cdate)||cdatetemp.getDate()==0||cdatetemp.getDate()==6)sub--; | ||
} | } | ||
document.frmevent.cf_1742956 .value=cdate; | document.frmevent.cf_1742956 .value=cdate; | ||
} | } | ||
− | + | bus_date_subtract(); | |
</pre> | </pre> |
Revision as of 10:11, 23 September 2009
To subtract business days from a given date, the following code can be used in a Special Browser script field that will populate a Calculated Value Custom Field with the new date.
In the Special Browser script field you define the function that subtracts the a number of days from a given date
function bus_date_subtract() { var frm=document.forms[0]; var formatstr="dd/mm/yyyy"; var start=ConvertDateStr(frm.startdate.value,formatstr); var sub=-5; for(i=-1;i>sub;i--) { var cdate=dateadd(start,'D',i); var cdatetemp=new Date(); var cdatearr=cdate.split("-"); cdatetemp.setFullYear(parseInt(cdatearr[0]),parseInt(cdatearr[1])-1,parseInt(cdatearr[2])); if(isHoliday(cdate)||cdatetemp.getDate()==0||cdatetemp.getDate()==6)sub--; } document.frmevent.cf_1742956 .value=cdate; } bus_date_subtract();
In Expression section of the Calculated Value Custom Field you would call the function:
bus_date_subtract();
Note: The function definition can be changed to accept parameters (fields containing dates) that are passed at the time of calling the function from any Calculated Value Custom Field.