PageRenderTime 65ms CodeModel.GetById 30ms RepoModel.GetById 1ms app.codeStats 0ms

/modules/Calendar/calendarLayout.php

https://bitbucket.org/thomashii/vtigercrm-5.4-for-postgresql
PHP | 2203 lines | 1839 code | 139 blank | 225 comment | 395 complexity | 268aeff444a6aa0109477f46291c5705 MD5 | raw file
Possible License(s): LGPL-2.1, GPL-2.0

Large files files are truncated, but you can click here to view the full file

  1. <?php
  2. /*+********************************************************************************
  3. * The contents of this file are subject to the vtiger CRM Public License Version 1.0
  4. * ("License"); You may not use this file except in compliance with the License
  5. * The Original Code is: vtiger CRM Open Source
  6. * The Initial Developer of the Original Code is vtiger.
  7. * Portions created by vtiger are Copyright (C) vtiger.
  8. * All Rights Reserved.
  9. ********************************************************************************/
  10. require_once('include/database/PearDatabase.php');
  11. require_once('include/utils/CommonUtils.php');
  12. require_once('include/utils/UserInfoUtil.php');
  13. require_once('modules/Calendar/CalendarCommon.php');
  14. /**
  15. * Function creates HTML to display Events and Todos div tags
  16. * @param array $param_arr - collection of objects and strings
  17. * @param string $viewBox - string 'listview' or 'hourview' or may be empty. if 'listview' means get Events ListView.if 'hourview' means gets Events HourView. if empty means get Todos ListView
  18. * @param string $subtab - string 'todo' or 'event'. if 'todo' means Todos View else Events View
  19. */
  20. function calendar_layout(& $param_arr,$viewBox='',$subtab='')
  21. {
  22. global $mod_strings,$cal_log;
  23. $category = getParentTab();
  24. $cal_log->debug("Entering calendar_layout() method");
  25. $cal_header = array ();
  26. if (isset($param_arr['size']) && $param_arr['size'] == 'small')
  27. $param_arr['calendar']->show_events = false;
  28. $cal_header['view'] = $param_arr['view'];
  29. $cal_header['IMAGE_PATH'] = $param_arr['IMAGE_PATH'];
  30. $cal_header['calendar'] = $param_arr['calendar'];
  31. $eventlabel = $mod_strings['LBL_EVENTS'];
  32. $todolabel = $mod_strings['LBL_TODOS'];
  33. //if $param_arr['size'] is set to 'small', get small(mini) calendar
  34. if(isset($param_arr['size']) && $param_arr['size'] == 'small')
  35. {
  36. get_mini_calendar($param_arr);
  37. }
  38. else
  39. {
  40. // User Select Customization
  41. $onlyForUserParam = "onlyforuser=" . calendarview_getSelectedUserId();
  42. // END
  43. //To differentiate selected subtab from unselected one - Starts
  44. if($subtab == 'event')
  45. {
  46. $eventtab_class = 'dvtSelectedCell';
  47. $todotab_class = 'dvtUnSelectedCell';
  48. $event_anchor = $eventlabel;
  49. // Added for User Based CustomView for Calendar module
  50. $todo_anchor = "<a href='index.php?module=Calendar&action=index&view=".$cal_header['view']."".$cal_header['calendar']->date_time->get_date_str()."&viewOption=".$viewBox."&subtab=todo&parenttab=".$category."&$onlyForUserParam'>".$todolabel."</a>";
  51. }
  52. elseif($subtab == 'todo')
  53. {
  54. $eventtab_class = 'dvtUnSelectedCell';
  55. $todotab_class = 'dvtSelectedCell';
  56. // Added User Based CustomView for Calendar module
  57. $event_anchor = "<a href='index.php?module=Calendar&action=index&view=".$cal_header['view']."".$cal_header['calendar']->date_time->get_date_str()."&viewOption=".$viewBox."&subtab=event&parenttab=".$category."&$onlyForUserParam'>".$eventlabel."</a>";
  58. $todo_anchor = $todolabel;
  59. }
  60. //Ends
  61. //To get calendar header and its links(like Day,Week,Month,Year and etc.)
  62. get_cal_header_tab($cal_header,$viewBox,$subtab);
  63. $subheader = "";
  64. $subheader .=<<<EOQ
  65. <tr>
  66. <td colspan="8" class="calBorder">
  67. <table align="center" border="0" cellpadding="0" cellspacing="0" width="100%">
  68. <tr>
  69. <td>
  70. <table class="small" border="0" cellpadding="3" cellspacing="0" width="100%">
  71. <tr>
  72. <td class="dvtTabCache" style="width: 10px;" nowrap="nowrap">&nbsp;</td>
  73. <td class="$eventtab_class" id="pi" align="center" nowrap="nowrap" width="75">$event_anchor</td>
  74. <td class="dvtTabCache" style="width: 10px;" nowrap="nowrap">&nbsp;</td>
  75. <td class="$todotab_class" style="width:100px;" id="mi" align="center" nowrap="nowrap">$todo_anchor</td>
  76. <td class="dvtTabCache" nowrap="nowrap">&nbsp;</td>
  77. </tr>
  78. </table>
  79. </td>
  80. </tr>
  81. <tr>
  82. <td class="calInnerBorder" align="left" bgcolor="#ffffff" valign="top">
  83. EOQ;
  84. echo $subheader;
  85. if($viewBox == 'hourview' && $subtab == 'event')
  86. {
  87. get_cal_header_data($param_arr,$viewBox,$subtab);
  88. getHourView($param_arr);
  89. }
  90. elseif($viewBox == 'listview' && $subtab == 'event')
  91. {
  92. get_cal_header_data($param_arr,$viewBox,$subtab);
  93. getEventListView($param_arr);
  94. }
  95. elseif($subtab == 'todo')
  96. {
  97. $todo_list = "";
  98. $todo_list .= getTodosListView($param_arr,'',$subtab);
  99. $todo_list .= '</td></tr></table></td></tr></table><br>';
  100. echo $todo_list;
  101. }
  102. }
  103. $cal_log->debug("Exiting calendar_layout() method");
  104. }
  105. /**
  106. * Function creates HTML to display small(mini) Calendar
  107. * @param array $cal - collection of objects and strings
  108. */
  109. function get_mini_calendar(& $cal){
  110. global $current_user,$adb,$cal_log,$mod_strings,$theme;
  111. $category = getParentTab();
  112. $cal_log->debug('Entering get_mini_calendar() method...');
  113. $count = 0;
  114. //To decide number of rows(weeks) in a month
  115. if ($cal['calendar']->month_array[$cal['calendar']->slices[35]]->start_time->month != $cal['calendar']->date_time->month) {
  116. $rows = 5;
  117. } else {
  118. $rows = 6;
  119. }
  120. $minical = "";
  121. $minical .= "<table class='mailClient ' bgcolor='white' border='0' cellpadding='2' cellspacing='0' width='98%'>
  122. <tr>
  123. <td class='calHdr'>&nbsp;</td>
  124. <td style='padding:5px' colspan='6' class='calHdr' align='center'>".get_previous_cal($cal)."&nbsp;";
  125. $minical .= "<a style='text-decoration: none;' href='index.php?module=Calendar&action=index&view=".$cal['view']."".$cal['calendar']->date_time->get_date_str()."&parenttab=".$category."'><b>".display_date($cal['view'],$cal['calendar']->date_time)."</b></a>&nbsp;".get_next_cal($cal)."</td>";
  126. $minical .= "<td class='calHdr' align='right'><a href='javascript:ghide(\"miniCal\");'><img src='". vtiger_imageurl('close.gif', $theme). "' align='right' border='0'></a>
  127. </td></tr>";
  128. $minical .= "<tr class='hdrNameBg'>";
  129. //To display days in week
  130. $minical .= '<th width="12%">'.$mod_strings['LBL_WEEK'].'</th>';
  131. for ($i = 0; $i < 7; $i ++){
  132. $weekday = $mod_strings['cal_weekdays_short'][$i];
  133. $minical .= '<th width="12%">'.$weekday.'</th>';
  134. }
  135. $minical .= "</tr>";
  136. $event_class = '';
  137. $class = '';
  138. for ($i = 0; $i < $rows; $i++){
  139. $minical .= "<tr>";
  140. //calculate blank days for first week
  141. for ($j = 0; $j < 7; $j ++){
  142. $cal['slice'] = $cal['calendar']->month_array[$cal['calendar']->slices[$count]];
  143. $class = dateCheck($cal['slice']->start_time->get_formatted_date());
  144. if($j == 0){
  145. $minical .= "<td style='text-align:center' ><a href='index.php?module=Calendar&action=index&view=week".$cal['slice']->start_time->get_date_str()."&parenttab=".$category."'>".$cal['slice']->start_time->week."</td>";
  146. }
  147. //To differentiate day having events from other days
  148. if(count($cal['slice']->activities) != 0 && ($cal['slice']->start_time->get_formatted_date() == $cal['slice']->activities[0]->start_time->get_formatted_date())){
  149. $event_class = 'class="eventDay"';
  150. }else{
  151. $event_class = '';
  152. }
  153. //To differentiate current day from other days
  154. if($class != '' ){
  155. $class = 'class="'.$class.'"';
  156. }else{
  157. $class = $event_class;
  158. }
  159. //To display month dates
  160. if ($cal['slice']->start_time->getMonth() == $cal['calendar']->date_time->getMonth()){
  161. $minical .= "<td ".$class." style='text-align:center' >";
  162. $minical .= "<a href='index.php?module=Calendar&action=index&view=".$cal['slice']->getView()."".$cal['slice']->start_time->get_date_str()."&parenttab=".$category."'>";
  163. $minical .= $cal['slice']->start_time->get_Date()."</a></td>";
  164. }else{
  165. $minical .= "<td style='text-align:center' ></td>";
  166. }
  167. $count++;
  168. }
  169. $minical .= '</tr>';
  170. }
  171. $minical .= "</table>";
  172. echo $minical;
  173. $cal_log->debug("Exiting get_mini_calendar() method...");
  174. }
  175. /**
  176. * Function creates HTML to display Calendar Header and its Links
  177. * @param array $header - collection of objects and strings
  178. * @param string $viewBox - string 'listview' or 'hourview' or may be empty. if 'listview' means Events ListView.if 'hourview' means Events HourView. if empty means get Todos ListView
  179. * @param string $subtab - string 'todo' or 'event'. if 'todo' means Todos View else Events View
  180. */
  181. function get_cal_header_tab(& $header,$viewBox,$subtab)
  182. {
  183. global $mod_strings,$cal_log;
  184. $category = getParentTab();
  185. $cal_log->debug("Entering get_cal_header_tab() method...");
  186. $tabhtml = "";
  187. $count = 1;
  188. include_once 'modules/Calendar/addEventUI.php';
  189. include_once 'modules/Calendar/header.php';
  190. $eventlabel = $mod_strings['LBL_EVENTS'];
  191. $todolabel = $mod_strings['LBL_TODOS'];
  192. $div = "<div id='miniCal' style='width:300px; position:absolute; display:none; left:100px; top:100px; z-index:100000; background-color:white'></div>
  193. <div id='calSettings' class='layerPopup calSettings' style='display:none;width:500px;' align=center ></div>
  194. <div id='dataArray'></div>
  195. ";
  196. echo $div;
  197. $tabhtml .= "<table class='small calHdr' align='center' border='0' cellpadding='5' cellspacing='0' width='100%'><tr>";
  198. $links = array ('day','week','month','year');
  199. //To differentiate the selected link from unselected links
  200. foreach ($links as $link)
  201. {
  202. if ($header['view'] == $link)
  203. {
  204. $class = 'calSel';
  205. $anchor = $mod_strings["LBL_".$header['calendar']->getCalendarView($link)];
  206. }
  207. else
  208. {
  209. $class = 'calUnSel';
  210. $anchor = "<a href='index.php?module=Calendar&action=index&view=".$link."".$header['calendar']->date_time->get_date_str()."&viewOption=".$viewBox."&subtab=".$subtab."&parenttab=".$category."'>".$mod_strings["LBL_".$header['calendar']->getCalendarView($link)]."</a>";
  211. }
  212. if($count == 1)
  213. $tabhtml .= "<!-- day week month buttons --> <td style='border-left: 1px solid #666666;' class=".$class.">".$anchor."</td>";
  214. else
  215. $tabhtml .= "<td class=".$class.">".$anchor."</td>";
  216. $count++;
  217. }
  218. //To get Navigation(next&previous) links and display Date info
  219. $tabhtml .= "<td width='30%'>
  220. <table border='0' cellpadding='0' cellspacing='0'>
  221. <tr>
  222. <td>".get_previous_cal($header,$viewBox,$subtab)."
  223. </td>";
  224. $tabhtml .= "<td class='calendarNav'>".display_date($header['view'],$header['calendar']->date_time)."</td>";
  225. $tabhtml .= "<td>".get_next_cal($header,$viewBox,$subtab)."
  226. </td></tr>
  227. </table>
  228. </td>";
  229. $tabhtml .= "<td width='2%'><img onClick='fnvshobj(this,\"miniCal\"); getMiniCal(\"view=".$header['calendar']->view."".$header['calendar']->date_time->get_date_str()."&viewOption=".$viewBox."&subtab=".$subtab."&parenttab=".$category."\");' src='".$header['IMAGE_PATH']."btnL3Calendar.gif' alt='".$mod_strings['LBL_OPENCAL']."...' title='".$mod_strings['LBL_OPENCAL']."...' align='absmiddle' border='0'></td>";
  230. $tabhtml .= "<td width=20% ><img onClick='fnvshobj(this,\"calSettings\"); getCalSettings(\"view=".$header['calendar']->view."".$header['calendar']->date_time->get_date_str()."&viewOption=".$viewBox."&subtab=".$subtab."&parenttab=".$category."\");' src='".$header['IMAGE_PATH']."tbarSettings.gif' alt='".$mod_strings['LBL_SETTINGS']."' title='".$mod_strings['LBL_SETTINGS']."' align='absmiddle' border='0'></td>";
  231. $tabhtml .= "<td class='calHdr calTopRight componentName'>".$app_strings['Calendar']."</td>";
  232. $tabhtml .= "</tr>";
  233. echo $tabhtml;
  234. $cal_log->debug("Exiting get_cal_header_tab() method...");
  235. }
  236. /**
  237. * Function creates HTML to display number of Events, Todos and pending list in calendar under header(Eg:Total Events : 5, 2 Pending / Total To Dos: 4, 1 Pending)
  238. * @param array $cal_arr - collection of objects and strings
  239. * @param string $viewBox - string 'listview' or 'hourview'. if 'listview' means Events ListView.if 'hourview' means Events HourView.
  240. */
  241. function get_cal_header_data(& $cal_arr,$viewBox,$subtab)
  242. {
  243. global $mod_strings,$cal_log,$current_user,$adb,$theme;
  244. $cal_log->debug("Entering get_cal_header_data() method...");
  245. global $current_user,$app_strings;
  246. $date_format = $current_user->date_format;
  247. $format = $cal_arr['calendar']->hour_format;
  248. $hour_startat = timeString(array('hour' => date('H:i', (time() + (5 * 60))), 'minute' => 0), '24');
  249. $hour_endat = timeString(array('hour'=>date('H:i',(time() + (60 * 60))),'minute'=>0),'24');
  250. $time_arr = getaddEventPopupTime($hour_startat,$hour_endat,$format);
  251. $date = new DateTimeField(null);
  252. //To get date in user selected format
  253. $temp_date = $date->getDisplayDate();
  254. if($current_user->column_fields['is_admin']=='on')
  255. $Res = $adb->pquery("select * from vtiger_activitytype",array());
  256. else
  257. {
  258. $roleid=$current_user->roleid;
  259. $subrole = getRoleSubordinates($roleid);
  260. if(count($subrole)> 0)
  261. {
  262. $roleids = $subrole;
  263. array_push($roleids, $roleid);
  264. }
  265. else
  266. {
  267. $roleids = $roleid;
  268. }
  269. if (count($roleids) > 1) {
  270. $Res=$adb->pquery("select distinct activitytype from vtiger_activitytype inner join vtiger_role2picklist on vtiger_role2picklist.picklistvalueid = vtiger_activitytype.picklist_valueid where roleid in (". generateQuestionMarks($roleids) .") and picklistid in (select picklistid from vtiger_activitytype) order by sortid asc", array($roleids));
  271. } else {
  272. $Res=$adb->pquery("select distinct activitytype from vtiger_activitytype inner join vtiger_role2picklist on vtiger_role2picklist.picklistvalueid = vtiger_activitytype.picklist_valueid where roleid = ? and picklistid in (select picklistid from vtiger_activitytype) order by sortid asc", array($roleid));
  273. }
  274. }
  275. $eventlist='';
  276. for($i=0; $i<$adb->num_rows($Res);$i++)
  277. {
  278. $eventlist .= $adb->query_result($Res,$i,'activitytype').";";
  279. }
  280. $headerdata = "";
  281. $headerdata .="
  282. <div style='display: block;' id='mnuTab'>
  283. <form name='EventViewOption' method='POST' action='index.php' style='display:inline;'>
  284. <input type='hidden' id='complete_view' name='complete_view' value='' />
  285. <table align='center' border='0' cellpadding='5' cellspacing='0' width='98%'>
  286. <tr><td colspan='3'>&nbsp;</td></tr>";
  287. if(isPermitted("Calendar","EditView") == "yes")
  288. {
  289. $headerdata .="<tr>
  290. <td>
  291. <table><tr><td class='calAddButton' style='cursor:pointer;height:30px' align='center' width='15%' onMouseOver='fnAddEvent(this,\"addEventDropDown\",\"".$temp_date."\",\"".$temp_date."\",\"".$time_arr['starthour']."\",\"".$time_arr['startmin']."\",\"".$time_arr['startfmt']."\",\"".$time_arr['endhour']."\",\"".$time_arr['endmin']."\",\"".$time_arr['endfmt']."\",\"".$viewBox."\",\"".$subtab."\",\"".$eventlist."\");'>
  292. ".$mod_strings['LBL_ADD']."
  293. <img src='".vtiger_imageurl('menuDnArrow.gif', $theme)."' style='padding-left: 5px;' border='0'>
  294. </td></tr></table> </td>";
  295. }
  296. else
  297. {
  298. $headerdata .="<tr><td>&nbsp;</td>";
  299. }
  300. $headerdata .="<td align='center' width='43%'><span id='total_activities'>";//USER SELECT CUSTOMIZATION
  301. $headerdata .= getEventInfo($cal_arr,'listcnt');
  302. $headerdata .= "</span></td>
  303. <td align='center' width='40%'><table border=0 cellspacing=0 cellpadding=2><tr><td class=small><b>".$mod_strings['LBL_VIEW']." : </b></td><td>";//USER SELECT CUSTOMIZATION
  304. $view_options = getEventViewOption($cal_arr,$viewBox);
  305. // User Select Customization
  306. $view_options .= calendarview_getUserSelectOptions( calendarview_getSelectedUserId() );
  307. // END
  308. $headerdata .=$view_options."</td></tr></table>
  309. </td>
  310. </tr>
  311. </table></form>";
  312. echo $headerdata;
  313. $cal_log->debug("Exiting get_cal_header_data() method...");
  314. }
  315. /**
  316. * Function creates HTML select statement to display View selection box
  317. * @param array $cal - collection of objects and strings
  318. * @param string $viewBox - string 'listview' or 'hourview'. if 'listview' means get Events ListView.if 'hourview' means get Events HourView.
  319. * return string $view - html selection box
  320. */
  321. function getEventViewOption(& $cal,$viewBox)
  322. {
  323. global $mod_strings,$cal_log;
  324. $category = getParentTab();
  325. if($viewBox == 'listview')
  326. {
  327. $list_sel = 'selected';
  328. $hr_sel = '';
  329. }
  330. else
  331. {
  332. $list_sel = '';
  333. $hr_sel = 'selected';
  334. }
  335. $cal_log->debug("Entering getEventViewOption() method...");
  336. $view = "<input type='hidden' name='view' value='".$cal['calendar']->view."'>
  337. <input type='hidden' name='hour' value='".$cal['calendar']->date_time->hour."'>
  338. <input type='hidden' name='day' value='".$cal['calendar']->date_time->day."'>
  339. <input type='hidden' name='week' value='".$cal['calendar']->date_time->week."'>
  340. <input type='hidden' name='month' value='".$cal['calendar']->date_time->month."'>
  341. <input type='hidden' name='year' value='".$cal['calendar']->date_time->year."'>
  342. <input type='hidden' name='parenttab' value='".$category."'>
  343. <input type='hidden' name='module' value='Calendar'>
  344. <input type='hidden' name='return_module' value='Calendar'>
  345. <input type='hidden' name='action' value=''>
  346. <input type='hidden' name='return_action' value=''>
  347. <select name='viewOption' class='importBox' id='view_Option' onChange='fnRedirect();'>";
  348. if($cal['view'] == 'day')
  349. {
  350. $view .="<option value='listview' ".$list_sel.">".$mod_strings['LBL_LISTVIEW']."</option>
  351. <option value='hourview' ".$hr_sel.">".$mod_strings['LBL_HRVIEW']."</option>";
  352. }
  353. elseif($cal['view'] == 'week')
  354. {
  355. $view .="<option value='listview' ".$list_sel.">".$mod_strings['LBL_LISTVIEW']."</option>
  356. <option value='hourview' ".$hr_sel.">".$mod_strings['LBL_WEEKVIEW']."</option>";
  357. }
  358. elseif($cal['view'] == 'month')
  359. {
  360. $view .="<option value='listview' ".$list_sel.">".$mod_strings['LBL_LISTVIEW']."</option>
  361. <option value='hourview' ".$hr_sel.">".$mod_strings['LBL_MONTHVIEW']."</option>";
  362. }
  363. elseif($cal['view'] == 'year')
  364. {
  365. $view .="<option value='listview' ".$list_sel.">".$mod_strings['LBL_LISTVIEW']."</option>
  366. <option value='hourview' ".$hr_sel.">".$mod_strings['LBL_YEARVIEW']."</option>";
  367. }
  368. else
  369. die("view is not defined");
  370. $view .="</select>";
  371. $cal_log->debug("Exiting getEventViewOption() method...");
  372. return $view;
  373. }
  374. /**
  375. * Function creates HTML anchor tag to get previous-day/week/month/year view
  376. * @param array $cal - collection of objects and strings
  377. * @param string $viewBox - string 'listview' or 'hourview' or may be empty. if 'listview' means previous link in Events ListView.if 'hourview' means previous link in Events HourView. if empty means previous link in Todos ListView
  378. * @param string $subtab - string 'todo' or 'event' or may be empty. if 'todo' means Todos View. if 'event' means Events View. if empty means small calendar view.
  379. * return string $link - html tags in string format
  380. */
  381. function get_previous_cal(& $cal,$viewBox='',$subtab='')
  382. {
  383. global $mod_strings,$cal_log,$theme;
  384. $category = getParentTab();
  385. $cal_log->debug("Entering get_previous_cal() method...");
  386. if(isset($cal['size']) && $cal['size'] == 'small')
  387. {
  388. $link = "<a href='javascript:getMiniCal(\"view=".$cal['calendar']->view."".$cal['calendar']->get_datechange_info('prev')."&parenttab=".$category."\")'><img src= '". vtiger_imageurl('small_left.gif', $theme)."' border='0' align='absmiddle' /></a>";
  389. }
  390. else
  391. {
  392. $link = "<a href='index.php?action=index&module=Calendar&view=".$cal['calendar']->view."".$cal['calendar']->get_datechange_info('prev')."&viewOption=".$viewBox."&subtab=".$subtab."&parenttab=".$category."&onlyforuser=".calendarview_getSelectedUserId()."' onclick='VtigerJS_DialogBox.block();return true;'><img src='".$cal['IMAGE_PATH']."cal_prev_nav.gif' border='0' align='absmiddle' /></a>";
  393. }
  394. $cal_log->debug("Exiting get_previous_cal() method...");
  395. return $link;
  396. }
  397. /**
  398. * Function creates HTML anchor tag to get next-day/week/month/year view
  399. * @param array $cal - collection of objects and strings
  400. * @param string $viewBox - string 'listview' or 'hourview' or may be empty. if 'listview' means next link in Events ListView.if 'hourview' means next link in Events HourView. if empty means next link in Todos ListView
  401. * @param string $subtab - string 'todo' or 'event' or may be empty. if 'todo' means Todos View. if 'event' means Events View. if empty means small calendar view.
  402. * return string $link - html tags in string format
  403. */
  404. function get_next_cal(& $cal,$viewBox='',$subtab='')
  405. {
  406. global $mod_strings,$cal_log,$theme;
  407. $category = getParentTab();
  408. $cal_log->debug("Entering get_next_cal() method...");
  409. if(isset($cal['size']) && $cal['size'] == 'small')
  410. {
  411. $link = "<a href='javascript:getMiniCal(\"view=".$cal['calendar']->view."".$cal['calendar']->get_datechange_info('next')."&parenttab=".$category."\")' ><img src='". vtiger_imageurl('small_right.gif', $theme)."' border='0' align='absmiddle' /></a>";
  412. }
  413. else
  414. {
  415. $link = "<a href='index.php?action=index&module=Calendar&view=".$cal['calendar']->view."".$cal['calendar']->get_datechange_info('next')."&viewOption=".$viewBox."&subtab=".$subtab."&parenttab=".$category."&onlyforuser=".calendarview_getSelectedUserId()."' onclick='VtigerJS_DialogBox.block();return true;'><img src='".$cal['IMAGE_PATH']."cal_next_nav.gif' border='0' align='absmiddle' /></a>";
  416. }
  417. $cal_log->debug("Exiting get_next_cal() method...");
  418. return $link;
  419. }
  420. /**
  421. * Function to get date info depending upon on the calendar view(Eg: 21 July 2000)
  422. * @param string $view - calendar view(day/week/month/year)
  423. * @param array $date_time - contains DateTime object
  424. * return string $label - date info(Eg for dayview : 13 July 2000)
  425. */
  426. function display_date($view,$date_time)
  427. {
  428. global $cal_log;
  429. $cal_log->debug("Entering display_date() method...");
  430. if ($view == 'day')
  431. {
  432. //$label = $date_time->getdayofWeek()." ";
  433. $label = $date_time->get_Date()." ";
  434. $label .= $date_time->getmonthName()." ";
  435. $label .= $date_time->year;
  436. $cal_log->debug("Exiting display_date() method...");
  437. return $label;
  438. }
  439. elseif ($view == 'week')
  440. {
  441. $week_start = $date_time->getThisweekDaysbyIndex(1);
  442. $week_end = $date_time->getThisweekDaysbyIndex(7);
  443. $label = $week_start->get_Date()." ";
  444. $label .= $week_start->getmonthName()." ";
  445. $label .= $week_start->year;
  446. $label .= " - ";
  447. $label .= $week_end->get_Date()." ";
  448. $label .= $week_end->getmonthName()." ";
  449. $label .= $week_end->year;
  450. $cal_log->debug("Exiting display_date() method...");
  451. return $label;
  452. }
  453. elseif ($view == 'month')
  454. {
  455. $label = $date_time->getmonthName()." ";
  456. $label .= $date_time->year;
  457. $cal_log->debug("Exiting display_date() method...");
  458. return $label;
  459. }
  460. elseif ($view == 'year')
  461. {
  462. $cal_log->debug("Exiting display_date() method...");
  463. return $date_time->year;
  464. }
  465. }
  466. /**
  467. * Function to get css class name for date
  468. * @param string $slice_date - date
  469. * returns string - css class name or empty string
  470. */
  471. function dateCheck($slice_date)
  472. {
  473. global $cal_log;
  474. $cal_log->debug("Entering dateCheck() method...");
  475. $userCurrenDate = new DateTimeField(date('Y-m-d H:i:s'));
  476. $today = $userCurrenDate->getDisplayDate();
  477. if($today == $slice_date)
  478. {
  479. $cal_log->debug("Exiting dateCheck() method...");
  480. //css class for day having event(s)
  481. return 'currDay';
  482. }
  483. else
  484. {
  485. $cal_log->debug("Exiting dateCheck() method...");
  486. return '';
  487. }
  488. }
  489. /**
  490. * Function to construct respective calendar layout depends on the calendar view
  491. * @param array $view - collection of objects and strings
  492. */
  493. function getHourView(& $view)
  494. {
  495. global $cal_log,$theme;
  496. $hourview_layout = '';
  497. $cal_log->debug("Entering getHourView() method...");
  498. $hourview_layout .= '<br /><!-- HOUR VIEW LAYER STARTS HERE -->
  499. <div id="hrView" align=center>';
  500. if($view['view'] == 'day')
  501. $hourview_layout .= getDayViewLayout($view);
  502. elseif($view['view'] == 'week')
  503. $hourview_layout .= getWeekViewLayout($view);
  504. elseif($view['view'] == 'month')
  505. $hourview_layout .= getMonthViewLayout($view);
  506. elseif($view['view'] == 'year')
  507. $hourview_layout .= getYearViewLayout($view);
  508. else
  509. die("view:".$view['view']." is not defined");
  510. $hourview_layout .= '<br></div>
  511. </div>';
  512. $hourview_layout .= '<br></td></tr></table></td></tr></table>
  513. </td></tr></table>
  514. </td></tr></table>
  515. </td></tr></table>
  516. </div>
  517. </td>
  518. <td valign=top><img src="'.vtiger_imageurl('showPanelTopRight.gif', $theme).'"></td>
  519. </tr>
  520. </table>
  521. <br>';
  522. echo $hourview_layout;
  523. $cal_log->debug("Exiting getHourView() method...");
  524. }
  525. /**
  526. * Fuction constructs Events ListView depends on the view
  527. * @param array $cal - collection of objects and strings
  528. * @param string $mode - string 'listcnt' or empty. if empty means get Events ListView else get total no. of events and no. of pending events Info.
  529. * returns string $activity_list - total no. of events and no. of pending events Info(Eg: Total Events : 2, 1 Pending).
  530. */
  531. function getEventListView(& $cal,$mode='')
  532. {
  533. global $cal_log,$theme;
  534. $list_view = "";
  535. $cal_log->debug("Entering getEventListView() method...");
  536. if($cal['calendar']->view == 'day')
  537. {
  538. $start_date = $end_date = $cal['calendar']->date_time->get_DB_formatted_date();
  539. }
  540. elseif($cal['calendar']->view == 'week')
  541. {
  542. $start_date = $cal['calendar']->slices[0];
  543. $end_date = $cal['calendar']->slices[6];
  544. $start_date = DateTimeField::convertToDBFormat($start_date);
  545. $end_date = DateTimeField::convertToDBFormat($end_date);
  546. }
  547. elseif($cal['calendar']->view == 'month')
  548. {
  549. $start_date = $cal['calendar']->date_time->getThismonthDaysbyIndex(0);
  550. $end_date = $cal['calendar']->date_time->getThismonthDaysbyIndex($cal['calendar']->date_time->daysinmonth - 1);
  551. $start_date = $start_date->get_DB_formatted_date();
  552. $end_date = $end_date->get_DB_formatted_date();
  553. }
  554. elseif($cal['calendar']->view == 'year')
  555. {
  556. $start_date = $cal['calendar']->date_time->getThisyearMonthsbyIndex(0);
  557. $end_date = $cal['calendar']->date_time->get_first_day_of_changed_year('increment');
  558. $start_date = $start_date->get_DB_formatted_date();
  559. $end_date = $end_date->get_DB_formatted_date();
  560. }
  561. else
  562. {
  563. die("view:".$cal['calendar']->view." is not defined");
  564. }
  565. //if $mode value is empty means get Events list in array format else get the count of total events and pending events in array format.
  566. if($mode != '')
  567. {
  568. $activity_list = getEventList($cal, $start_date, $end_date,$mode);
  569. $cal_log->debug("Exiting getEventListView() method...");
  570. return $activity_list;
  571. }
  572. else
  573. {
  574. $ret_arr = getEventList($cal, $start_date, $end_date,$mode);
  575. $activity_list = $ret_arr[0];
  576. $navigation_array = $ret_arr[1];
  577. }
  578. //To get Events listView
  579. $list_view .="<br><div id='listView'>";
  580. $list_view .=constructEventListView($cal,$activity_list,$navigation_array);
  581. $list_view .="<br></div>
  582. </div>";
  583. $list_view .="<br></td></tr></table></td></tr></table>
  584. </td></tr></table>
  585. </td></tr></table>
  586. </div>
  587. </td></tr></table>
  588. </td>
  589. <td valign=top><img src='".vtiger_imageurl('showPanelTopRight.gif', $theme)."'></td>
  590. </tr>
  591. </table>
  592. <br>";
  593. echo $list_view;
  594. $cal_log->debug("Exiting getEventListView() method...");
  595. }
  596. /**
  597. * Fuction constructs Todos ListView depends on the view
  598. * @param array $cal - collection of objects and strings
  599. * @param string $check - string 'listcnt' or empty. if empty means get Todos ListView else get total no. of Todos and no. of pending todos Info.
  600. * returns string $todo_list - total no. of todos and no. of pending todos Info(Eg: Total Todos : 2, 1 Pending).
  601. */
  602. function getTodosListView($cal, $check='',$subtab='')
  603. {
  604. global $cal_log,$theme;
  605. $list_view = "";
  606. $cal_log->debug("Entering getTodosListView() method...");
  607. if($cal['calendar']->view == 'day') {
  608. $start_date = $end_date = $cal['calendar']->date_time->get_DB_formatted_date();
  609. } elseif ($cal['calendar']->view == 'week') {
  610. $start_date = $cal['calendar']->slices[0];
  611. $end_date = $cal['calendar']->slices[6];
  612. $start_date = DateTimeField::convertToDBFormat($start_date);
  613. $end_date = DateTimeField::convertToDBFormat($end_date);
  614. } elseif ($cal['calendar']->view == 'month') {
  615. $start_date = $cal['calendar']->date_time->getThismonthDaysbyIndex(0);
  616. $end_date = $cal['calendar']->date_time->getThismonthDaysbyIndex($cal['calendar']->
  617. date_time->daysinmonth - 1);
  618. $start_date = $start_date->get_DB_formatted_date();
  619. $end_date = $end_date->get_DB_formatted_date();
  620. } elseif ($cal['calendar']->view == 'year') {
  621. $start_date = $cal['calendar']->date_time->getThisyearMonthsbyIndex(0);
  622. $end_date = $cal['calendar']->date_time->get_first_day_of_changed_year('increment');
  623. $start_date = $start_date->get_DB_formatted_date();
  624. $end_date = $end_date->get_DB_formatted_date();
  625. } else {
  626. die("view:" . $cal['calendar']->view . " is not defined");
  627. }
  628. //if $check value is empty means get Todos list in array format else get the count of total todos and pending todos in array format.
  629. if($check != '')
  630. {
  631. $todo_list = getTodoList($cal, $start_date, $end_date,$check);
  632. $cal_log->debug("Exiting getTodosListView() method...");
  633. return $todo_list;
  634. }
  635. else
  636. {
  637. $ret_arr = getTodoList($cal, $start_date, $end_date,$check);
  638. $todo_list = $ret_arr[0];
  639. $navigation_arr = $ret_arr[1];
  640. }
  641. $cal_log->debug("Exiting getTodosListView() method...");
  642. $list_view .="<div id='mnuTab2' style='background-color: rgb(255, 255, 215); display:block;'>";
  643. //To get Todos listView
  644. $list_view .= constructTodoListView($todo_list,$cal,$subtab,$navigation_arr);
  645. $list_view .="</div></div></td></tr></table></td></tr></table>
  646. </td></tr></table>
  647. </td></tr></table>
  648. </td></tr></table>
  649. </div>
  650. </td>
  651. <td valign=top><img src='".vtiger_imageurl('showPanelTopRight.gif', $theme)."'></td>
  652. </tr>
  653. </table>
  654. ";
  655. echo $list_view;
  656. }
  657. /**
  658. * Function creates HTML to display Calendar DayView
  659. * @param array $cal - collections of objects and strings.
  660. * return string $dayview_layout - html tags in string format
  661. */
  662. function getDayViewLayout(& $cal)
  663. {
  664. global $current_user,$app_strings,$cal_log,$adb;
  665. $no_of_rows = 1;
  666. $cal_log->debug("Entering getDayViewLayout() method...");
  667. $date_format = $current_user->date_format;
  668. $day_start_hour = $cal['calendar']->day_start_hour;
  669. $day_end_hour = $cal['calendar']->day_end_hour;
  670. $format = $cal['calendar']->hour_format;
  671. $show_complete_view = false;
  672. if(!empty($_REQUEST['complete_view'])){
  673. $show_complete_view =true;
  674. }
  675. $dayview_layout = '';
  676. $dayview_layout .= '<!-- Day view layout starts here --> <table border="0" cellpadding="10" cellspacing="0" width="100%">';
  677. $dayview_layout .= '<tr>
  678. <td id="mainContent" style="border-top: 1px solid rgb(204, 204, 204);">
  679. <table border="0" cellpadding="5" cellspacing="0" width="100%">';
  680. if(!empty($show_complete_view)) {
  681. $dayview_layout .= '<tr><td width=12% class="lvtCol" bgcolor="blue" valign=top><img onClick="document.EventViewOption.complete_view.value=0;fnRedirect();" src="'.vtiger_imageurl('activate.gif', $theme).'" border="0"></td><td class="dvtCellInfo">&nbsp;</td><td class="dvtCellInfo">&nbsp;</td></tr>';
  682. $day_start_hour = 0;
  683. $day_end_hour = 23;
  684. } else {
  685. $dayview_layout .= '<tr><td width=12% class="lvtCol" bgcolor="blue" valign=top><img onClick="document.EventViewOption.complete_view.value=1;fnRedirect();" src="'.vtiger_imageurl('inactivate.gif', $theme).'" border="0"></td><td class="dvtCellInfo">&nbsp;</td><td class="dvtCellInfo">&nbsp;</td></tr>';
  686. }
  687. for($j=0;$j<24;$j++)
  688. {
  689. $slice = $cal['calendar']->slices[$j];
  690. $act = $cal['calendar']->day_slice[$slice]->activities;
  691. if(!empty($act))
  692. {
  693. $temprows = count($act);
  694. $no_of_rows = ($no_of_rows>$temprows)?$no_of_rows:$temprows;
  695. }
  696. }
  697. for($i=$day_start_hour;$i<=$day_end_hour;$i++)
  698. {
  699. $time = array('hour'=>$i,'minute'=>0);
  700. $sub_str = formatUserTimeString($time,$format);
  701. $y = $i+1;
  702. $hour_startat = formatUserTimeString(array('hour'=>$i,'minute'=>0),'24');
  703. $hour_endat = formatUserTimeString(array('hour'=>$y,'minute'=>0),'24');
  704. $time_arr = getaddEventPopupTime($hour_startat,$hour_endat,$format);
  705. $date = new DateTimeField(null);
  706. $endDate = new DateTimeField(date('Y-m-d', time() + (1*24*50*60)));
  707. $sttemp_date = $date->getDisplayDate();
  708. $endtemp_date = $endDate->getDisplayDate();
  709. $js_string = "";
  710. if(isPermitted("Calendar","EditView") == "yes")
  711. $js_string = 'onClick="fnvshobj(this,\'addEvent\'); gshow(\'addEvent\',\'Call\',\''.$sttemp_date.'\',\''.$endtemp_date.'\',\''.$time_arr['starthour'].'\',\''.$time_arr['startmin'].'\',\''.$time_arr['startfmt'].'\',\''.$time_arr['endhour'].'\',\''.$time_arr['endmin'].'\',\''.$time_arr['endfmt'].'\',\'hourview\',\'event\')"';
  712. $dayview_layout .= '<tr>
  713. <td style="cursor:pointer;" class="lvtCol" valign=top height="75" width="10%" '.$js_string.'>'.$sub_str.'</td>';
  714. //To display events in Dayview
  715. $dayview_layout .= getdayEventLayer($cal,$cal['calendar']->slices[$i],$no_of_rows);
  716. $dayview_layout .= '</tr>';
  717. }
  718. $dayview_layout .= '</table>
  719. </td></tr></table>';
  720. $cal_log->debug("Exiting getDayViewLayout() method...");
  721. return $dayview_layout;
  722. }
  723. /**
  724. * Function creates HTML to display Calendar WeekView
  725. * @param array $cal - collections of objects and strings.
  726. * return string $weekview_layout - html tags in string format
  727. */
  728. function getWeekViewLayout(& $cal)
  729. {
  730. global $current_user,$app_strings,$cal_log,$theme;
  731. $category = getParentTab();
  732. $cal_log->debug("Entering getWeekViewLayout() method...");
  733. $date_format = $current_user->date_format;
  734. $day_start_hour = $cal['calendar']->day_start_hour;
  735. $day_end_hour = $cal['calendar']->day_end_hour;
  736. $format = $cal['calendar']->hour_format;
  737. $show_complete_view = false;
  738. if(!empty($_REQUEST['complete_view'])){
  739. $show_complete_view =true;
  740. }
  741. $weekview_layout = '';
  742. $weekview_layout .= '<table border="0" cellpadding="10" cellspacing="0" width="98%" class="calDayHour" style="background-color: #dadada">';
  743. for ($col=0;$col<=7;$col++)
  744. {
  745. if($col==0) {
  746. $weekview_layout .= '<tr>';
  747. if(!empty($show_complete_view)) {
  748. $weekview_layout .= '<td width=12% class="lvtCol" bgcolor="blue" valign=top><img onClick="document.EventViewOption.complete_view.value=0;fnRedirect();" src="'.vtiger_imageurl('activate.gif', $theme).'" border="0"></td>';
  749. $day_start_hour = 0;
  750. $day_end_hour = 23;
  751. } else {
  752. $weekview_layout .= '<td width=12% class="lvtCol" bgcolor="blue" valign=top><img onClick="document.EventViewOption.complete_view.value=1;fnRedirect();" src="'.vtiger_imageurl('inactivate.gif', $theme).'" border="0"></td>';
  753. }
  754. } else {
  755. //To display Days in Week
  756. $cal['slice'] = $cal['calendar']->week_array[$cal['calendar']->slices[$col-1]];
  757. $date = $cal['calendar']->date_time->getThisweekDaysbyIndex($col);
  758. $day = $date->getdayofWeek_inshort();
  759. $weekview_layout .= '<td width=12% class="lvtCol" bgcolor="blue" valign=top>';
  760. $weekview_layout .= '<a href="index.php?module=Calendar&action=index&view='.$cal['slice']->getView().'&'.$cal['slice']->start_time->get_date_str().'&parenttab='.$category.'">';
  761. $weekview_layout .= $date->get_Date().' - '.$day;
  762. $weekview_layout .= "</a>";
  763. $weekview_layout .= '</td>';
  764. }
  765. }
  766. $weekview_layout .= '</tr></table>';
  767. $weekview_layout .= '<table border="0" cellpadding="10" cellspacing="1" width="98%" class="calDayHour" style="background-color: #dadada">';
  768. //To display Hours in User selected format
  769. for($i=$day_start_hour;$i<=$day_end_hour;$i++)
  770. {
  771. $count = $i;
  772. $hour_startat = formatUserTimeString(array('hour'=>$i,'minute'=>0),'24');
  773. $hour_endat = formatUserTimeString(array('hour'=>($i+1),'minute'=>0),'24');
  774. $time_arr = getaddEventPopupTime($hour_startat,$hour_endat,$format);
  775. $weekview_layout .= '<tr>';
  776. for ($column=1;$column<=1;$column++)
  777. {
  778. $time = array('hour'=>$i,'minute'=>0);
  779. $sub_str = formatUserTimeString($time,$format);
  780. $weekview_layout .= '<td style="border-top: 1px solid rgb(239, 239, 239); background-color: rgb(234, 234, 234); height: 40px;" valign="top" width="12%">';
  781. $weekview_layout .=$sub_str;
  782. $weekview_layout .= '</td>';
  783. }
  784. for ($column=0;$column<=6;$column++)
  785. {
  786. $temp_ts = $cal['calendar']->week_array[$cal['calendar']->slices[$column]]->start_time->ts;
  787. $date = new DateTimeField(date('Y-m-d', $temp_ts));
  788. $sttemp_date = $date->getDisplayDate();
  789. if($i != 23)
  790. $endtemp_date = $sttemp_date;
  791. else
  792. {
  793. $endtemp_ts = $cal['calendar']->week_array[$cal['calendar']->slices[$column+1]]->start_time->ts;
  794. $endDate = new DateTimeField(date('Y-m-d', $temp_ts));
  795. $endtemp_date = $endDate->getDisplayDate();
  796. }
  797. $weekview_layout .= '<td class="cellNormal" onMouseOver="cal_show(\'create_'.$sttemp_date.''.$time_arr['starthour'].''.$time_arr['startfmt'].'\')" onMouseOut="fnHide_Event(\'create_'.$sttemp_date.''.$time_arr['starthour'].''.$time_arr['startfmt'].'\')" style="height: 40px;" bgcolor="white" valign="top" width="12%" align=right vlign=top>';
  798. $weekview_layout .= '<div id="create_'.$sttemp_date.''.$time_arr['starthour'].''.$time_arr['startfmt'].'" style="visibility: hidden;">';
  799. if(isPermitted("Calendar","EditView") == "yes")
  800. $weekview_layout .='<img onClick="fnvshobj(this,\'addEvent\'); gshow(\'addEvent\',\'Call\',\''.$sttemp_date.'\',\''.$endtemp_date.'\',\''.$time_arr['starthour'].'\',\''.$time_arr['startmin'].'\',\''.$time_arr['startfmt'].'\',\''.$time_arr['endhour'].'\',\''.$time_arr['endmin'].'\',\''.$time_arr['endfmt'].'\',\'hourview\',\'event\')" src="'.vtiger_imageurl('cal_add.gif', $theme).'" border="0">';
  801. $weekview_layout .='</div>';
  802. //To display events in WeekView
  803. $weekview_layout .=getweekEventLayer($cal,$cal['calendar']->week_hour_slices[$count]);
  804. $weekview_layout .= '</td>';
  805. $count = $count+24;
  806. }
  807. $weekview_layout .= '</tr>';
  808. }
  809. $weekview_layout .= '</table>';
  810. return $weekview_layout;
  811. $cal_log->debug("Exiting getWeekViewLayout() method...");
  812. }
  813. /**
  814. * Function creates HTML to display Calendar MonthView
  815. * @param array $cal - collections of objects and strings.
  816. * return string $monthview_layout - html tags in string format
  817. */
  818. function getMonthViewLayout(& $cal)
  819. {
  820. global $current_user,$app_strings,$cal_log,$theme;
  821. $category = getParentTab();
  822. $cal_log->debug("Entering getMonthViewLayout() method...");
  823. $date_format = $current_user->date_format;
  824. $count = 0;
  825. //To get no. of rows(weeks) in month
  826. if ($cal['calendar']->month_array[$cal['calendar']->slices[35]]->start_time->month != $cal['calendar']->date_time->month) {
  827. $rows = 5;
  828. } else {
  829. $rows = 6;
  830. }
  831. $format = $cal['calendar']->hour_format;
  832. $hour_startat = formatUserTimeString(array('hour'=>date('H:i'),'minute'=>0),'24');
  833. $hour_endat = formatUserTimeString(array('hour'=>date('H:i',(time() + (60 * 60))),'minute'=>0),'24');
  834. $time_arr = getaddEventPopupTime($hour_startat,$hour_endat,$format);
  835. $monthview_layout = '';
  836. $monthview_layout .= '<table class="calDayHour" style="background-color: rgb(218, 218, 218);" border="0" cellpadding="5" cellspacing="1" width="98%"><tr>';
  837. //To display days in week
  838. for ($i = 0; $i < 7; $i ++)
  839. {
  840. $first_row = $cal['calendar']->month_array[$cal['calendar']->slices[$i]];
  841. $weekday = $first_row->start_time->getdayofWeek();
  842. $monthview_layout .= '<td class="lvtCol" valign="top" width="14%">'.$weekday.'</td>';
  843. }
  844. $monthview_layout .= '</tr></table>';
  845. $monthview_layout .= '<!-- month headers --> <table border=0 cellspacing=1 cellpadding=5 width=98% class="calDayHour" >';
  846. $cnt = 0;
  847. for ($i = 0; $i < $rows; $i ++)
  848. {
  849. $monthview_layout .= '<tr>';
  850. for ($j = 0; $j < 7; $j ++)
  851. {
  852. $temp_ts = $cal['calendar']->month_array[$cal['calendar']->slices[$count]]->start_time->ts;
  853. $temp_date = (($date_format == 'dd-mm-yyyy')?(date('d-m-Y',$temp_ts)):(($date_format== 'mm-dd-yyyy')?(date('m-d-Y',$temp_ts)):(($date_format == 'yyyy-mm-dd')?(date('Y-m-d', $temp_ts)):(''))));
  854. if($cal['calendar']->day_start_hour != 23)
  855. $endtemp_date = $temp_date;
  856. else
  857. {
  858. $endtemp_ts = $cal['calendar']->month_array[$cal['calendar']->slices[$count+1]]->start_time->ts;
  859. $endtemp_date = (($date_format == 'dd-mm-yyyy')?(date('d-m-Y',$endtemp_ts)):(($date_format== 'mm-dd-yyyy')?(date('m-d-Y',$endtemp_ts)):(($date_format == 'yyyy-mm-dd')?(date('Y-m-d', $endtemp_ts)):(''))));
  860. }
  861. $cal['slice'] = $cal['calendar']->month_array[$cal['calendar']->slices[$count]];
  862. $monthclass = dateCheck($cal['slice']->start_time->get_formatted_date());
  863. if($monthclass != '')
  864. $monthclass = 'calSel';
  865. else
  866. $monthclass = 'dvtCellLabel';
  867. //to display dates in month
  868. if ($cal['slice']->start_time->getMonth() == $cal['calendar']->date_time->getMonth())
  869. {
  870. $monthview_layout .= '<td style="text-align:left;" class="'.$monthclass.'" width="14%" onMouseOver="cal_show(\'create_'.$temp_date.''.$time_arr['starthour'].'\')" onMouseOut="fnHide_Event(\'create_'.$temp_date.''.$time_arr['starthour'].'\')">';
  871. $monthview_layout .= '<a href="index.php?module=Calendar&action=index&view='.$cal['slice']->getView().''.$cal['slice']->start_time->get_date_str().'&parenttab='.$category.'">';
  872. $monthview_layout .= $cal['slice']->start_time->get_Date();
  873. $monthview_layout .= '</a>';
  874. $monthview_layout .= '<div id="create_'.$temp_date.''.$time_arr['starthour'].'" style="visibility:hidden;">';
  875. if(isPermitted("Calendar","EditView") == "yes")
  876. $monthview_layout .='<a onClick="fnvshobj(this,\'addEvent\'); gshow(\'addEvent\',\'Call\',\''.$temp_date.'\',\''.$endtemp_date.'\',\''.$time_arr['starthour'].'\',\''.$time_arr['startmin'].'\',\''.$time_arr['startfmt'].'\',\''.$time_arr['endhour'].'\',\''.$time_arr['endmin'].'\',\''.$time_arr['endfmt'].'\',\'hourview\',\'event\')" href="javascript:void(0)"><img src="' . vtiger_imageurl('cal_add.gif', $theme). '" border="0"></a>';
  877. $monthview_layout .= ' </div></td>';
  878. }
  879. else
  880. {
  881. $monthview_layout .= '<td class="dvtCellLabel" width="14%">&nbsp;</td>';
  882. }
  883. $count++;
  884. }
  885. $monthview_layout .= '</tr>';
  886. $monthview_layout .= '<tr>';
  887. for ($j = 0; $j < 7; $j ++)
  888. {
  889. $monthview_layout .= '<td bgcolor="white" height="90" valign="top" width="200" align=right>';
  890. $monthview_layout .= getmonthEventLayer($cal,$cal['calendar']->slices[$cnt]);
  891. $monthview_layout .= '</td>';
  892. $cnt++;
  893. }
  894. $monthview_layout .= '</tr>';
  895. }
  896. $monthview_layout .= '</table>';
  897. return $monthview_layout;
  898. $cal_log->debug("Exiting getMonthViewLayout() method...");
  899. }
  900. /**
  901. * Function creates HTML to display Calendar YearView
  902. * @param array $cal - collections of objects and strings.
  903. * return string $yearview_layout - html tags in string format
  904. */
  905. function getYearViewLayout(& $cal)
  906. {
  907. global $mod_strings,$cal_log;
  908. $category = getParentTab();
  909. $cal_log->debug("Entering getYearViewLayout() method...");
  910. $yearview_layout = '';
  911. $yearview_layout .= '<table border="0" cellpadding="5" cellspacing="0" width="100%">';
  912. $count = 0;
  913. //year view divided as 4 rows and 3 columns
  914. for($i=0;$i<4;$i++)
  915. {
  916. $yearview_layout .= '<tr>';
  917. for($j=0;$j<3;$j++)
  918. {
  919. $cal['slice'] = $cal['calendar']->year_array[$cal['calendar']->slices[$count]];
  920. $yearview_layout .= '<td width="33%">
  921. <table class="mailClient " border="0" cellpadding="2" cellspacing="0" width="98%">
  922. <tr>
  923. <td colspan="7" class="calHdr" style="padding:5px">
  924. <a style="text-decoration: none;" href="index.php?module=Calendar&action=index&view=month&hour=0&day=1&month='.($count+1).'&year='.$cal['calendar']->date_time->year.'&parenttab='.$category.'"><b>
  925. '.$cal['slice']->start_time->month_inlong.'
  926. </b></a>
  927. </td>
  928. </tr><tr class="hdrNameBg">';
  929. for($w=0;$w<7;$w++)
  930. {
  931. $yearview_layout .= '<th width="14%">'.$mod_strings['cal_weekdays_short'][$w].'</th>';
  932. }
  933. $yearview_layout .= '</tr>';
  934. $date = DateTimeField::convertToDBFormat($cal['calendar']->month_day_slices
  935. [$count][35]);
  936. list($_3rdyear,$_3rdmonth,$_3rddate) = explode("-",$date);
  937. $date = DateTimeField::convertToDBFormat($cal['calendar']->month_day_slices
  938. [$count][6]);
  939. list($_2ndyear,$_2ndmonth,$_2nddate) = explode("-",$date);
  940. //to get no. of rows(weeks) in month
  941. if ($_3rdmonth != $_2ndmonth) {
  942. $rows = 5;
  943. } else {
  944. $rows = 6;
  945. }
  946. $cnt = 0;
  947. $date_stack = Array();
  948. for ($k = 0; $k < 5; $k ++)
  949. {
  950. $yearview_layout .= '<tr>';
  951. for ($mr = 0; $mr < 7; $mr ++)
  952. {
  953. $date = DateTimeField::convertToDBFormat($cal['calendar']->month_day_slices
  954. [$count][$cnt]);
  955. list($_1styear,$_1stmonth,$_1stdate) = explode("-", $date);
  956. if(count($cal['slice']->activities) != 0)
  957. {
  958. for($act_count = 0;$act_count<count($cal['slice']->activities);$act_count++)
  959. {
  960. array_push($date_stack,$cal['slice']->activities[$act_count]->
  961. start_time->get_formatted_date());
  962. }
  963. }
  964. if(in_array($cal['calendar']->month_day_slices[$count][$cnt],$date_stack))
  965. $event_class = 'class="eventDay"';
  966. else
  967. $event_class = '';
  968. if($_1stmonth == $_2ndmonth)
  969. $curclass = dateCheck($cal['calendar']->month_day_slices[$count][$cnt]);
  970. if($curclass != '')
  971. {
  972. $class = 'class="'.$curclass.'"';
  973. $curclass = '';
  974. }
  975. else
  976. {
  977. $class = $event_class;
  978. $event_class = '';
  979. }
  980. $date = $_1stdate + 0;
  981. $month = $_1stmonth + 0;
  982. $yearview_layout .= '<td '.$class.' style="text-align:center">';
  983. if($rows == 6 && $k==0)
  984. {
  985. $tdate = DateTimeField::convertToDBFormat($cal['calendar']->
  986. month_day_slices[$count][35+$mr]);
  987. list($tempyear,$tempmonth,$tempdate) = explode("-", $tdate);
  988. if($tempmonth == $_2ndmonth)
  989. $yearview_layout .= '<a href="index.php?module=Calendar&action=index&view=day&hour=0&day='.$tempdate.'&month='.$tempmonth.'&year='.$tempyear.'&parenttab='.$category.'">'.$tempdate;
  990. }
  991. if($_1stmonth == $_2ndmonth)
  992. {
  993. $yearview_layout .= '<a href="index.php?module=Calendar&action=index&view=day&hour=0&day='.$date.'&month='.$month.'&year='.$_1styear.'&parenttab='.$category.'">'.$date;
  994. }
  995. $yearview_layout .= '</a></td>';
  996. $cnt++;
  997. }
  998. $yearview_layout .= '</tr>';
  999. }
  1000. $yearview_layout .= '
  1001. </table>
  1002. ';
  1003. $count++;
  1004. }
  1005. $yearview_layout .= '</tr>';
  1006. }
  1007. $yearview_layout .= '</table>';
  1008. return $yearview_layout;
  1009. $cal_log->debug("Exiting getYearViewLayout() method...");
  1010. }
  1011. /**
  1012. * Function creates HTML To display events in day view
  1013. * @param array $cal - collection of objects and strings
  1014. * @param string $slice - date:time(eg: 2006-07-13:10)
  1015. * returns string $eventlayer - hmtl in string format
  1016. */
  1017. function getdayEventLayer(& $cal,$slice,$rows)
  1018. {
  1019. global $mod_strings,$cal_log,$listview_max_textlength,$adb,$current_user,$theme;
  1020. $category = getParentTab();
  1021. $cal_log->debug("Entering getdayEventLayer() method...");
  1022. $eventlayer = '';
  1023. $arrow_img_name = '';
  1024. $rows = $rows + 1;
  1025. $last_colwidth = 100 / $rows;
  1026. $width = 100 / $rows ;
  1027. $act = $cal['calendar']->day_slice[$slice]->activities;
  1028. if(!empty($act))
  1029. {
  1030. for($i=0;$i<count($act);$i++)
  1031. {
  1032. $rowspan = 1;
  1033. $arrow_img_name = 'event'.$cal['calendar']->day_slice[$slice]->start_time->hour.'_'.$i;
  1034. $subject = $act[$i]->subject;
  1035. $id = $act[$i]->record;
  1036. if($listview_max_textlength && (strlen($subject)>$listview_max_textlength))
  1037. $subject = substr($subject,0,$listview_max_textlength)."...";
  1038. $format = $cal['calendar']->hour_format;
  1039. $duration_hour = $act[$i]->duration_hour;
  1040. $duration_min =$act[$i]->duration_minute;
  1041. $user = $act[$i]->owner;
  1042. $priority = $act[$i]->priority;
  1043. if($duration_min != '00')
  1044. $rowspan = $duration_hour+$rowspan;
  1045. elseif($duration_hour != '0')
  1046. {
  1047. $rowspan = $duration_hour;
  1048. }
  1049. $row_cnt = $rowspan;
  1050. $start_hour = timeString($act[$i]->start_time,$format);
  1051. $end_hour = timeString($act[$i]->end_time,$format);
  1052. $account_name = $act[$i]->accountname;
  1053. $eventstatus = $act[$i]->eventstatus;
  1054. $color = $act[$i]->color;
  1055. $image = vtiger_imageurl($act[$i]->image_name, $theme);
  1056. if($act[$i]->recurring)
  1057. $recurring = '<img src="'.vtiger_imageurl($act[$i]->recurring, $theme).'" align="middle" border="0"></img>';
  1058. else
  1059. $recurring = '&nbsp;';
  1060. $height = $rowspan * 75;
  1061. $javacript_str = '';
  1062. $idShared = "normal"; if($act[$i]->shared) $idShared = "shared";
  1063. /*if($eventstatus != 'Held')
  1064. {*/
  1065. if($idShared == "normal")
  1066. {
  1067. if(isPermitted("Calendar","EditView") == "yes" || isPermitted("Calendar","Delete") == "yes")
  1068. $javacript_str = 'onMouseOver="cal_show(\''.$arrow_img_name.'\');" onMouseOut="fnHide_Event(\''.$arrow_img_name.'\');"';
  1069. $action_str = '<img src="' . vtiger_imageurl('cal_event.jpg', $theme). '" id="'.$arrow_img_name.'" style="visibility: hidden;" onClick="getcalAction(this,\'eventcalAction\','.$id.',\''.$cal['view'].'\',\''.$cal['calendar']->date_time->hour.'\',\''.$cal['calendar']->date_time->get_DB_formatted_date().'\',\'event\');" align="middle" border="0">';
  1070. }
  1071. else
  1072. {
  1073. $javacript_str = '';
  1074. $eventlayer .= '&nbsp;';
  1075. }
  1076. $eventlayer .= '<td class="dvtCellInfo" rowspan="'.$rowspan.'" colspan="1" width="'.$width.'%" >';
  1077. $visibility_query=$adb->pquery('SELECT visibility from vtiger_activity where activityid=?',array($id));
  1078. $visibility = $adb->query_result($visibility_query,0,'visibility');
  1079. $user_query = $adb->pquery("SELECT vtiger_crmentity.smownerid,vtiger_users.user_name from vtiger_crmentity,vtiger_users where crmid=? and vtiger_crm…

Large files files are truncated, but you can click here to view the full file