'crmid','vtiger_campaign'=>'campaignid','vtiger_campaignscf'=>'campaignid');
/**
* Mandatory table for supporting custom fields.
*/
var $customFieldTable = Array('vtiger_campaignscf', 'campaignid');
var $column_fields = Array();
var $sortby_fields = Array('campaignname','smownerid','campaigntype','productname','expectedrevenue','closingdate','campaignstatus','expectedresponse','targetaudience','expectedcost');
var $list_fields = Array(
'Campaign Name'=>Array('campaign'=>'campaignname'),
'Campaign Type'=>Array('campaign'=>'campaigntype'),
'Campaign Status'=>Array('campaign'=>'campaignstatus'),
'Expected Revenue'=>Array('campaign'=>'expectedrevenue'),
'Expected Close Date'=>Array('campaign'=>'closingdate'),
'Assigned To' => Array('crmentity'=>'smownerid')
);
var $list_fields_name = Array(
'Campaign Name'=>'campaignname',
'Campaign Type'=>'campaigntype',
'Campaign Status'=>'campaignstatus',
'Expected Revenue'=>'expectedrevenue',
'Expected Close Date'=>'closingdate',
'Assigned To'=>'assigned_user_id'
);
var $list_link_field= 'campaignname';
//Added these variables which are used as default order by and sortorder in ListView
var $default_order_by = 'crmid';
var $default_sort_order = 'DESC';
//var $groupTable = Array('vtiger_campaigngrouprelation','campaignid');
var $search_fields = Array(
'Campaign Name'=>Array('vtiger_campaign'=>'campaignname'),
'Campaign Type'=>Array('vtiger_campaign'=>'campaigntype'),
);
var $search_fields_name = Array(
'Campaign Name'=>'campaignname',
'Campaign Type'=>'campaigntype',
);
// Used when enabling/disabling the mandatory fields for the module.
// Refers to vtiger_field.fieldname values.
var $mandatory_fields = Array('campaignname','createdtime' ,'modifiedtime','assigned_user_id');
// For Alphabetical search
var $def_basicsearch_col = 'campaignname';
function Campaigns()
{
$this->log =LoggerManager::getLogger('campaign');
$this->db = PearDatabase::getInstance();
$this->column_fields = getColumnFields('Campaigns');
}
/** Function to handle module specific operations when saving a entity
*/
function save_module($module)
{
}
// Mike Crowe Mod --------------------------------------------------------Default ordering for us
/**
* Function to get Campaign related Accouts
* @param integer $id - campaignid
* returns related Accounts record in array format
*/
function get_accounts($id, $cur_tab_id, $rel_tab_id, $actions = false) {
global $log, $singlepane_view,$currentModule;
$log->debug("Entering get_accounts(".$id.") method ...");
$this_module = $currentModule;
$related_module = vtlib_getModuleNameById($rel_tab_id);
require_once("modules/$related_module/$related_module.php");
$other = new $related_module();
$is_CampaignStatusAllowed = false;
global $current_user;
if(getFieldVisibilityPermission('Accounts', $current_user->id, 'campaignrelstatus') == '0') {
$other->list_fields['Status'] = array('vtiger_campaignrelstatus'=>'campaignrelstatus');
$other->list_fields_name['Status'] = 'campaignrelstatus';
$other->sortby_fields[] = 'campaignrelstatus';
$is_CampaignStatusAllowed = (getFieldVisibilityPermission('Accounts', $current_user->id, 'campaignrelstatus','readwrite') == '0')? true : false;
}
vtlib_setup_modulevars($related_module, $other);
$singular_modname = vtlib_toSingular($related_module);
$parenttab = getParentTab();
if($singlepane_view == 'true')
$returnset = '&return_module='.$this_module.'&return_action=DetailView&return_id='.$id;
else
$returnset = '&return_module='.$this_module.'&return_action=CallRelatedList&return_id='.$id;
$button = '';
// Send mail button for selected Accounts
$button .= "";
$button .= '  ';
/* To get Accounts CustomView -START */
require_once('modules/CustomView/CustomView.php');
$ahtml = "";
/* To get Accounts CustomView -END */
$button .= $ahtml."";
$button .= '  ';
if($actions)
{
if(is_string($actions))
$actions = explode(',', strtoupper($actions));
if(in_array('SELECT', $actions) && isPermitted($related_module,4, '') == 'yes')
{
$button .= " ";
}
if(in_array('ADD', $actions) && isPermitted($related_module,1, '') == 'yes')
{
$button .= "".
" ";
}
}
$userNameSql = getSqlForNameInDisplayFormat(array('first_name'=>
'vtiger_users.first_name', 'last_name' => 'vtiger_users.last_name'), 'Users');
$query = "SELECT vtiger_account.*,
CASE when (vtiger_users.user_name not like '') then $userNameSql else vtiger_groups.groupname end as user_name,
vtiger_crmentity.*, vtiger_crmentity.modifiedtime, vtiger_campaignrelstatus.*, vtiger_accountbillads.*
FROM vtiger_account
INNER JOIN vtiger_campaignaccountrel ON vtiger_campaignaccountrel.accountid = vtiger_account.accountid
INNER JOIN vtiger_crmentity ON vtiger_crmentity.crmid = vtiger_account.accountid
LEFT JOIN vtiger_groups ON vtiger_groups.groupid=vtiger_crmentity.smownerid
LEFT JOIN vtiger_users ON vtiger_crmentity.smownerid=vtiger_users.id
LEFT JOIN vtiger_accountbillads ON vtiger_accountbillads.accountaddressid = vtiger_account.accountid
LEFT JOIN vtiger_campaignrelstatus ON vtiger_campaignrelstatus.campaignrelstatusid = vtiger_campaignaccountrel.campaignrelstatusid
WHERE vtiger_campaignaccountrel.campaignid = ".$id." AND vtiger_crmentity.deleted=0";
$return_value = GetRelatedList($this_module, $related_module, $other, $query, $button, $returnset);
if($return_value == null)
$return_value = Array();
else if($is_CampaignStatusAllowed) {
$statusPos = count($return_value['header']) - 2; // Last column is for Actions, exclude that. Also the index starts from 0, so reduce one more count.
$return_value = $this->add_status_popup($return_value, $statusPos, 'Accounts');
}
$return_value['CUSTOM_BUTTON'] = $button;
$log->debug("Exiting get_accounts method ...");
return $return_value;
}
/**
* Function to get Campaign related Contacts
* @param integer $id - campaignid
* returns related Contacts record in array format
*/
function get_contacts($id, $cur_tab_id, $rel_tab_id, $actions=false) {
global $log, $singlepane_view,$currentModule;
$log->debug("Entering get_contacts(".$id.") method ...");
$this_module = $currentModule;
$related_module = vtlib_getModuleNameById($rel_tab_id);
require_once("modules/$related_module/$related_module.php");
$other = new $related_module();
$is_CampaignStatusAllowed = false;
global $current_user;
if(getFieldVisibilityPermission('Contacts', $current_user->id, 'campaignrelstatus') == '0') {
$other->list_fields['Status'] = array('vtiger_campaignrelstatus'=>'campaignrelstatus');
$other->list_fields_name['Status'] = 'campaignrelstatus';
$other->sortby_fields[] = 'campaignrelstatus';
$is_CampaignStatusAllowed = (getFieldVisibilityPermission('Contacts', $current_user->id, 'campaignrelstatus','readwrite') == '0')? true : false;
}
vtlib_setup_modulevars($related_module, $other);
$singular_modname = vtlib_toSingular($related_module);
$parenttab = getParentTab();
if($singlepane_view == 'true')
$returnset = '&return_module='.$this_module.'&return_action=DetailView&return_id='.$id;
else
$returnset = '&return_module='.$this_module.'&return_action=CallRelatedList&return_id='.$id;
$button = '';
// Send mail button for selected Leads
$button .= "";
$button .= '  ';
/* To get Leads CustomView -START */
require_once('modules/CustomView/CustomView.php');
$lhtml = "";
/* To get Leads CustomView -END */
$button .= $lhtml."";
$button .= '  ';
if($actions) {
if(is_string($actions)) $actions = explode(',', strtoupper($actions));
if(in_array('SELECT', $actions) && isPermitted($related_module,4, '') == 'yes') {
$button .= " ";
}
if(in_array('ADD', $actions) && isPermitted($related_module,1, '') == 'yes') {
$button .= "".
" ";
}
}
$userNameSql = getSqlForNameInDisplayFormat(array('first_name'=>
'vtiger_users.first_name', 'last_name' => 'vtiger_users.last_name'), 'Users');
$query = "SELECT vtiger_contactdetails.accountid, vtiger_account.accountname,
CASE when (vtiger_users.user_name not like '') then $userNameSql else vtiger_groups.groupname end as user_name ,
vtiger_contactdetails.contactid, vtiger_contactdetails.lastname, vtiger_contactdetails.firstname, vtiger_contactdetails.title,
vtiger_contactdetails.department, vtiger_contactdetails.email, vtiger_contactdetails.phone, vtiger_crmentity.crmid,
vtiger_crmentity.smownerid, vtiger_crmentity.modifiedtime, vtiger_campaignrelstatus.*
FROM vtiger_contactdetails
INNER JOIN vtiger_campaigncontrel ON vtiger_campaigncontrel.contactid = vtiger_contactdetails.contactid
INNER JOIN vtiger_crmentity ON vtiger_crmentity.crmid = vtiger_contactdetails.contactid
LEFT JOIN vtiger_groups ON vtiger_groups.groupid=vtiger_crmentity.smownerid
LEFT JOIN vtiger_users ON vtiger_crmentity.smownerid=vtiger_users.id
LEFT JOIN vtiger_account ON vtiger_account.accountid = vtiger_contactdetails.accountid
LEFT JOIN vtiger_campaignrelstatus ON vtiger_campaignrelstatus.campaignrelstatusid = vtiger_campaigncontrel.campaignrelstatusid
WHERE vtiger_campaigncontrel.campaignid = ".$id." AND vtiger_crmentity.deleted=0";
$return_value = GetRelatedList($this_module, $related_module, $other, $query, $button, $returnset);
if($return_value == null)
$return_value = Array();
else if($is_CampaignStatusAllowed) {
$statusPos = count($return_value['header']) - 2; // Last column is for Actions, exclude that. Also the index starts from 0, so reduce one more count.
$return_value = $this->add_status_popup($return_value, $statusPos, 'Contacts');
}
$return_value['CUSTOM_BUTTON'] = $button;
$log->debug("Exiting get_contacts method ...");
return $return_value;
}
/**
* Function to get Campaign related Leads
* @param integer $id - campaignid
* returns related Leads record in array format
*/
function get_leads($id, $cur_tab_id, $rel_tab_id, $actions=false) {
global $log, $singlepane_view, $currentModule;
$log->debug("Entering get_leads(".$id.") method ...");
$this_module = $currentModule;
$related_module = vtlib_getModuleNameById($rel_tab_id);
require_once("modules/$related_module/$related_module.php");
$other = new $related_module();
$is_CampaignStatusAllowed = false;
global $current_user;
if(getFieldVisibilityPermission('Leads', $current_user->id, 'campaignrelstatus') == '0') {
$other->list_fields['Status'] = array('vtiger_campaignrelstatus'=>'campaignrelstatus');
$other->list_fields_name['Status'] = 'campaignrelstatus';
$other->sortby_fields[] = 'campaignrelstatus';
$is_CampaignStatusAllowed = (getFieldVisibilityPermission('Leads', $current_user->id, 'campaignrelstatus','readwrite') == '0')? true : false;
}
vtlib_setup_modulevars($related_module, $other);
$singular_modname = vtlib_toSingular($related_module);
$parenttab = getParentTab();
if($singlepane_view == 'true')
$returnset = '&return_module='.$this_module.'&return_action=DetailView&return_id='.$id;
else
$returnset = '&return_module='.$this_module.'&return_action=CallRelatedList&return_id='.$id;
$button = '';
// Send mail button for selected Leads
$button .= "";
$button .= '  ';
/* To get Leads CustomView -START */
require_once('modules/CustomView/CustomView.php');
$lhtml = "";
/* To get Leads CustomView -END */
$button .= $lhtml."";
$button .= '  ';
if($actions) {
if(is_string($actions)) $actions = explode(',', strtoupper($actions));
if(in_array('SELECT', $actions) && isPermitted($related_module,4, '') == 'yes') {
$button .= " ";
}
if(in_array('ADD', $actions) && isPermitted($related_module,1, '') == 'yes') {
$button .= "".
" ";
}
}
$userNameSql = getSqlForNameInDisplayFormat(array('first_name'=>
'vtiger_users.first_name', 'last_name' => 'vtiger_users.last_name'), 'Users');
$query = "SELECT vtiger_leaddetails.*, vtiger_crmentity.crmid,vtiger_leadaddress.phone,vtiger_leadsubdetails.website,
CASE when (vtiger_users.user_name not like '') then $userNameSql else vtiger_groups.groupname end as user_name,
vtiger_crmentity.smownerid, vtiger_campaignrelstatus.*
FROM vtiger_leaddetails
INNER JOIN vtiger_campaignleadrel ON vtiger_campaignleadrel.leadid=vtiger_leaddetails.leadid
INNER JOIN vtiger_crmentity ON vtiger_crmentity.crmid = vtiger_leaddetails.leadid
INNER JOIN vtiger_leadsubdetails ON vtiger_leadsubdetails.leadsubscriptionid = vtiger_leaddetails.leadid
INNER JOIN vtiger_leadaddress ON vtiger_leadaddress.leadaddressid = vtiger_leadsubdetails.leadsubscriptionid
LEFT JOIN vtiger_users ON vtiger_crmentity.smownerid = vtiger_users.id
LEFT JOIN vtiger_groups ON vtiger_groups.groupid=vtiger_crmentity.smownerid
LEFT JOIN vtiger_campaignrelstatus ON vtiger_campaignrelstatus.campaignrelstatusid = vtiger_campaignleadrel.campaignrelstatusid
WHERE vtiger_crmentity.deleted=0 AND vtiger_campaignleadrel.campaignid = ".$id;
$return_value = GetRelatedList($this_module, $related_module, $other, $query, $button, $returnset);
if($return_value == null)
$return_value = Array();
else if($is_CampaignStatusAllowed) {
$statusPos = count($return_value['header']) - 2; // Last column is for Actions, exclude that. Also the index starts from 0, so reduce one more count.
$return_value = $this->add_status_popup($return_value, $statusPos, 'Leads');
}
$return_value['CUSTOM_BUTTON'] = $button;
$log->debug("Exiting get_leads method ...");
return $return_value;
}
/**
* Function to get Campaign related Potentials
* @param integer $id - campaignid
* returns related potentials record in array format
*/
function get_opportunities($id, $cur_tab_id, $rel_tab_id, $actions=false) {
global $log, $singlepane_view,$currentModule,$current_user;
$log->debug("Entering get_opportunities(".$id.") method ...");
$this_module = $currentModule;
$related_module = vtlib_getModuleNameById($rel_tab_id);
require_once("modules/$related_module/$related_module.php");
$other = new $related_module();
vtlib_setup_modulevars($related_module, $other);
$singular_modname = vtlib_toSingular($related_module);
$parenttab = getParentTab();
if($singlepane_view == 'true')
$returnset = '&return_module='.$this_module.'&return_action=DetailView&return_id='.$id;
else
$returnset = '&return_module='.$this_module.'&return_action=CallRelatedList&return_id='.$id;
$button = '';
if($actions && getFieldVisibilityPermission($related_module,$current_user->id,'campaignid', 'readwrite') == '0') {
if(is_string($actions)) $actions = explode(',', strtoupper($actions));
if(in_array('SELECT', $actions) && isPermitted($related_module,4, '') == 'yes') {
$button .= " ";
}
if(in_array('ADD', $actions) && isPermitted($related_module,1, '') == 'yes') {
$button .= " ";
}
}
$userNameSql = getSqlForNameInDisplayFormat(array('first_name'=>
'vtiger_users.first_name', 'last_name' => 'vtiger_users.last_name'), 'Users');
$query = "SELECT CASE when (vtiger_users.user_name not like '') then $userNameSql else vtiger_groups.groupname end as user_name,
vtiger_potential.related_to, vtiger_account.accountname, vtiger_potential.potentialid, vtiger_potential.potentialname,
vtiger_potential.potentialtype, vtiger_potential.sales_stage, vtiger_potential.amount, vtiger_potential.closingdate,
vtiger_crmentity.crmid, vtiger_crmentity.smownerid FROM vtiger_campaign
INNER JOIN vtiger_potential ON vtiger_campaign.campaignid = vtiger_potential.campaignid
INNER JOIN vtiger_crmentity ON vtiger_crmentity.crmid = vtiger_potential.potentialid
LEFT JOIN vtiger_groups ON vtiger_groups.groupid=vtiger_crmentity.smownerid
LEFT JOIN vtiger_users ON vtiger_users.id=vtiger_crmentity.smownerid
LEFT JOIN vtiger_account ON vtiger_account.accountid = vtiger_potential.related_to
WHERE vtiger_campaign.campaignid = ".$id." AND vtiger_crmentity.deleted=0";
$return_value = GetRelatedList($this_module, $related_module, $other, $query, $button, $returnset);
if($return_value == null) $return_value = Array();
$return_value['CUSTOM_BUTTON'] = $button;
$log->debug("Exiting get_opportunities method ...");
return $return_value;
}
/**
* Function to get Campaign related Activities
* @param integer $id - campaignid
* returns related activities record in array format
*/
function get_activities($id, $cur_tab_id, $rel_tab_id, $actions=false) {
global $log, $singlepane_view,$currentModule,$current_user;
$log->debug("Entering get_activities(".$id.") method ...");
$this_module = $currentModule;
$related_module = vtlib_getModuleNameById($rel_tab_id);
require_once("modules/$related_module/Activity.php");
$other = new Activity();
vtlib_setup_modulevars($related_module, $other);
$singular_modname = vtlib_toSingular($related_module);
$parenttab = getParentTab();
if($singlepane_view == 'true')
$returnset = '&return_module='.$this_module.'&return_action=DetailView&return_id='.$id;
else
$returnset = '&return_module='.$this_module.'&return_action=CallRelatedList&return_id='.$id;
$button = '';
$button .= '';
if($actions) {
if(is_string($actions)) $actions = explode(',', strtoupper($actions));
if(in_array('ADD', $actions) && isPermitted($related_module,1, '') == 'yes') {
if(getFieldVisibilityPermission('Calendar',$current_user->id,'parent_id', 'readwrite') == '0') {
$button .= " ";
}
if(getFieldVisibilityPermission('Events',$current_user->id,'parent_id', 'readwrite') == '0') {
$button .= "";
}
}
}
$userNameSql = getSqlForNameInDisplayFormat(array('first_name'=>
'vtiger_users.first_name', 'last_name' => 'vtiger_users.last_name'), 'Users');
$query = "SELECT vtiger_contactdetails.lastname,
vtiger_contactdetails.firstname,
vtiger_contactdetails.contactid,
vtiger_activity.*,
vtiger_seactivityrel.*,
vtiger_crmentity.crmid, vtiger_crmentity.smownerid,
vtiger_crmentity.modifiedtime,
CASE when (vtiger_users.user_name not like '') then $userNameSql else vtiger_groups.groupname end as user_name,
vtiger_recurringevents.recurringtype
FROM vtiger_activity
INNER JOIN vtiger_seactivityrel
ON vtiger_seactivityrel.activityid = vtiger_activity.activityid
INNER JOIN vtiger_crmentity
ON vtiger_crmentity.crmid=vtiger_activity.activityid
LEFT JOIN vtiger_cntactivityrel
ON vtiger_cntactivityrel.activityid = vtiger_activity.activityid
LEFT JOIN vtiger_contactdetails
ON vtiger_contactdetails.contactid = vtiger_cntactivityrel.contactid
LEFT JOIN vtiger_users
ON vtiger_users.id = vtiger_crmentity.smownerid
LEFT OUTER JOIN vtiger_recurringevents
ON vtiger_recurringevents.activityid = vtiger_activity.activityid
LEFT JOIN vtiger_groups
ON vtiger_groups.groupid = vtiger_crmentity.smownerid
WHERE vtiger_seactivityrel.crmid=".$id."
AND vtiger_crmentity.deleted = 0
AND (activitytype = 'Task'
OR activitytype !='Emails')";
$return_value = GetRelatedList($this_module, $related_module, $other, $query, $button, $returnset);
if($return_value == null) $return_value = Array();
$return_value['CUSTOM_BUTTON'] = $button;
$log->debug("Exiting get_activities method ...");
return $return_value;
}
/*
* Function populate the status columns' HTML
* @param - $related_list return value from GetRelatedList
* @param - $status_column index of the status column in the list.
* returns true on success
*/
function add_status_popup($related_list, $status_column = 7, $related_module)
{
global $adb;
if(!$this->campaignrelstatus)
{
$result = $adb->query('SELECT * FROM vtiger_campaignrelstatus;');
while($row = $adb->fetchByAssoc($result))
{
$this->campaignrelstatus[$row['campaignrelstatus']] = $row;
}
}
foreach($related_list['entries'] as $key => &$entry)
{
$popupitemshtml = '';
foreach($this->campaignrelstatus as $campaingrelstatus)
{
$camprelstatus = getTranslatedString($campaingrelstatus[campaignrelstatus],'Campaigns');
$popupitemshtml .= "id."', '$key', '$campaingrelstatus[campaignrelstatusid]', '".addslashes($camprelstatus)."');\">$camprelstatus
";
}
$popuphtml = '