]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - modules/Calls/CallFormBase.php
Release 6.5.10
[Github/sugarcrm.git] / modules / Calls / CallFormBase.php
1 <?php
2 if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
3 /*********************************************************************************
4  * SugarCRM Community Edition is a customer relationship management program developed by
5  * SugarCRM, Inc. Copyright (C) 2004-2013 SugarCRM Inc.
6  * 
7  * This program is free software; you can redistribute it and/or modify it under
8  * the terms of the GNU Affero General Public License version 3 as published by the
9  * Free Software Foundation with the addition of the following permission added
10  * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
11  * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
12  * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
13  * 
14  * This program is distributed in the hope that it will be useful, but WITHOUT
15  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
16  * FOR A PARTICULAR PURPOSE.  See the GNU Affero General Public License for more
17  * details.
18  * 
19  * You should have received a copy of the GNU Affero General Public License along with
20  * this program; if not, see http://www.gnu.org/licenses or write to the Free
21  * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
22  * 02110-1301 USA.
23  * 
24  * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
25  * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
26  * 
27  * The interactive user interfaces in modified source and object code versions
28  * of this program must display Appropriate Legal Notices, as required under
29  * Section 5 of the GNU Affero General Public License version 3.
30  * 
31  * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
32  * these Appropriate Legal Notices must retain the display of the "Powered by
33  * SugarCRM" logo. If the display of the logo is not reasonably feasible for
34  * technical reasons, the Appropriate Legal Notices must display the words
35  * "Powered by SugarCRM".
36  ********************************************************************************/
37
38 /*********************************************************************************
39
40  * Description: Call Form Base
41  * Portions created by SugarCRM are Copyright (C) SugarCRM, Inc.
42  * All Rights Reserved.
43  * Contributor(s): ______________________________________..
44  ********************************************************************************/
45
46 require_once('include/SugarObjects/forms/FormBase.php');
47
48 class CallFormBase extends FormBase {
49
50 function getFormBody($prefix, $mod='', $formname='',$cal_date='',$cal_time=''){
51 if(!ACLController::checkAccess('Calls', 'edit', true)){
52                 return '';
53         }
54 global $mod_strings;
55 $temp_strings = $mod_strings;
56 if(!empty($mod)){
57         global $current_language;
58         $mod_strings = return_module_language($current_language, $mod);
59 }
60 global $app_strings;
61 global $app_list_strings;
62 global $current_user;
63 global $theme;
64
65
66 $lbl_subject = $mod_strings['LBL_SUBJECT'];
67 // Unimplemented until jscalendar language files are fixed
68 // global $current_language;
69 // global $default_language;
70 // global $cal_codes;
71 // Unimplemented until jscalendar language files are fixed
72 // $cal_lang = (empty($cal_codes[$current_language])) ? $cal_codes[$default_language] : $cal_codes[$current_language];
73
74 global $timedate;
75 $cal_lang = "en";
76 $cal_dateformat = $timedate->get_cal_date_format();
77
78 $lbl_required_symbol = $app_strings['LBL_REQUIRED_SYMBOL'];
79 $lbl_date = $mod_strings['LBL_DATE'];
80 $lbl_time = $mod_strings['LBL_TIME'];
81 $ntc_date_format = $timedate->get_user_date_format();
82 $ntc_time_format = '('.$timedate->get_user_time_format().')';
83
84         $user_id = $current_user->id;
85 $default_status = $app_list_strings['call_status_default'];
86 $default_parent_type= $app_list_strings['record_type_default_key'];
87 $date = TimeDate::getInstance()->nowDb();
88 $default_date_start = $timedate->to_display_date($date,false);
89 $default_time_start = $timedate->to_display_time($date);
90 $time_ampm = $timedate->AMPMMenu($prefix,$default_time_start);
91 $lbl_save_button_title = $app_strings['LBL_SAVE_BUTTON_TITLE'];
92 $lbl_save_button_key = $app_strings['LBL_SAVE_BUTTON_KEY'];
93 $lbl_save_button_label = $app_strings['LBL_SAVE_BUTTON_LABEL'];
94         $form = <<<EOQ
95                         <form name="${formname}" onSubmit="return check_form('${formname}') "method="POST" action="index.php">
96                         <input type="hidden" name="${prefix}module" value="Calls">
97                         <input type="hidden" name="${prefix}action" value="Save">
98                                 <input type="hidden" name="${prefix}record" value="">
99                         <input type="hidden"  name="${prefix}direction" value="Outbound">
100                         <input type="hidden" name="${prefix}status" value="${default_status}">
101                         <input type="hidden" name="${prefix}parent_type" value="${default_parent_type}">
102                         <input type="hidden" name="${prefix}assigned_user_id" value='${user_id}'>
103                         <input type="hidden" name="${prefix}duration_hours" value="1">
104                         <input type="hidden" name="${prefix}duration_minutes" value="0">
105                         <input type="hidden" name="${prefix}user_id" value="${user_id}">
106
107                 <table cellspacing="1" cellpadding="0" border="0">
108 <tr>
109     <td colspan="2"><input type='radio' name='appointment' value='Call' class='radio' onchange='document.${formname}.module.value="Calls";' style='vertical-align: middle;' checked> <span scope="row">${mod_strings['LNK_NEW_CALL']}</span>
110 &nbsp;
111 &nbsp;
112 <input type='radio' name='appointment' value='Meeting' class='radio' onchange='document.${formname}.module.value="Meetings";'><span scope="row">${mod_strings['LNK_NEW_MEETING']}</span></td>
113 </tr>
114 <tr>
115     <td colspan="2"><span scope="row">$lbl_subject</span>&nbsp;<span class="required">$lbl_required_symbol</span></td>
116 </tr>
117 <tr><td valign=top><input name='${prefix}name' size='30' maxlength='255' type="text"></td>
118     <td><input name='${prefix}date_start' id='${formname}jscal_field' maxlength='10' type="hidden" value="${cal_date}"></td>
119     <td><input name='${prefix}time_start' type="hidden" maxlength='10' value="{$cal_time}"></td>
120
121                         <script type="text/javascript">
122 //              Calendar.setup ({
123 //                      inputField : "${formname}jscal_field", daFormat : "$cal_dateformat" ifFormat : "$cal_dateformat", showsTime : false, button : "${formname}jscal_trigger", singleClick : true, step : 1, weekNumbers:false
124 //              });
125                 </script>
126
127
128
129 EOQ;
130
131
132
133 $javascript = new javascript();
134 $javascript->setFormName($formname);
135 $javascript->setSugarBean(new Call());
136 $javascript->addRequiredFields($prefix);
137 $form .=$javascript->getScript();
138 $form .= "<td align=\"left\" valign=top><input title='$lbl_save_button_title' accessKey='$lbl_save_button_key' class='button' type='submit' name='button' value=' $lbl_save_button_label ' ></td></tr></table></form>";
139 $mod_strings = $temp_strings;
140 return $form;
141
142 }
143 function getFormHeader($prefix, $mod='', $title=''){
144         if(!ACLController::checkAccess('Calls', 'edit', true)){
145                 return '';
146         }
147         if(!empty($mod)){
148         global $current_language;
149         $mod_strings = return_module_language($current_language, $mod);
150 }else global $mod_strings;
151
152
153
154
155
156
157 if(!empty($title)){
158         $the_form = get_left_form_header($title);
159 }else{
160         $the_form = get_left_form_header($mod_strings['LBL_NEW_FORM_TITLE']);
161 }
162 $the_form .= <<<EOQ
163                 <form name="${prefix}CallSave" onSubmit="return check_form('${prefix}CallSave') "method="POST" action="index.php">
164                         <input type="hidden" name="${prefix}module" value="Calls">
165                         <input type="hidden" name="${prefix}action" value="Save">
166
167 EOQ;
168 return $the_form;
169 }
170 function getFormFooter($prefic, $mod=''){
171         if(!ACLController::checkAccess('Calls', 'edit', true)){
172                 return '';
173         }
174 global $app_strings;
175 global $app_list_strings;
176 $lbl_save_button_title = $app_strings['LBL_SAVE_BUTTON_TITLE'];
177 $lbl_save_button_label = $app_strings['LBL_SAVE_BUTTON_LABEL'];
178 $the_form = "   <p><input title='$lbl_save_button_title' class='button' type='submit' name='button' value=' $lbl_save_button_label ' ></p></form>";
179 $the_form .= get_left_form_footer();
180 $the_form .= get_validate_record_js();
181 return $the_form;
182 }
183
184 function getForm($prefix, $mod=''){
185         if(!ACLController::checkAccess('Calls', 'edit', true)){
186                 return '';
187         }
188 $the_form = $this->getFormHeader($prefix, $mod);
189 $the_form .= $this->getFormBody($prefix, $mod, "${prefix}CallSave");
190 $the_form .= $this->getFormFooter($prefix, $mod);
191
192 return $the_form;
193 }
194
195
196 function handleSave($prefix,$redirect=true,$useRequired=false) {
197
198
199         require_once('include/formbase.php');
200
201         global $current_user;
202         global $timedate;
203
204         //BUG 17418 MFH
205         if (isset($_POST[$prefix.'duration_hours'])){
206                 $_POST[$prefix.'duration_hours'] = trim($_POST[$prefix.'duration_hours']);
207         }
208
209         $focus = new Call();
210
211         if($useRequired && !checkRequired($prefix, array_keys($focus->required_fields))) {
212                 return null;
213         }
214     if ( !isset($_POST[$prefix.'reminder_checked']) or ($_POST[$prefix.'reminder_checked'] == 0)) {
215         $GLOBALS['log']->debug(__FILE__.'('.__LINE__.'): No reminder checked, resetting the reminder_time');
216         $_POST[$prefix.'reminder_time'] = -1;
217     }
218
219         if(!isset($_POST[$prefix.'reminder_time'])) {
220         $GLOBALS['log']->debug(__FILE__.'('.__LINE__.'): Getting the users default reminder time');
221                 $_POST[$prefix.'reminder_time'] = $current_user->getPreference('reminder_time');
222         }
223
224         if(!isset($_POST['email_reminder_checked']) || (isset($_POST['email_reminder_checked']) && $_POST['email_reminder_checked'] == '0')) {
225                 $_POST['email_reminder_time'] = -1;
226         }
227         if(!isset($_POST['email_reminder_time'])){
228                 $_POST['email_reminder_time'] = $current_user->getPreference('email_reminder_time');
229                 $_POST['email_reminder_checked'] = 1;
230         }
231
232         // don't allow to set recurring_source from a form
233         unset($_POST['recurring_source']);
234
235         $time_format = $timedate->get_user_time_format();
236     $time_separator = ":";
237     if(preg_match('/\d+([^\d])\d+([^\d]*)/s', $time_format, $match)) {
238        $time_separator = $match[1];
239     }
240
241         if(!empty($_POST[$prefix.'time_hour_start']) && empty($_POST[$prefix.'time_start'])) {
242                 $_POST[$prefix.'time_start'] = $_POST[$prefix.'time_hour_start']. $time_separator .$_POST[$prefix.'time_minute_start'];
243         }
244
245         if(isset($_POST[$prefix.'meridiem']) && !empty($_POST[$prefix.'meridiem'])) {
246                 $_POST[$prefix.'time_start'] = $timedate->merge_time_meridiem($_POST[$prefix.'time_start'],$timedate->get_time_format(), $_POST[$prefix.'meridiem']);
247         }
248
249         if(isset($_POST[$prefix.'time_start']) && strlen($_POST[$prefix.'date_start']) == 10) {
250            $_POST[$prefix.'date_start'] = $_POST[$prefix.'date_start'] . ' ' . $_POST[$prefix.'time_start'];
251         }
252
253         // retrieve happens here
254         $focus = populateFromPost($prefix, $focus);
255         if(!$focus->ACLAccess('Save')) {
256            ACLController::displayNoAccess(true);
257            sugar_cleanup(true);
258         }
259
260         $newBean = true;
261         if (!empty($focus->id)) {
262             $newBean = false;
263         }
264
265         //add assigned user and current user if this is the first time bean is saved
266         if(empty($focus->id) && !empty($_REQUEST['return_module']) && $_REQUEST['return_module'] =='Calls' && !empty($_REQUEST['return_action']) && $_REQUEST['return_action'] =='DetailView'){
267                 //if return action is set to detail view and return module to call, then this is from the long form, do not add the assigned user (only the current user)
268                 //The current user is already added to UI and we want to give the current user the option of opting out of meeting.
269                 if($current_user->id != $_POST['assigned_user_id']){
270                         $_POST['user_invitees'] .= ','.$_POST['assigned_user_id'].', ';
271                         $_POST['user_invitees'] = str_replace(',,', ',', $_POST['user_invitees']);
272                 }
273         }else {
274                 //this is not from long form so add assigned and current user automatically as there is no invitee list UI.
275                 //This call could be through an ajax call from subpanels or shortcut bar
276                 $_POST['user_invitees'] .= ','.$_POST['assigned_user_id'].', ';
277
278                 //add current user if the assigned to user is different than current user.
279                 if($current_user->id != $_POST['assigned_user_id'] && $_REQUEST['module'] != "Calendar"){
280                         $_POST['user_invitees'] .= ','.$current_user->id.', ';
281                 }
282
283                 //remove any double commas introduced during appending
284             $_POST['user_invitees'] = str_replace(',,', ',', $_POST['user_invitees']);
285         }
286
287     if( (isset($_POST['isSaveFromDetailView']) && $_POST['isSaveFromDetailView'] == 'true') ||
288         (isset($_POST['is_ajax_call']) && !empty($_POST['is_ajax_call']) && !empty($focus->id) ||
289         (isset($_POST['return_action']) && $_POST['return_action'] == 'SubPanelViewer') && !empty($focus->id))
290     ){
291         $focus->save(true);
292         $return_id = $focus->id;
293     }else{
294
295         if($focus->status == 'Held' && $this->isEmptyReturnModuleAndAction() && !$this->isSaveFromDCMenu()){
296                 //if we are closing the meeting, and the request does not have a return module AND return action set and it is not a save
297             //being triggered by the DCMenu (shortcut bar) then the request is coming from a dashlet or subpanel close icon and there is no
298             //need to process user invitees, just save the current values.
299                 $focus->save(true);
300             }else{
301                 ///////////////////////////////////////////////////////////////////////////
302                 ////    REMOVE INVITEE RELATIONSHIPS
303                 if(!empty($_POST['user_invitees'])) {
304                    $userInvitees = explode(',', trim($_POST['user_invitees'], ','));
305                 } else {
306                    $userInvitees = array();
307                 }
308
309                 // Calculate which users to flag as deleted and which to add
310                 $deleteUsers = array();
311                 $focus->load_relationship('users');
312                 // Get all users for the call
313                 $q = 'SELECT mu.user_id, mu.accept_status FROM calls_users mu WHERE mu.call_id = \''.$focus->id.'\'';
314                 $r = $focus->db->query($q);
315                 $acceptStatusUsers = array();
316                 while($a = $focus->db->fetchByAssoc($r)) {
317                           if(!in_array($a['user_id'], $userInvitees)) {
318                                  $deleteUsers[$a['user_id']] = $a['user_id'];
319                           } else {
320                              $acceptStatusUsers[$a['user_id']] = $a['accept_status'];
321                           }
322                 }
323
324                 if(count($deleteUsers) > 0) {
325                         $sql = '';
326                         foreach($deleteUsers as $u) {
327                         $sql .= ",'" . $u . "'";
328                         }
329
330                         $sql = substr($sql, 1);
331                         // We could run a delete SQL statement here, but will just mark as deleted instead
332                         $sql = "UPDATE calls_users set deleted = 1 where user_id in ($sql) AND call_id = '". $focus->id . "'";
333                         $focus->db->query($sql);
334                 }
335
336                 // Get all contacts for the call
337                 if(!empty($_POST['contact_invitees'])) {
338                    $contactInvitees = explode(',', trim($_POST['contact_invitees'], ','));
339                 } else {
340                    $contactInvitees = array();
341                 }
342
343                 $deleteContacts = array();
344                 $focus->load_relationship('contacts');
345                 $q = 'SELECT mu.contact_id, mu.accept_status FROM calls_contacts mu WHERE mu.call_id = \''.$focus->id.'\'';
346                 $r = $focus->db->query($q);
347                 $acceptStatusContacts = array();
348                 while($a = $focus->db->fetchByAssoc($r)) {
349                           if(!in_array($a['contact_id'], $contactInvitees)) {
350                                  $deleteContacts[$a['contact_id']] = $a['contact_id'];
351                           }     else {
352                                  $acceptStatusContacts[$a['contact_id']] = $a['accept_status'];
353                           }
354                 }
355
356                 if(count($deleteContacts) > 0) {
357                         $sql = '';
358                         foreach($deleteContacts as $u) {
359                                 $sql .= ",'" . $u . "'";
360                         }
361                         $sql = substr($sql, 1);
362                         // We could run a delete SQL statement here, but will just mark as deleted instead
363                         $sql = "UPDATE calls_contacts set deleted = 1 where contact_id in ($sql) AND call_id = '". $focus->id . "'";
364                         $focus->db->query($sql);
365                 }
366                 if(!empty($_POST['lead_invitees'])) {
367                    $leadInvitees = explode(',', trim($_POST['lead_invitees'], ','));
368                 } else {
369                    $leadInvitees = array();
370                 }
371
372                 // Calculate which leads to flag as deleted and which to add
373                 $deleteLeads = array();
374                 $focus->load_relationship('leads');
375                 // Get all leads for the call
376                 $q = 'SELECT mu.lead_id, mu.accept_status FROM calls_leads mu WHERE mu.call_id = \''.$focus->id.'\'';
377                 $r = $focus->db->query($q);
378                 $acceptStatusLeads = array();
379                 while($a = $focus->db->fetchByAssoc($r)) {
380                           if(!in_array($a['lead_id'], $leadInvitees)) {
381                                  $deleteLeads[$a['lead_id']] = $a['lead_id'];
382                           } else {
383                              $acceptStatusLeads[$a['user_id']] = $a['accept_status'];
384                           }
385                 }
386
387                 if(count($deleteLeads) > 0) {
388                         $sql = '';
389                         foreach($deleteLeads as $u) {
390                         // make sure we don't delete the assigned user
391                         if ( $u != $focus->assigned_user_id )
392                                 $sql .= ",'" . $u . "'";
393                         }
394                         $sql = substr($sql, 1);
395                         // We could run a delete SQL statement here, but will just mark as deleted instead
396                         $sql = "UPDATE calls_leads set deleted = 1 where lead_id in ($sql) AND call_id = '". $focus->id . "'";
397                         $focus->db->query($sql);
398                 }
399                 ////    END REMOVE
400                 ///////////////////////////////////////////////////////////////////////////
401
402
403                 ///////////////////////////////////////////////////////////////////////////
404                 ////    REBUILD INVITEE RELATIONSHIPS
405                 $focus->users_arr = array();
406                 $focus->users_arr = $userInvitees;
407                 $focus->contacts_arr = array();
408                 $focus->contacts_arr = $contactInvitees;
409                 $focus->leads_arr = array();
410                 $focus->leads_arr = $leadInvitees;
411                 if(!empty($_POST['parent_id']) && $_POST['parent_type'] == 'Contacts') {
412                         $focus->contacts_arr[] = $_POST['parent_id'];
413                 }
414                 if(!empty($_POST['parent_id']) && $_POST['parent_type'] == 'Leads') {
415                         $focus->leads_arr[] = $_POST['parent_id'];
416                 }
417                 // Call the Call module's save function to handle saving other fields besides
418                 // the users and contacts relationships
419             $focus->update_vcal = false;    // Bug #49195 : don't update vcal b/s related users aren't saved yet, create vcal cache below
420                 $focus->save(true);
421                 $return_id = $focus->id;
422
423                 // Process users
424                 $existing_users = array();
425                 if(!empty($_POST['existing_invitees'])) {
426                    $existing_users =  explode(",", trim($_POST['existing_invitees'], ','));
427                 }
428
429                 foreach($focus->users_arr as $user_id) {
430                     if(empty($user_id) || isset($existing_users[$user_id]) || isset($deleteUsers[$user_id])) {
431                                 continue;
432                         }
433
434                         if(!isset($acceptStatusUsers[$user_id])) {
435                                 $focus->load_relationship('users');
436                                 $focus->users->add($user_id);
437                         } else {
438                                 // update query to preserve accept_status
439                                 $qU  = 'UPDATE calls_users SET deleted = 0, accept_status = \''.$acceptStatusUsers[$user_id].'\' ';
440                                 $qU .= 'WHERE call_id = \''.$focus->id.'\' ';
441                                 $qU .= 'AND user_id = \''.$user_id.'\'';
442                                 $focus->db->query($qU);
443                         }
444                 }
445
446                 // Process contacts
447                 $existing_contacts =  array();
448                 if(!empty($_POST['existing_contact_invitees'])) {
449                    $existing_contacts =  explode(",", trim($_POST['existing_contact_invitees'], ','));
450                 }
451
452                 foreach($focus->contacts_arr as $contact_id) {
453                         if(empty($contact_id) || isset($existing_contacts[$contact_id]) || (isset($deleteContacts[$contact_id]) && $contact_id !=  $_POST['parent_id'])) {
454                                 continue;
455                         }
456
457                         if(!isset($acceptStatusContacts[$contact_id])) {
458                                 $focus->load_relationship('contacts');
459                             $focus->contacts->add($contact_id);
460                         } else {
461                                 // update query to preserve accept_status
462                                 $qU  = 'UPDATE calls_contacts SET deleted = 0, accept_status = \''.$acceptStatusContacts[$contact_id].'\' ';
463                                 $qU .= 'WHERE call_id = \''.$focus->id.'\' ';
464                                 $qU .= 'AND contact_id = \''.$contact_id.'\'';
465                                 $focus->db->query($qU);
466                         }
467                 }
468                 // Process leads
469                 $existing_leads =  array();
470                 if(!empty($_POST['existing_lead_invitees'])) {
471                    $existing_leads =  explode(",", trim($_POST['existing_lead_invitees'], ','));
472                 }
473
474                 foreach($focus->leads_arr as $lead_id) {
475                         if(empty($lead_id) || isset($existing_leads[$lead_id]) || (isset($deleteLeads[$lead_id]) && $lead_id !=  $_POST['parent_id'])) {
476                                 continue;
477                         }
478
479                         if(!isset($acceptStatusLeads[$lead_id])) {
480                                 $focus->load_relationship('leads');
481                             $focus->leads->add($lead_id);
482                         } else {
483                                 // update query to preserve accept_status
484                                 $qU  = 'UPDATE calls_leads SET deleted = 0, accept_status = \''.$acceptStatusLeads[$lead_id].'\' ';
485                                 $qU .= 'WHERE call_id = \''.$focus->id.'\' ';
486                                 $qU .= 'AND lead_id = \''.$lead_id.'\'';
487                                 $focus->db->query($qU);
488                         }
489                 }
490
491             // Bug #49195 : update vcal
492             vCal::cache_sugar_vcal($current_user);
493             
494                 // CCL - Comment out call to set $current_user as invitee
495                 //set organizer to auto-accept
496             if ($focus->assigned_user_id == $current_user->id && $newBean) {
497                 $focus->set_accept_status($current_user, 'accept');
498             }
499
500                 ////    END REBUILD INVITEE RELATIONSHIPS
501                 ///////////////////////////////////////////////////////////////////////////
502             }
503     }
504         if (isset($_REQUEST['return_module']) && $_REQUEST['return_module'] == 'Home'){
505                 $_REQUEST['return_action'] = 'index';
506         handleRedirect('', 'Home');
507         }
508         else if($redirect) {
509                 handleRedirect($return_id, 'Calls');
510         } else {
511                 return $focus;
512         }
513
514 } // end handleSave();
515
516 function getWideFormBody ($prefix, $mod='', $formname='', $wide =true){
517         if(!ACLController::checkAccess('Calls', 'edit', true)){
518                 return '';
519         }
520 global $mod_strings;
521 $temp_strings = $mod_strings;
522 if(!empty($mod)){
523         global $current_language;
524         $mod_strings = return_module_language($current_language, $mod);
525 }
526 global $app_strings;
527 global $app_list_strings;
528 global $current_user;
529 global $theme;
530
531 $lbl_subject = $mod_strings['LBL_SUBJECT'];
532 // Unimplemented until jscalendar language files are fixed
533 // global $current_language;
534 // global $default_language;
535 // global $cal_codes;
536 // Unimplemented until jscalendar language files are fixed
537 // $cal_lang = (empty($cal_codes[$current_language])) ? $cal_codes[$default_language] : $cal_codes[$current_language];
538 $cal_lang = "en";
539
540
541 $lbl_required_symbol = $app_strings['LBL_REQUIRED_SYMBOL'];
542         $lbl_date = $mod_strings['LBL_DATE'];
543 $lbl_time = $mod_strings['LBL_TIME'];
544 global $timedate;
545 $ntc_date_format = '('.$timedate->get_user_date_format(). ')';
546 $ntc_time_format = '('.$timedate->get_user_time_format(). ')';
547 $cal_dateformat = $timedate->get_cal_date_format();
548
549         $user_id = $current_user->id;
550 $default_status = $app_list_strings['call_status_default'];
551 $default_parent_type= $app_list_strings['record_type_default_key'];
552 $date = TimeDate::getInstance()->nowDb();
553 $default_date_start = $timedate->to_display_date($date);
554 $default_time_start = $timedate->to_display_time($date,true);
555 $time_ampm = $timedate->AMPMMenu($prefix,$default_time_start);
556         $form = <<<EOQ
557                         <input type="hidden"  name="${prefix}direction" value="Outbound">
558                         <input type="hidden" name="${prefix}record" value="">
559                         <input type="hidden" name="${prefix}status" value="${default_status}">
560                         <input type="hidden" name="${prefix}parent_type" value="${default_parent_type}">
561                         <input type="hidden" name="${prefix}assigned_user_id" value='${user_id}'>
562                         <input type="hidden" name="${prefix}duration_hours" value="1">
563                         <input type="hidden" name="${prefix}duration_minutes" value="0">
564                         <input type="hidden" name="${prefix}user_id" value="${user_id}">
565
566                 <table cellspacing='0' cellpadding='0' border='0' width="100%">
567 <tr>
568 EOQ;
569
570 if($wide){
571 $form .= <<<EOQ
572 <td scope='row' width="20%"><input type='radio' name='appointment' value='Call' class='radio' checked> ${mod_strings['LNK_NEW_CALL']}</td>
573 <td scope='row' width="80%">${mod_strings['LBL_DESCRIPTION']}</td>
574 </tr>
575
576 <tr>
577 <td scope='row'><input type='radio' name='appointment' value='Meeting' class='radio'> ${mod_strings['LNK_NEW_MEETING']}</td>
578
579 <td rowspan='8' ><textarea name='Appointmentsdescription' cols='50' rows='5'></textarea></td>
580 </tr>
581 EOQ;
582 }else{
583                 $form .= <<<EOQ
584 <td scope='row' width="20%"><input type='radio' name='appointment' value='Call' class='radio' onchange='document.$formname.module.value="Calls";' checked> ${mod_strings['LNK_NEW_CALL']}</td>
585 </tr>
586
587 <tr>
588 <td scope='row'><input type='radio' name='appointment' value='Meeting' class='radio' onchange='document.$formname.module.value="Meetings";'> ${mod_strings['LNK_NEW_MEETING']}</td>
589 </tr>
590 EOQ;
591 }
592 $jscalenderImage = SugarThemeRegistry::current()->getImageURL('jscalendar.gif');
593 $form .=        <<<EOQ
594
595
596 <tr>
597 <td scope='row'>$lbl_subject&nbsp;<span class="required">$lbl_required_symbol</span></td>
598 </tr>
599
600 <tr>
601 <td ><input name='${prefix}name' maxlength='255' type="text"></td>
602 </tr>
603
604 <tr>
605 <td scope='row'>$lbl_date&nbsp;<span class="required">$lbl_required_symbol</span>&nbsp;<span class="dateFormat">$ntc_date_format</span></td>
606 </tr>
607 <tr>
608 <td ><input onblur="parseDate(this, '$cal_dateformat');" name='${prefix}date_start' size="12" id='${prefix}jscal_field' maxlength='10' type="text" value="${default_date_start}"> <!--not_in_theme!--><img src="{$jscalenderImage}" alt="{$app_strings['LBL_ENTER_DATE']}"  id="${prefix}jscal_trigger" align="absmiddle"></td>
609 </tr>
610
611 <tr>
612 <td scope='row'>$lbl_time&nbsp;<span class="required">$lbl_required_symbol</span>&nbsp;<span class="dateFormat">$ntc_time_format</span></td>
613 </tr>
614 <tr>
615 <td ><input name='${prefix}time_start' size="12" type="text" maxlength='5' value="{$default_time_start}">$time_ampm</td>
616 </tr>
617
618 </table>
619
620                 <script type="text/javascript">
621                 Calendar.setup ({
622                         inputField : "${prefix}jscal_field", daFormat : "$cal_dateformat", ifFormat : "$cal_dateformat", showsTime : false, button : "${prefix}jscal_trigger", singleClick : true, step : 1, weekNumbers:false
623                 });
624                 </script>
625 EOQ;
626
627
628 $javascript = new javascript();
629 $javascript->setFormName($formname);
630 $javascript->setSugarBean(new Call());
631 $javascript->addRequiredFields($prefix);
632 $form .=$javascript->getScript();
633 $mod_strings = $temp_strings;
634 return $form;
635
636 }
637
638
639
640 }
641 ?>