'crmid','vtiger_invoice'=>'invoiceid','vtiger_invoicebillads'=>'invoicebilladdressid','vtiger_invoiceshipads'=>'invoiceshipaddressid','vtiger_invoicecf'=>'invoiceid'); /** * Mandatory table for supporting custom fields. */ var $customFieldTable = Array('vtiger_invoicecf', 'invoiceid'); var $column_fields = Array(); var $update_product_array = Array(); var $sortby_fields = Array('subject','invoice_no','invoicestatus','smownerid','accountname','lastname'); // This is used to retrieve related vtiger_fields from form posts. var $additional_column_fields = Array('assigned_user_name', 'smownerid', 'opportunity_id', 'case_id', 'contact_id', 'task_id', 'note_id', 'meeting_id', 'call_id', 'email_id', 'parent_name', 'member_id' ); // This is the list of vtiger_fields that are in the lists. var $list_fields = Array( //'Invoice No'=>Array('crmentity'=>'crmid'), 'Invoice No'=>Array('invoice'=>'invoice_no'), 'Subject'=>Array('invoice'=>'subject'), 'Sales Order'=>Array('invoice'=>'salesorderid'), 'Status'=>Array('invoice'=>'invoicestatus'), 'Total'=>Array('invoice'=>'total'), 'Assigned To'=>Array('crmentity'=>'smownerid') ); var $list_fields_name = Array( 'Invoice No'=>'invoice_no', 'Subject'=>'subject', 'Sales Order'=>'salesorder_id', 'Status'=>'invoicestatus', 'Total'=>'hdnGrandTotal', 'Assigned To'=>'assigned_user_id' ); var $list_link_field= 'subject'; var $search_fields = Array( //'Invoice No'=>Array('crmentity'=>'crmid'), 'Invoice No'=>Array('invoice'=>'invoice_no'), 'Subject'=>Array('purchaseorder'=>'subject'), ); var $search_fields_name = Array( 'Invoice No'=>'', 'Subject'=>'subject', ); // This is the list of vtiger_fields that are required. var $required_fields = array("accountname"=>1); //Added these variables which are used as default order by and sortorder in ListView var $default_order_by = 'crmid'; var $default_sort_order = 'ASC'; //var $groupTable = Array('vtiger_invoicegrouprelation','invoiceid'); var $mandatory_fields = Array('subject','createdtime' ,'modifiedtime'); var $_salesorderid; var $_recurring_mode; // For Alphabetical search var $def_basicsearch_col = 'subject'; /** Constructor which will set the column_fields in this object */ function Invoice() { $this->log =LoggerManager::getLogger('Invoice'); $this->log->debug("Entering Invoice() method ..."); $this->db = PearDatabase::getInstance(); $this->column_fields = getColumnFields('Invoice'); $this->log->debug("Exiting Invoice method ..."); } /** Function to handle the module specific save operations */ function save_module($module) { //Checking if vtiger_salesorderid is present and updating the quote status if($this->column_fields["salesorder_id"] != '') { $so_id = $this->column_fields["salesorder_id"]; $query1 = "update vtiger_salesorder set sostatus='Approved' where salesorderid=?"; $this->db->pquery($query1, array($so_id)); } //in ajax save we should not call this function, because this will delete all the existing product values if(isset($this->_recurring_mode) && $this->_recurring_mode == 'recurringinvoice_from_so' && isset($this->_salesorderid) && $this->_salesorderid!='') { // We are getting called from the RecurringInvoice cron service! $this->createRecurringInvoiceFromSO(); } else if(isset($_REQUEST)) { if($_REQUEST['action'] != 'InvoiceAjax' && $_REQUEST['ajxaction'] != 'DETAILVIEW' && $_REQUEST['action'] != 'MassEditSave' && $_REQUEST['action'] != 'ProcessDuplicates') { //Based on the total Number of rows we will save the product relationship with this entity saveInventoryProductDetails($this, 'Invoice'); } } // Update the currency id and the conversion rate for the invoice $update_query = "update vtiger_invoice set currency_id=?, conversion_rate=? where invoiceid=?"; $update_params = array($this->column_fields['currency_id'], $this->column_fields['conversion_rate'], $this->id); $this->db->pquery($update_query, $update_params); } /** function used to get the name of the current object * @return string $this->name - name of the current object */ function get_summary_text() { global $log; $log->debug("Entering get_summary_text() method ..."); $log->debug("Exiting get_summary_text method ..."); return $this->name; } /** function used to get the list of activities which are related to the invoice * @param int $id - invoice id * @return array - return an array which will be returned from the function GetRelatedList */ 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 .= " "; } } } $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_contactdetails.lastname, vtiger_contactdetails.firstname, vtiger_contactdetails.contactid, vtiger_activity.*,vtiger_seactivityrel.*,vtiger_crmentity.crmid, vtiger_crmentity.smownerid, vtiger_crmentity.modifiedtime 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 join vtiger_groups on vtiger_groups.groupid=vtiger_crmentity.smownerid where vtiger_seactivityrel.crmid=".$id." and activitytype='Task' and vtiger_crmentity.deleted=0 and (vtiger_activity.status is not NULL and vtiger_activity.status != 'Completed') and (vtiger_activity.status is not NULL and vtiger_activity.status != 'Deferred')"; $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 used to get the the activity history related to the quote * @param int $id - invoice id * @return array - return an array which will be returned from the function GetHistory */ function get_history($id) { global $log; $log->debug("Entering get_history(".$id.") method ..."); $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, vtiger_crmentity.createdtime, vtiger_crmentity.description, case when (vtiger_users.user_name not like '') then $userNameSql else vtiger_groups.groupname end as user_name 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_groups on vtiger_groups.groupid=vtiger_crmentity.smownerid left join vtiger_users on vtiger_users.id=vtiger_crmentity.smownerid where vtiger_activity.activitytype='Task' and (vtiger_activity.status = 'Completed' or vtiger_activity.status = 'Deferred') and vtiger_seactivityrel.crmid=".$id." and vtiger_crmentity.deleted = 0"; //Don't add order by, because, for security, one more condition will be added with this query in include/RelatedListView.php $log->debug("Exiting get_history method ..."); return getHistory('Invoice',$query,$id); } /** Function used to get the Status history of the Invoice * @param $id - invoice id * @return $return_data - array with header and the entries in format Array('header'=>$header,'entries'=>$entries_list) where as $header and $entries_list are arrays which contains header values and all column values of all entries */ function get_invoicestatushistory($id) { global $log; $log->debug("Entering get_invoicestatushistory(".$id.") method ..."); global $adb; global $mod_strings; global $app_strings; $query = 'select vtiger_invoicestatushistory.*, vtiger_invoice.invoice_no from vtiger_invoicestatushistory inner join vtiger_invoice on vtiger_invoice.invoiceid = vtiger_invoicestatushistory.invoiceid inner join vtiger_crmentity on vtiger_crmentity.crmid = vtiger_invoice.invoiceid where vtiger_crmentity.deleted = 0 and vtiger_invoice.invoiceid = ?'; $result=$adb->pquery($query, array($id)); $noofrows = $adb->num_rows($result); $header[] = $app_strings['Invoice No']; $header[] = $app_strings['LBL_ACCOUNT_NAME']; $header[] = $app_strings['LBL_AMOUNT']; $header[] = $app_strings['LBL_INVOICE_STATUS']; $header[] = $app_strings['LBL_LAST_MODIFIED']; //Getting the field permission for the current user. 1 - Not Accessible, 0 - Accessible //Account Name , Amount are mandatory fields. So no need to do security check to these fields. global $current_user; //If field is accessible then getFieldVisibilityPermission function will return 0 else return 1 $invoicestatus_access = (getFieldVisibilityPermission('Invoice', $current_user->id, 'invoicestatus') != '0')? 1 : 0; $picklistarray = getAccessPickListValues('Invoice'); $invoicestatus_array = ($invoicestatus_access != 1)? $picklistarray['invoicestatus']: array(); //- ==> picklist field is not permitted in profile //Not Accessible - picklist is permitted in profile but picklist value is not permitted $error_msg = ($invoicestatus_access != 1)? 'Not Accessible': '-'; while($row = $adb->fetch_array($result)) { $entries = Array(); // Module Sequence Numbering //$entries[] = $row['invoiceid']; $entries[] = $row['invoice_no']; // END $entries[] = $row['accountname']; $entries[] = $row['total']; $entries[] = (in_array($row['invoicestatus'], $invoicestatus_array))? $row['invoicestatus']: $error_msg; $entries[] = DateTimeField::convertToUserFormat($row['lastmodified']); $entries_list[] = $entries; } $return_data = Array('header'=>$header,'entries'=>$entries_list); $log->debug("Exiting get_invoicestatushistory method ..."); return $return_data; } // Function to get column name - Overriding function of base class function get_column_value($columname, $fldvalue, $fieldname, $uitype, $datatype) { if ($columname == 'salesorderid') { if ($fldvalue == '') return null; } return parent::get_column_value($columname, $fldvalue, $fieldname, $uitype, $datatype); } /* * Function to get the secondary query part of a report * @param - $module primary module name * @param - $secmodule secondary module name * returns the query string formed on fetching the related data for report for secondary module */ function generateReportsSecQuery($module,$secmodule){ $query = $this->getRelationQuery($module,$secmodule,"vtiger_invoice","invoiceid"); $query .= " left join vtiger_crmentity as vtiger_crmentityInvoice on vtiger_crmentityInvoice.crmid=vtiger_invoice.invoiceid and vtiger_crmentityInvoice.deleted=0 left join vtiger_invoicecf on vtiger_invoice.invoiceid = vtiger_invoicecf.invoiceid left join vtiger_currency_info as vtiger_currency_info$secmodule on vtiger_currency_info$secmodule.id = vtiger_invoice.currency_id left join vtiger_salesorder as vtiger_salesorderInvoice on vtiger_salesorderInvoice.salesorderid=vtiger_invoice.salesorderid left join vtiger_invoicebillads on vtiger_invoice.invoiceid=vtiger_invoicebillads.invoicebilladdressid left join vtiger_invoiceshipads on vtiger_invoice.invoiceid=vtiger_invoiceshipads.invoiceshipaddressid left join vtiger_inventoryproductrel as vtiger_inventoryproductrelInvoice on vtiger_invoice.invoiceid = vtiger_inventoryproductrelInvoice.id left join vtiger_products as vtiger_productsInvoice on vtiger_productsInvoice.productid = vtiger_inventoryproductrelInvoice.productid left join vtiger_service as vtiger_serviceInvoice on vtiger_serviceInvoice.serviceid = vtiger_inventoryproductrelInvoice.productid left join vtiger_groups as vtiger_groupsInvoice on vtiger_groupsInvoice.groupid = vtiger_crmentityInvoice.smownerid left join vtiger_users as vtiger_usersInvoice on vtiger_usersInvoice.id = vtiger_crmentityInvoice.smownerid left join vtiger_contactdetails as vtiger_contactdetailsInvoice on vtiger_invoice.contactid = vtiger_contactdetailsInvoice.contactid left join vtiger_account as vtiger_accountInvoice on vtiger_accountInvoice.accountid = vtiger_invoice.accountid left join vtiger_users as vtiger_lastModifiedByInvoice on vtiger_lastModifiedByInvoice.id = vtiger_crmentityInvoice.modifiedby "; return $query; } /* * Function to get the relation tables for related modules * @param - $secmodule secondary module name * returns the array with table names and fieldnames storing relations between module and this module */ function setRelationTables($secmodule){ $rel_tables = array ( "Calendar" =>array("vtiger_seactivityrel"=>array("crmid","activityid"),"vtiger_invoice"=>"invoiceid"), "Documents" => array("vtiger_senotesrel"=>array("crmid","notesid"),"vtiger_invoice"=>"invoiceid"), "Accounts" => array("vtiger_invoice"=>array("invoiceid","accountid")), ); return $rel_tables[$secmodule]; } // Function to unlink an entity with given Id from another entity function unlinkRelationship($id, $return_module, $return_id) { global $log; if(empty($return_module) || empty($return_id)) return; if($return_module == 'Accounts' || $return_module == 'Contacts') { $this->trash('Invoice',$id); } elseif($return_module=='SalesOrder') { $relation_query = 'UPDATE vtiger_invoice set salesorderid=? where invoiceid=?'; $this->db->pquery($relation_query, array(null,$id)); } else { $sql = 'DELETE FROM vtiger_crmentityrel WHERE (crmid=? AND relmodule=? AND relcrmid=?) OR (relcrmid=? AND module=? AND crmid=?)'; $params = array($id, $return_module, $return_id, $id, $return_module, $return_id); $this->db->pquery($sql, $params); } } /* * Function to get the relations of salesorder to invoice for recurring invoice procedure * @param - $salesorder_id Salesorder ID */ function createRecurringInvoiceFromSO(){ global $adb; $salesorder_id = $this->_salesorderid; $query1 = "SELECT * FROM vtiger_inventoryproductrel WHERE id=?"; $res = $adb->pquery($query1, array($salesorder_id)); $no_of_products = $adb->num_rows($res); $fieldsList = $adb->getFieldsArray($res); $update_stock = array(); for($j=0; $j<$no_of_products; $j++) { $row = $adb->query_result_rowdata($res, $j); $col_value = array(); for($k=0; $k 0) { $col_value['id'] = $this->id; $columns = array_keys($col_value); $values = array_values($col_value); $query2 = "INSERT INTO vtiger_inventoryproductrel(". implode(",",$columns) .") VALUES (". generateQuestionMarks($values) .")"; $adb->pquery($query2, array($values)); $prod_id = $col_value['productid']; $qty = $col_value['quantity']; $update_stock[$col_value['sequence_no']] = $qty; updateStk($prod_id,$qty,'',array(),'Invoice'); } } $query1 = "SELECT * FROM vtiger_inventorysubproductrel WHERE id=?"; $res = $adb->pquery($query1, array($salesorder_id)); $no_of_products = $adb->num_rows($res); $fieldsList = $adb->getFieldsArray($res); for($j=0; $j<$no_of_products; $j++) { $row = $adb->query_result_rowdata($res, $j); $col_value = array(); for($k=0; $k 0) { $col_value['id'] = $this->id; $columns = array_keys($col_value); $values = array_values($col_value); $query2 = "INSERT INTO vtiger_inventorysubproductrel(". implode(",",$columns) .") VALUES (". generateQuestionMarks($values) .")"; $adb->pquery($query2, array($values)); $prod_id = $col_value['productid']; $qty = $update_stock[$col_value['sequence_no']]; updateStk($prod_id,$qty,'',array(),'Invoice'); } } // Add the Shipping taxes for the Invoice $query3 = "SELECT * FROM vtiger_inventoryshippingrel WHERE id=?"; $res = $adb->pquery($query3, array($salesorder_id)); $no_of_shippingtax = $adb->num_rows($res); $fieldsList = $adb->getFieldsArray($res); for($j=0; $j<$no_of_shippingtax; $j++) { $row = $adb->query_result_rowdata($res, $j); $col_value = array(); for($k=0; $k 0) { $col_value['id'] = $this->id; $columns = array_keys($col_value); $values = array_values($col_value); $query4 = "INSERT INTO vtiger_inventoryshippingrel(". implode(",",$columns) .") VALUES (". generateQuestionMarks($values) .")"; $adb->pquery($query4, array($values)); } } //Update the netprice (subtotal), taxtype, discount, S&H charge, adjustment and total for the Invoice $updatequery = " UPDATE vtiger_invoice SET "; $updateparams = array(); // Remaining column values to be updated -> column name to field name mapping $invoice_column_field = Array ( 'adjustment' => 'txtAdjustment', 'subtotal' => 'hdnSubTotal', 'total' => 'hdnGrandTotal', 'taxtype' => 'hdnTaxType', 'discount_percent' => 'hdnDiscountPercent', 'discount_amount' => 'hdnDiscountAmount', 's_h_amount' => 'hdnS_H_Amount', ); $updatecols = array(); foreach($invoice_column_field as $col => $field) { $updatecols[] = "$col=?"; $updateparams[] = $this->column_fields[$field]; } if (count($updatecols) > 0) { $updatequery .= implode(",", $updatecols); $updatequery .= " WHERE invoiceid=?"; array_push($updateparams, $this->id); $adb->pquery($updatequery, $updateparams); } } } ?>