226 lines
9.6 KiB
PHP
Executable File
226 lines
9.6 KiB
PHP
Executable File
<?php
|
|
/*+***********************************************************************************
|
|
* The contents of this file are subject to the vtiger CRM Public License Version 1.0
|
|
* ("License"); You may not use this file except in compliance with the License
|
|
* The Original Code is: vtiger CRM Open Source
|
|
* The Initial Developer of the Original Code is vtiger.
|
|
* Portions created by vtiger are Copyright (C) vtiger.
|
|
* All Rights Reserved.
|
|
*************************************************************************************/
|
|
|
|
class Events_SaveAjax_Action extends Events_Save_Action {
|
|
|
|
public function process(Vtiger_Request $request) {
|
|
$response = new Vtiger_Response();
|
|
try {
|
|
$user = Users_Record_Model::getCurrentUserModel();
|
|
|
|
vglobal('VTIGER_TIMESTAMP_NO_CHANGE_MODE', $request->get('_timeStampNoChangeMode', false));
|
|
// SalesPlatform.ru begin
|
|
// recurringtype is empty when save record in quickCreate
|
|
$recurringType = $request->get('recurringtype');
|
|
$recordId = $request->get('record');
|
|
if (empty($recurringType) && empty($recordId)) {
|
|
$request->set('recurringtype','--None--' );
|
|
}
|
|
// SalesPlatform.ru end
|
|
$recordModel = $this->saveRecord($request);
|
|
vglobal('VTIGER_TIMESTAMP_NO_CHANGE_MODE', false);
|
|
|
|
$fieldModelList = $recordModel->getModule()->getFields();
|
|
$result = array();
|
|
foreach ($fieldModelList as $fieldName => $fieldModel) {
|
|
if($fieldModel->isViewable()){
|
|
$recordFieldValue = $recordModel->get($fieldName);
|
|
if (is_array($recordFieldValue) && $fieldModel->getFieldDataType() == 'multipicklist') {
|
|
$recordFieldValue = implode(' |##| ', $recordFieldValue);
|
|
}
|
|
$fieldValue = $displayValue = Vtiger_Util_Helper::toSafeHTML($recordFieldValue);
|
|
if ($fieldModel->getFieldDataType() !== 'currency' && $fieldModel->getFieldDataType() !== 'datetime' && $fieldModel->getFieldDataType() !== 'date') {
|
|
$displayValue = $fieldModel->getDisplayValue($fieldValue, $recordModel->getId());
|
|
}
|
|
$result[$fieldName] = array();
|
|
if ($fieldName == 'date_start') {
|
|
$timeStart = $recordModel->get('time_start');
|
|
$dateTimeFieldInstance = new DateTimeField($fieldValue . ' ' . $timeStart);
|
|
|
|
$fieldValue = $fieldValue . ' ' . $timeStart;
|
|
|
|
$userDateTimeString = $dateTimeFieldInstance->getDisplayDateTimeValue();
|
|
$dateTimeComponents = explode(' ', $userDateTimeString);
|
|
$dateComponent = $dateTimeComponents[0];
|
|
//Conveting the date format in to Y-m-d . since full calendar expects in the same format
|
|
$dataBaseDateFormatedString = DateTimeField::__convertToDBFormat($dateComponent, $user->get('date_format'));
|
|
$result[$fieldName]['calendar_display_value'] = $dataBaseDateFormatedString . ' ' . $dateTimeComponents[1];
|
|
$displayValue = $fieldModel->getDisplayValue($fieldValue);
|
|
} else if ($fieldName == 'due_date') {
|
|
$timeEnd = $recordModel->get('time_end');
|
|
$dateTimeFieldInstance = new DateTimeField($fieldValue . ' ' . $timeEnd);
|
|
|
|
$fieldValue = $fieldValue . ' ' . $timeEnd;
|
|
|
|
$userDateTimeString = $dateTimeFieldInstance->getDisplayDateTimeValue();
|
|
$dateTimeComponents = explode(' ', $userDateTimeString);
|
|
$dateComponent = $dateTimeComponents[0];
|
|
//Conveting the date format in to Y-m-d . since full calendar expects in the same format
|
|
$dataBaseDateFormatedString = DateTimeField::__convertToDBFormat($dateComponent, $user->get('date_format'));
|
|
$result[$fieldName]['calendar_display_value'] = $dataBaseDateFormatedString . ' ' . $dateTimeComponents[1];
|
|
$displayValue = $fieldModel->getDisplayValue($fieldValue);
|
|
}
|
|
$result[$fieldName]['value'] = $fieldValue;
|
|
$result[$fieldName]['display_value'] = decode_html($displayValue);
|
|
}
|
|
}
|
|
|
|
$result['_recordLabel'] = $recordModel->getName();
|
|
$result['_recordId'] = $recordModel->getId();
|
|
$result['calendarModule'] = $request->get('calendarModule');
|
|
$result['sourceModule'] = $request->get('calendarModule');
|
|
|
|
// Handled to save follow up event
|
|
$followupMode = $request->get('followup');
|
|
|
|
if ($followupMode == 'on') {
|
|
//Start Date and Time values
|
|
$startTime = Vtiger_Time_UIType::getTimeValueWithSeconds($request->get('followup_time_start'));
|
|
$startDateTime = Vtiger_Datetime_UIType::getDBDateTimeValue($request->get('followup_date_start') . " " . $startTime);
|
|
list($startDate, $startTime) = explode(' ', $startDateTime);
|
|
|
|
$subject = $request->get('subject');
|
|
if ($startTime != '' && $startDate != '') {
|
|
$recordModel->set('eventstatus', 'Planned');
|
|
$recordModel->set('subject', '[Followup] ' . $subject);
|
|
$recordModel->set('date_start', $startDate);
|
|
$recordModel->set('time_start', $startTime);
|
|
|
|
$currentUser = Users_Record_Model::getCurrentUserModel();
|
|
$activityType = $recordModel->get('activitytype');
|
|
if ($activityType == 'Call') {
|
|
$minutes = $currentUser->get('callduration');
|
|
} else {
|
|
$minutes = $currentUser->get('othereventduration');
|
|
}
|
|
$dueDateTime = date('Y-m-d H:i:s', strtotime("$startDateTime+$minutes minutes"));
|
|
list($endDate, $endTime) = explode(' ', $dueDateTime);
|
|
|
|
$recordModel->set('due_date', $endDate);
|
|
$recordModel->set('time_end', $endTime);
|
|
$recordModel->set('mode', 'create');
|
|
$recordModel->save();
|
|
}
|
|
}
|
|
$response->setEmitType(Vtiger_Response::$EMIT_JSON);
|
|
$response->setResult($result);
|
|
} catch (DuplicateException $e) {
|
|
$response->setError($e->getMessage(), $e->getDuplicationMessage(), $e->getMessage());
|
|
} catch (Exception $e) {
|
|
$response->setError($e->getMessage());
|
|
}
|
|
$response->emit();
|
|
}
|
|
|
|
function setRecurrenceInfo($recordModel) {
|
|
//Activity.php insertIntoRecurringTable api depends on $_REQUEST mode edit
|
|
$_REQUEST['mode'] = 'edit';
|
|
$startDateTime = DateTimeField::convertToUserTimeZone($recordModel->get('date_start') . ' ' . $recordModel->get('time_start'));
|
|
$endDateTime = DateTimeField::convertToUserTimeZone($recordModel->get('due_date') . ' ' . $recordModel->get('time_end'));
|
|
$_REQUEST['date_start'] = $startDateTime->format('Y-m-d');
|
|
$_REQUEST['time_start'] = $startDateTime->format('H:i');
|
|
$_REQUEST['due_date'] = $endDateTime->format('Y-m-d');
|
|
$_REQUEST['time_end'] = $endDateTime->format('H:i');
|
|
|
|
$recurringInfo = $recordModel->getRecurrenceInformation();
|
|
$_REQUEST['recurringcheck'] = $recurringInfo['recurringcheck'];
|
|
$_REQUEST['repeat_frequency'] = $recurringInfo['repeat_frequency'];
|
|
$_REQUEST['recurringtype'] = $recurringInfo['eventrecurringtype'];
|
|
$_REQUEST['calendar_repeat_limit_date'] = $recurringInfo['recurringenddate'];
|
|
|
|
if ($recurringInfo['eventrecurringtype'] == 'Weekly') {
|
|
$_REQUEST['sun_flag'] = $recurringInfo['week0'];
|
|
$_REQUEST['mon_flag'] = $recurringInfo['week1'];
|
|
$_REQUEST['tue_flag'] = $recurringInfo['week2'];
|
|
$_REQUEST['wed_flag'] = $recurringInfo['week3'];
|
|
$_REQUEST['thu_flag'] = $recurringInfo['week4'];
|
|
$_REQUEST['fri_flag'] = $recurringInfo['week5'];
|
|
$_REQUEST['sat_flag'] = $recurringInfo['week6'];
|
|
}
|
|
|
|
if ($recurringInfo['eventrecurringtype'] == 'Monthly') {
|
|
if ($recurringInfo['repeatMonth'] == 'date') {
|
|
$_REQUEST['repeatMonth'] = $recurringInfo['repeatMonth'];
|
|
$_REQUEST['repeatMonth_date'] = $recurringInfo['repeatMonth_date'];
|
|
} else if ($recurringInfo['repeatMonth'] == 'day') {
|
|
$_REQUEST['repeatMonth_daytype'] = $recurringInfo['repeatMonth_daytype'];
|
|
$_REQUEST['repeatMonth_day'] = $recurringInfo['repeatMonth_day'];
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Function to get the record model based on the request parameters
|
|
* @param Vtiger_Request $request
|
|
* @return Vtiger_Record_Model or Module specific Record Model instance
|
|
*/
|
|
public function getRecordModelFromRequest(Vtiger_Request $request) {
|
|
$recordModel = parent::getRecordModelFromRequest($request);
|
|
|
|
if ($recordModel->get('mode') == 'edit') {
|
|
$this->setRecurrenceInfo($recordModel);
|
|
}
|
|
|
|
$startDate = $request->get('date_start');
|
|
if (!empty($startDate)) {
|
|
//Start Date and Time values
|
|
$startTime = Vtiger_Time_UIType::getTimeValueWithSeconds($request->get('time_start'));
|
|
$startDateTime = Vtiger_Datetime_UIType::getDBDateTimeValue($request->get('date_start') . " " . $startTime);
|
|
list($startDate, $startTime) = explode(' ', $startDateTime);
|
|
|
|
$recordModel->set('date_start', $startDate);
|
|
$recordModel->set('time_start', $startTime);
|
|
}
|
|
|
|
$endDate = $request->get('due_date');
|
|
if (!empty($endDate)) {
|
|
//End Date and Time values
|
|
$endTime = $request->get('time_end');
|
|
$endDate = Vtiger_Date_UIType::getDBInsertedValue($request->get('due_date'));
|
|
|
|
if ($endTime) {
|
|
$endTime = Vtiger_Time_UIType::getTimeValueWithSeconds($endTime);
|
|
$endDateTime = Vtiger_Datetime_UIType::getDBDateTimeValue($request->get('due_date') . " " . $endTime);
|
|
list($endDate, $endTime) = explode(' ', $endDateTime);
|
|
}
|
|
|
|
$recordModel->set('time_end', $endTime);
|
|
$recordModel->set('due_date', $endDate);
|
|
}
|
|
|
|
$activityType = $request->get('activitytype');
|
|
$visibility = $request->get('visibility');
|
|
if (empty($activityType)) {
|
|
$recordModel->set('activitytype', 'Task');
|
|
$visibility = 'Private';
|
|
$recordModel->set('visibility', $visibility);
|
|
}
|
|
|
|
if (empty($visibility)) {
|
|
$assignedUserId = $recordModel->get('assigned_user_id');
|
|
$sharedType = Calendar_Module_Model::getSharedType($assignedUserId);
|
|
if ($sharedType == 'selectedusers') {
|
|
$sharedType = 'public';
|
|
}
|
|
$recordModel->set('visibility', ucfirst($sharedType));
|
|
}
|
|
|
|
$setReminder = $request->get('set_reminder');
|
|
if ($setReminder) {
|
|
$_REQUEST['set_reminder'] = 'Yes';
|
|
} else {
|
|
$_REQUEST['set_reminder'] = 'No';
|
|
}
|
|
|
|
return $recordModel;
|
|
}
|
|
|
|
}
|