486 lines
22 KiB
PHP
486 lines
22 KiB
PHP
<?php
|
|
/*********************************************************************************
|
|
* The contents of this file are subject to the SugarCRM Public License Version 1.1.2
|
|
* ("License"); You may not use this file except in compliance with the
|
|
* License. You may obtain a copy of the License at http://www.sugarcrm.com/SPL
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
|
|
* the specific language governing rights and limitations under the License.
|
|
* The Original Code is: SugarCRM Open Source
|
|
* The Initial Developer of the Original Code is SugarCRM, Inc.
|
|
* Portions created by SugarCRM are Copyright (C) SugarCRM, Inc.;
|
|
* All Rights Reserved.
|
|
* Contributor(s): ______________________________________.
|
|
********************************************************************************/
|
|
/*********************************************************************************
|
|
* $Header$
|
|
* Description: Defines the Account SugarBean Account entity with the necessary
|
|
* methods and variables.
|
|
* Portions created by SugarCRM are Copyright (C) SugarCRM, Inc.
|
|
* All Rights Reserved.
|
|
* Contributor(s): ______________________________________..
|
|
********************************************************************************/
|
|
|
|
include_once('config.php');
|
|
require_once('include/logging.php');
|
|
require_once('include/utils/utils.php');
|
|
require_once('user_privileges/default_module_view.php');
|
|
|
|
// Account is used to store vtiger_account information.
|
|
class Invoice extends CRMEntity {
|
|
var $log;
|
|
var $db;
|
|
|
|
var $table_name = "vtiger_invoice";
|
|
var $table_index= 'invoiceid';
|
|
var $tab_name = Array('vtiger_crmentity','vtiger_invoice','vtiger_invoicebillads','vtiger_invoiceshipads','vtiger_invoicecf');
|
|
var $tab_name_index = Array('vtiger_crmentity'=>'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 .= '<input type="hidden" name="activity_mode">';
|
|
|
|
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 .= "<input title='".getTranslatedString('LBL_NEW'). " ". getTranslatedString('LBL_TODO', $related_module) ."' class='crmbutton small create'" .
|
|
" onclick='this.form.action.value=\"EditView\";this.form.module.value=\"$related_module\";this.form.return_module.value=\"$this_module\";this.form.activity_mode.value=\"Task\";' type='submit' name='button'" .
|
|
" value='". getTranslatedString('LBL_ADD_NEW'). " " . getTranslatedString('LBL_TODO', $related_module) ."'> ";
|
|
}
|
|
}
|
|
}
|
|
|
|
$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<count($fieldsList); $k++) {
|
|
if($fieldsList[$k]!='lineitem_id'){
|
|
$col_value[$fieldsList[$k]] = $row[$fieldsList[$k]];
|
|
}
|
|
}
|
|
if(count($col_value) > 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<count($fieldsList); $k++) {
|
|
$col_value[$fieldsList[$k]] = $row[$fieldsList[$k]];
|
|
}
|
|
if(count($col_value) > 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<count($fieldsList); $k++) {
|
|
$col_value[$fieldsList[$k]] = $row[$fieldsList[$k]];
|
|
}
|
|
if(count($col_value) > 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);
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
?>
|