first commit
This commit is contained in:
122
modules/Events/actions/Save.php
Normal file
122
modules/Events/actions/Save.php
Normal file
@@ -0,0 +1,122 @@
|
||||
<?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_Save_Action extends Calendar_Save_Action {
|
||||
|
||||
/**
|
||||
* Function to save record
|
||||
* @param <Vtiger_Request> $request - values of the record
|
||||
* @return <RecordModel> - record Model of saved record
|
||||
*/
|
||||
public function saveRecord($request) {
|
||||
$adb = PearDatabase::getInstance();
|
||||
$recordModel = $this->getRecordModelFromRequest($request);
|
||||
$recurObjDb = false;
|
||||
if($recordModel->get('mode') == 'edit') {
|
||||
$recurObjDb = $recordModel->getRecurringObject();
|
||||
}
|
||||
$recordModel->save();
|
||||
$originalRecordId = $recordModel->getId();
|
||||
if($request->get('relationOperation')) {
|
||||
$parentModuleName = $request->get('sourceModule');
|
||||
$parentModuleModel = Vtiger_Module_Model::getInstance($parentModuleName);
|
||||
$parentRecordId = $request->get('sourceRecord');
|
||||
$relatedModule = $recordModel->getModule();
|
||||
if($relatedModule->getName() == 'Events'){
|
||||
$relatedModule = Vtiger_Module_Model::getInstance('Calendar');
|
||||
}
|
||||
$relatedRecordId = $recordModel->getId();
|
||||
|
||||
$relationModel = Vtiger_Relation_Model::getInstance($parentModuleModel, $relatedModule);
|
||||
$relationModel->addRelation($parentRecordId, $relatedRecordId);
|
||||
}
|
||||
|
||||
// Handled to save follow up event
|
||||
$followupMode = $request->get('followup');
|
||||
|
||||
//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($followupMode == 'on' && $startTime != '' && $startDate != ''){
|
||||
$record = $this->getRecordModelFromRequest($request);
|
||||
$record->set('eventstatus', 'Planned');
|
||||
//recurring events status should not be held for future events
|
||||
$recordModel->set('eventstatus', 'Planned');
|
||||
$record->set('subject','[Followup] '.$subject);
|
||||
$record->set('date_start',$startDate);
|
||||
$record->set('time_start',$startTime);
|
||||
|
||||
$currentUser = Users_Record_Model::getCurrentUserModel();
|
||||
$activityType = $record->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($startDate, $startTime) = explode(' ', $dueDateTime);
|
||||
|
||||
$record->set('due_date',$startDate);
|
||||
$record->set('time_end',$startTime);
|
||||
$record->set('recurringtype', '');
|
||||
$record->set('mode', 'create');
|
||||
$record->save();
|
||||
$heldevent = true;
|
||||
}
|
||||
$recurringEditMode = $request->get('recurringEditMode');
|
||||
$recordModel->set('recurringEditMode', $recurringEditMode);
|
||||
|
||||
vimport('~~/modules/Calendar/RepeatEvents.php');
|
||||
$recurObj = getrecurringObjValue();
|
||||
$recurringDataChanged = Calendar_RepeatEvents::checkRecurringDataChanged($recurObj, $recurObjDb);
|
||||
//TODO: remove the dependency on $_REQUEST
|
||||
if(($_REQUEST['recurringtype'] != '' && $_REQUEST['recurringtype'] != '--None--' && $recurringEditMode != 'current') || ($recurringDataChanged && empty($recurObj))) {
|
||||
$focus = CRMEntity::getInstance('Events');
|
||||
//get all the stored data to this object
|
||||
$focus->column_fields = new TrackableObject($recordModel->getData());
|
||||
try {
|
||||
Calendar_RepeatEvents::repeatFromRequest($focus, $recurObjDb);
|
||||
} catch (DuplicateException $e) {
|
||||
$requestData = $request->getAll();
|
||||
$requestData['view'] = 'Edit';
|
||||
$requestData['mode'] = 'Events';
|
||||
$requestData['module'] = 'Events';
|
||||
$requestData['duplicateRecords'] = $e->getDuplicateRecordIds();
|
||||
|
||||
global $vtiger_current_version;
|
||||
$viewer = new Vtiger_Viewer();
|
||||
$viewer->assign('REQUEST_DATA', $requestData);
|
||||
$viewer->assign('REQUEST_URL', 'index.php?module=Calendar&view=Edit&mode=Events&record='.$request->get('record'));
|
||||
$viewer->view('RedirectToEditView.tpl', 'Vtiger');
|
||||
exit();
|
||||
} catch (Exception $ex) {
|
||||
throw new Exception($ex->getMessage());
|
||||
}
|
||||
}
|
||||
return $recordModel;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 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
|
||||
*/
|
||||
protected function getRecordModelFromRequest(Vtiger_Request $request) {
|
||||
$recordModel = parent::getRecordModelFromRequest($request);
|
||||
if($request->has('selectedusers')) {
|
||||
$recordModel->set('selectedusers', $request->get('selectedusers'));
|
||||
}
|
||||
return $recordModel;
|
||||
}
|
||||
}
|
||||
238
modules/Events/actions/SaveAjax.php
Normal file
238
modules/Events/actions/SaveAjax.php
Normal file
@@ -0,0 +1,238 @@
|
||||
<?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 checkPermission(Vtiger_Request $request) {
|
||||
$moduleName = $request->getModule();
|
||||
$record = $request->get('record');
|
||||
|
||||
$actionName = ($record) ? 'EditView' : 'CreateView';
|
||||
if(!Users_Privileges_Model::isPermitted($moduleName, $actionName, $record)) {
|
||||
throw new AppException(vtranslate('LBL_PERMISSION_DENIED'));
|
||||
}
|
||||
|
||||
if(!Users_Privileges_Model::isPermitted($moduleName, 'Save', $record)) {
|
||||
throw new AppException(vtranslate('LBL_PERMISSION_DENIED'));
|
||||
}
|
||||
|
||||
if ($record) {
|
||||
$activityModulesList = array('Calendar', 'Events');
|
||||
$recordEntityName = getSalesEntityType($record);
|
||||
|
||||
if (!in_array($recordEntityName, $activityModulesList) || !in_array($moduleName, $activityModulesList)) {
|
||||
throw new AppException(vtranslate('LBL_PERMISSION_DENIED'));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
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));
|
||||
$recordModel = $this->saveRecord($request);
|
||||
vglobal('VTIGER_TIMESTAMP_NO_CHANGE_MODE', false);
|
||||
|
||||
$fieldModelList = $recordModel->getModule()->getFields();
|
||||
$result = array();
|
||||
foreach ($fieldModelList as $fieldName => $fieldModel) {
|
||||
$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;
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user