'notes', 'email_id' => 'emails' // 'account_id' => 'account', // 'contact_id' => 'contact', ); function EcmSale() { parent::SugarBean (); $this->setupCustomFields ( 'EcmSales' ); foreach ( $this->field_defs as $field ) { $this->field_name_map [$field ['name']] = $field; } } var $new_schema = true; function get_summary_text() { return "$this->name"; } function create_list_query($order_by, $where, $show_deleted = 0) { // Fill in the assigned_user_name $custom_join = $this->custom_fields->getJOIN (); $query = "SELECT "; $query .= "ecmsales.* ,wz.id as wzid ,users.user_name as assigned_user_name"; if ($custom_join) { $query .= $custom_join ['select']; } $query .= " FROM ecmsales LEFT JOIN users ON ecmsales.assigned_user_id=users.id LEFT JOIN ecmstockdocouts as wz ON wz.ecmsale_id=ecmsales.id"; $query .= " "; if ($custom_join) { $query .= $custom_join ['join']; } $where_auto = '1=1'; if ($show_deleted == 0) { $where_auto = " $this->table_name.deleted=0 "; } else if ($show_deleted == 1) { $where_auto = " $this->table_name.deleted=1 "; } if($_GET['show_empty_wz'])$where_auto.=" AND wz.id is null"; if ($where != "") $query .= "where $where AND " . $where_auto; else $query .= "where " . $where_auto; if (substr_count ( $order_by, '.' ) > 0) { $query .= " ORDER BY $order_by"; } else if ($order_by != "") $query .= " ORDER BY $order_by"; else $query .= " ORDER BY ecmsales.date_entered"; return $query; } function create_export_query($order_by, $where) { $custom_join = $this->custom_fields->getJOIN (); $query = "SELECT ecmsales.*, users.user_name assigned_user_name"; if ($custom_join) { $query .= $custom_join ['select']; } $query .= " FROM ecmsales "; $query .= " LEFT JOIN users ON ecmsales.assigned_user_id=users.id"; if ($custom_join) { $query .= $custom_join ['join']; } $query .= ""; $where_auto = " ecmsales.deleted=0 "; if ($where != "") $query .= " where $where AND " . $where_auto; else $query .= " where " . $where_auto; if ($order_by != "") $query .= " ORDER BY $order_by"; else $query .= " ORDER BY ecmsales.name"; return $query; } function fill_in_additional_list_fields() { } function fill_in_additional_detail_fields() { // FILL IN THE ASSIGNED_USER_NAME $this->assigned_user_name = get_assigned_user_name ( $this->assigned_user_id ); $this->created_by_name = get_assigned_user_name ( $this->created_by ); $this->modified_by_name = get_assigned_user_name ( $this->modified_user_id ); /* $result = $this->db->query ( "SELECT status, parent_id, contact_id, template_id, assigned_user_id FROM ecmsales WHERE id='$this->id'" ); if (is_resource ( $result )) { $row = $this->db->fetchByAssoc ( $result ); if ($row) { $this->status = $row ['status']; $this->parent_id = $row ['parent_id']; $this->contact_id = $row ['contact_id']; $this->template_id = $row ['template_id']; $this->assigned_user_id = $row ['assigned_user_id']; } } */ /* * $query = "select `number`, `template_id` from `ecmsales` where `id`='$this->id' limit 1"; $r = $this->db->query($query); if($r) { $r = $this->db->fetchByAssoc($r); $this->template_id = $r['template_id']; $this->number = $r['number']; $this->setTemplate(); $this->document_no = $this->formatNumber(); } */ } function get_list_view_data() { global $current_language; $this->fill_in_additional_detail_fields (); $app_list_strings = return_app_list_strings_language ( $current_language ); $mod_strings = return_module_language ( $current_language, 'EcmSales' ); $the_array = parent::get_list_view_data (); // THE NEW LISTVIEW CODE ONLY FETCHES COLUMNS THAT WE'RE DISPLAYING AND NOT ALL // THE COLUMNS SO WE NEED THESE CHECKS. if($this->ecmproduct_id!=''){ //add subpanel data $tmp=$this->getPriceFromDocument($this->ecmproduct_id); $the_array ['QUANTITY'] = format_number ( $tmp['quantity'] ); $the_array ['PRICE_NETTO'] = format_number ( $tmp['price_netto'] ); $the_array ['TOTAL_NETTO'] = format_number ( $tmp['total_netto'] ); } $this->retrieve($this->id); $the_array ['NAME'] = (($this->name == "") ? $this->document_no : $this->name); $a = new EcmStockDocOut(); $a->retrieve_by_string_fields(['ecmsale_id'=>$this->id]); if($a->id)$the_array ['WZ'] = "".$a->document_no.""; else $the_array ['WZ'] = $this->wz_name; $a = new EcmInvoiceOut(); $a->retrieve_by_string_fields(['so_id'=>$this->id]); $the_array ['FV'] = "".$a->document_no.""; $the_array ['TOTAL'] = format_number ( $this->total_netto ); $a = new Account(); $a->retrieve($this->parent_id); $the_array ['SHOP_NUMBER'] =($this->shop_number!="" ? $this->shop_number:$a->shop_number); //create image options $op = ''; $the_array ['ZS'] = "".$this->edi_zs_document_no.""; $the_array['OPTIONS'] = $op; return $the_array; } function getPriceFromDocument($product){ $zap=$this->db->query("select quantity,price_netto,total_netto from ecmsaleitems where id='".$product."'"); $dane=$this->db->fetchByAssoc($zap); return $dane; } function getStatusMenuInfo($inJSON = true) { global $app_list_strings; $arr = array (); foreach ( $app_list_strings ['ecmsales_status_dom'] as $key => $value ) { $arr [$key] = array ( 'enabled' => '
' . $value . '
', 'disabled' => '
' . $value . '
' ); } $json = getJSONobj (); if ($inJSON) return str_replace ( '"', '\"', $json->encode ( $arr ) ); else return $arr; } function create_new_list_query($order_by, $where, $filter = array(), $params = array(), $show_deleted = 0, $join_type = '', $return_array = false, $parentbean, $singleSelect = false) { echo ''; echo ''; echo ''; echo ''; if($_GET['show_empty_wz'])$where.='ecmsales.wz_name is null'; $ret=parent::create_new_list_query ( $order_by, $where, $filter, $params, $show_deleted, $join_type, $return_array, $parentbean, $singleSelect ); //$ret['from'].=" left outer join ecmstockdocouts as wz on wz.ecmsale_id=ecmsales.id"; //echo print_r($ret,true); return $ret; } static function CreateImgStatus($id, $status) { global $app_list_strings; return ''; } /** * BUILDS A GENERIC SEARCH BASED ON THE QUERY STRING USING OR. * DO NOT INCLUDE ANY $THIS-> BECAUSE THIS IS CALLED ON WITHOUT HAVING THE CLASS INSTANTIATED. */ function build_generic_where_clause($the_query_string) { $where_clauses = Array (); $the_query_string = PearDatabase::quote ( from_html ( $the_query_string ) ); array_push ( $where_clauses, "ecmsales.name like '$the_query_string%'" ); $the_where = ""; foreach ( $where_clauses as $clause ) { if ($the_where != "") $the_where .= " or "; $the_where .= $clause; } return $the_where; } function set_notification_body($xtpl, $simplemodule) { global $mod_strings, $app_list_strings; $xtpl->assign ( "NAME", $simplemodule->name ); $xtpl->assign ( "DESCRIPTION", $simplemodule->description ); return $xtpl; } function bean_implements($interface) { switch ($interface) { case 'ACL' : return true; } return false; } function save($check_notify = FALSE) { global $current_user; if (!$this->id || $this->id=='') { // generate number $this->number = $this->generateNumber(); $this->document_no = $this->formatNumber($this->number); } $this->vats_summary = htmlspecialchars($this->vats_summary); $return_id = parent::save ( $check_notify ); $this->savePositions($return_id); return $return_id; } // ***************************Start Managing Positions*************************// function constructInsertQuery($data, $table = '') { if ($table == '' && isset ( $this->object_name ) && $this->object_name != '') { $table = strtolower ( $this->object_name ) . "items"; } else return ""; $keys = array (); $values = array (); foreach ( $data as $key => $value ) { $keys [] = $key; if (is_array ( $value )) $values [] = $value [1] . str_replace ( "'", "\'", $value [0] ) . $value [1]; else $values [] = "'" . str_replace ( "'", "\'", $value ) . "'"; } $q = "insert into `$table` (`"; $q .= implode ( '`, `', $keys ); $q .= "`) values ("; $q .= implode ( ", ", $values ); $q .= ");"; return $q; } function savePositions($id = null, $position_list = null) { global $current_user, $timedate; if ($position_list == null) $position_list = $this->position_list; if ($id == null) $id = $this->id; if (count ( $position_list ) > 0) $this->deleteAssignedPositions ( $id ); $arr = array (); $position = 0; for($i = 0; $i < count ( $position_list ); $i ++) { if ($position_list [$i] ['name'] == '') continue; $p = $position_list [$i]; if (! empty ( $p ['category_id'] ) || $p ['category_id'] == '') { require_once ("modules/EcmProducts/EcmProduct.php"); $pr = new EcmProduct (); $pr->retrieve ( $p ['id'] ); $p ['category_id'] = $pr->product_category_id; } $arr = array ( 'id' => create_guid (), 'date_entered' => array ( 'NOW()', '' ), 'date_modified' => array ( 'NOW()', '' ), 'modified_user_id' => $current_user->id, 'assigned_user_id' => $current_user->id, 'created_by' => $current_user->id, 'deleted' => '0', strtolower ( $this->object_name ) . '_id' => $id, 'ecmproduct_id' => $p ['product_id'], 'position' => $position, 'code' => $p ['product_code'], 'name' => $p ['name'], 'quantity' => ((empty ( $p ['quantity'] ) || $p ['quantity'] == '') ? 0 : $p ['quantity']), 'price_start' => ((empty ( $p ['price_start'] ) || $p ['price_start'] == '') ? 0 : $p ['price_start']), 'price_netto' => ((empty ( $p ['price_netto'] ) || $p ['price_netto'] == '') ? 0 : $p ['price_netto']), 'price_brutto'=> ($p['price_netto']+($p['price_netto']*($p ['ecmvat_name']/100))), 'total_brutto'=> ($p['total_netto']+($p['total_netto']*($p ['ecmvat_name']/100))), 'discount' => ((empty ( $p ['discount'] ) || $p ['discount'] == '') ? 0 : $p ['discount']), 'total_netto' => ((empty ( $p ['total_netto'] ) || $p ['total_netto'] == '') ? 0 : $p ['total_netto']), 'dd_unit_id' => $p ['unit_id'], 'dd_unit_name' => $p['unit_name'], 'ecmvat_id' => $p ['ecmvat_id'], 'ecmvat_name' => $p ['ecmvat_name'], 'ecmvat_value' => $p ['ecmvat_value'], 'ecmproductcategory_id' => $p ['category_id'], 'recipient_code' => $p ['recipient_code'], 'ean' => $p['product_ean'], 'brand_label' => $p['product_brand_label'], 'description' => $p['product_description'], ); if (isset($p['product_production_date']) && strlen($p['product_production_date']) > 5) { $arr['production_date'] = $p['product_production_date']; } // else { // $arr['production_date'] = null; //} $this->db->query ( $this->constructInsertQuery ( $arr ) ); $this->db->query("INSERT INTO log VALUES ('".mysql_escape_string($this->constructInsertQuery ( $arr ))."')"); $position ++; } } function getPosition($position) { if (! is_array ( $position )) return ''; global $timedate; $return_array = array (); $return_array ['product_id'] = $position ['ecmproduct_id']; $return_array ['position'] = $position ['position']; $return_array ['product_code'] = $position ['code']; $return_array ['name'] = $position ['name']; $return_array ['quantity'] = $position ['quantity']; $return_array ['price_start'] = $position ['price_start']; $return_array ['price_netto'] = $position ['price_netto']; $return_array ['price_sell'] = $position ['price_start']; $return_array ['price_total_sell'] = $position ['total_netto']; $return_array ['discount'] = $position ['discount']; $return_array ['total_netto'] = $position ['total_netto']; $return_array ['total_brutto'] = $position ['total_brutto']; $return_array ['unit_id'] = $position ['dd_unit_id']; $return_array ['unit_name'] = $position ['dd_unit_name']; $return_array ['ecmvat_id'] = $position ['ecmvat_id']; $return_array ['ecmvat_name'] = $position ['ecmvat_name']; $return_array ['ecmvat_value'] = $position ['ecmvat_value']; $return_array ['recipient_code'] = $position ['recipient_code']; $return_array ['product_supplier_code'] = $position ['recipient_code']; $return_array ['product_ean'] = $position ['ean']; $return_array ['product_brand_label'] = $position ['brand_label']; $return_array ['product_description'] = $position ['description']; $return_array ['product_production_date'] = $position ['production_date']; $ecmStockOperations = new EcmStockOperation(); $return_array ['stock_state']=($ecmStockOperations->getRealStock($position ['ecmproduct_id'])); $return_array ['reservation']=$return_array ['stock_state']; return $return_array; } function getPositionList($array = false) { if (isset ( $this->id ) && $this->id != '') { $query = "SELECT * FROM `" . strtolower ( $this->object_name ) . "items` WHERE `" . strtolower ( $this->object_name ) . "_id`='" . $this->id . "' order by position asc"; $r = $this->db->query ( $query ); $return_array = array (); if ($r) { while ( $w = $this->db->fetchByAssoc ( $r ) ) { $return_array [] = $this->getPosition ( $w ); } $json = getJSONobj (); return $array ? $return_array : $json->encode ( $return_array ); } } return $array ? false : '[]'; } function deleteAssignedPositions() { if (isset ( $this->id ) && $this->id != '') { $query = "DELETE FROM `" . strtolower ( $this->object_name ) . "items` WHERE `" . strtolower ( $this->object_name ) . "_id`='" . $this->id . "'"; $r = $this->db->query ( $query ); if ($r) return true; } return false; } function formatPositions($position_list) { return; if (! is_array ( $position_list ) || count ( $position_list ) == 0) return false; global $app_list_strings; require_once ('modules/Currencies/Currency.php'); foreach ( $position_list as $key => $value ) { $position_list [$key] ['unit_id'] = $app_list_strings ['ecmproducts_unit_dom'] [$value ['unit_id']]; $position_list [$key] ['category_id'] = $app_list_strings ['ecmproducts_category_dom'] [$value ['category_id']]; // $position_list[$key]['vat_id'] = format_number($value['vat_id']).'%'; $position_list [$key] ['discount'] = format_number ( $value ['discount'] ) . '%'; if (isset ( $currency ) && ($currency->id == $this->currency_id)) { } else { $currency = new Currency (); $currency->retrieve ( $this->currency_id ); } $position_list [$key] ['price'] = format_number ( $value ['price'] ) . ' ' . $currency->iso4217; $position_list [$key] ['total'] = format_number ( $value ['total'] ) . ' ' . $currency->iso4217; // $position_list[$key]['price'] = format_number($value['price']).' PLN'; // $position_list[$key]['total'] = format_number($value['total']).' PLN'; $this->currency_symbol = $currency->iso4217; } return $position_list; } function sendSoap($id){ ini_set ( "soap.wsdl_cache_enabled", "0" ); require_once ("nusoap/nusoap.php"); $soapUrl = 'http://system.saas-systems.pl/soap.php?wsdl'; $soapUser = 'admin'; $soapPassword = 'rudemodz123'; $client = new nusoap_client ( $soapUrl, 'wsdl' ); $login_parameters = array ( 'user_auth' => array ( 'user_name' => $soapUser, 'password' => md5 ( $soapPassword ), 'version' => '1' ), 'application_name' => 'SoapTest', 'name_value_list' => array () ); $login_result = $client->call ( 'login', $login_parameters ); if ($login_result ['id'] != '') { $session_id = $login_result ['id']; $sdi = new EcmSale(); $sdi->retrieve($id); $sdi_fields = array (); $sdi_fields [] = array ( "name" => 'id', "value" => $sdi->edi_zs_id ); $sdi_fields [] = array ( "name" => 'edi_zs_id', "value" => $sdi->id ); $sdi_fields [] = array ( "name" => 'edi_zs_document_no', "value" => $sdi->document_no ); $set_entry_parameters = array ( // session id "session" => $session_id, // The name of the module from which to retrieve records. "module_name" => "EcmSales", // Record attributes "name_value_list" => $sdi_fields ) ; $set_entry_result = $client->call ( "set_entry", $set_entry_parameters ); } } // ***************************End Managing Positions*************************// function ACLAccess($view, $is_owner = 'not_set') { global $current_user; $file = 'modules/EcmGroupSales/EcmGroupSale.php'; if (file_exists ( $file )) { require_once ($file); $cc = EcmGroupSale::loadSettings ( true ); } else return true; if (is_admin ( $current_user )) { switch ($view) { case 'confirming' : return ($this->status == "s20"); case 'send_to_confirm' : return ($this->status == "s10"); case 'pdf_toolbar' : return ($this->status != "s10" && $this->status != "s20" && $this->status != "s40"); } return true; } if ($is_owner == 'not_set') { $is_owner = $this->isOwner ( $current_user->id ); } // if we don't implent acls return true if (! $this->bean_implements ( 'ACL' )) return true; $view = strtolower ( $view ); if ($cc ['user_manager_role']) { // Manager switch ($view) { case 'list' : case 'index' : case 'listview' : return ACLController::checkAccess ( $this->module_dir, 'list', true ); case 'edit' : case 'save' : case 'popupeditview' : case 'editview' : return (ACLController::checkAccess ( $this->module_dir, 'edit', $is_owner )); case 'view' : case 'detail' : case 'detailview' : return ACLController::checkAccess ( $this->module_dir, 'view', $is_owner ); case 'delete' : return ACLController::checkAccess ( $this->module_dir, 'delete', $is_owner ); case 'export' : return ACLController::checkAccess ( $this->module_dir, 'export', $is_owner ); case 'import' : return ACLController::checkAccess ( $this->module_dir, 'import', true ); case 'send_to_confirm' : return ($this->status == "s10"); case 'can_commit' : return true; case 'confirming' : return ($this->status == "s20"); case 'auto_commiting' : return true; case 'pdf_toolbar' : return ($this->status != "s10" && $this->status != "s20" && $this->status != "s40"); } } else if ($cc ['user_representative_extra_role']) { // Representative Extra switch ($view) { case 'list' : case 'index' : case 'listview' : return ACLController::checkAccess ( $this->module_dir, 'list', true ); case 'edit' : return (ACLController::checkAccess ( $this->module_dir, 'edit', $is_owner ) && ($this->status == "s10" || $this->status == "s40")); case 'save' : case 'popupeditview' : case 'editview' : return (ACLController::checkAccess ( $this->module_dir, 'edit', $is_owner )); case 'view' : case 'detail' : case 'detailview' : return ACLController::checkAccess ( $this->module_dir, 'view', $is_owner ); case 'delete' : return (ACLController::checkAccess ( $this->module_dir, 'delete', $is_owner ) && $this->status == "s10"); case 'export' : return ACLController::checkAccess ( $this->module_dir, 'export', $is_owner ); case 'import' : return ACLController::checkAccess ( $this->module_dir, 'import', true ); case 'quote_to_sale' : case 'quote_to_invoice' : return ($this->status != "s10" && $this->status != "s20" && $this->status != "s40" && $this->status != "s60"); case 'send_to_confirm' : return ($this->status == "s10"); case 'send_email' : return ($this->status != "s10" && $this->status != "s20" && $this->status != "s40"); case 'can_commit' : return true; case 'confirming' : return false; case 'auto_commiting' : return true; case 'pdf_toolbar' : return ($this->status != "s10" && $this->status != "s20" && $this->status != "s40"); } } else if ($cc ['user_representative_role']) { // Representative switch ($view) { case 'list' : case 'index' : case 'listview' : return ACLController::checkAccess ( $this->module_dir, 'list', true ); case 'edit' : return (ACLController::checkAccess ( $this->module_dir, 'edit', $is_owner ) && ($this->status == "s10" || $this->status == "s40")); case 'save' : case 'popupeditview' : case 'editview' : return (ACLController::checkAccess ( $this->module_dir, 'edit', $is_owner )); case 'view' : case 'detail' : case 'detailview' : return ACLController::checkAccess ( $this->module_dir, 'view', $is_owner ); case 'delete' : return (ACLController::checkAccess ( $this->module_dir, 'delete', $is_owner ) && $this->status == "s10"); case 'export' : return ACLController::checkAccess ( $this->module_dir, 'export', $is_owner ); case 'import' : return ACLController::checkAccess ( $this->module_dir, 'import', true ); case 'quote_to_sale' : case 'quote_to_invoice' : return ($this->status != "s10" && $this->status != "s20" && $this->status != "s40" && $this->status != "s60"); case 'send_to_confirm' : return ($this->status == "s10"); case 'send_email' : return ($this->status != "s10" && $this->status != "s20" && $this->status != "s40"); case 'can_commit' : return false; case 'confirming' : return false; case 'auto_commiting' : return false; case 'pdf_toolbar' : return ($this->status != "s10" && $this->status != "s20" && $this->status != "s40"); } } // if it is not one of the above views then it should be implemented on the page level return true; } //mz generate number function generateNumber() { $db = $GLOBALS['db']; $r = $db->fetchByAssoc($db->query("SELECT count(id) as c FROM ecmsales WHERE YEAR(register_date)='".date('Y')."'")); if (!$r || !$r['c'] || $r['c']=='') $count = 0; else $count = intval($r['c']); $count++; //has 5 digits? $tmp = strval($count); while (strlen($tmp) < 5) $tmp = '0'.$tmp; return date("Ymd").$tmp; } function formatNumber($number) { $n = intval(substr($number, 8,5)); $y = substr($number,0,4); //has 3 digits? while (strlen($n) < 3) $n = '0'.$n; return 'ZS '.$n.'/'.$y; } function CreateQueryFromPost($array){ $field_array=array(); if($array['date_from']!='')$field_array[]="delivery_date>='".date("Y-m-d",strtotime($array['date_from']))."'"; if($array['date_to']!='')$field_array[]="delivery_date<='".date("Y-m-d",strtotime($array['date_to']))."'"; if($array['date_send_from']!='')$field_array[]="send_date>='".date("Y-m-d",strtotime($array['date_send_from']))."'"; if($array['date_send_to']!='')$field_array[]="send_date<='".date("Y-m-d",strtotime($array['date_send_to']))."'"; if($array['time_from']!='')$field_array[]="date_entered>='".date("Y-m-d",strtotime($array['time_from']))."'"; if($array['time_to']!='')$field_array[]="date_entered<='".date("Y-m-d",strtotime($array['time_to']))."'"; if($array['account_id']!='')$field_array[]="parent_id='".$array['account_id']."'"; if($array['account_name']!='')$field_array[]="parent_name like '".$array['account_name']."'"; if($array['parent_order_no']!='')$field_array[]="parent_document_no='".$array['parent_order_no']."'"; switch ($array ['sale_type']) { case 'all' : $field_array[] = "type IN ('sales_order', 'gratis')"; break; case 'sale' : $field_array[] = "type='sales_order'"; break; case 'gratis' : $field_array[] = "type='gratis'"; break; } if (count ( $field_array ) > 0) $where = " and " . implode ( " and ", $field_array ); else $where = ""; $z = "select * from ecmsales where deleted='0' and status!='s10' " . $where; if ($array['sale_type']=='all') $z.=" ORDER BY type DESC"; return $z; } function GetArrayResultFromQuery($query){ $db = $GLOBALS ['db']; $w = $db->query ($query ); echo mysql_error (); $bb = 0; $i=0; $result_array=array(); $sum_total_qty=0; $sum_total_netto=0; $sum_total_brutto=0; $sum_total_invoice=0; $sum_total_vat=0; $wal_query="select * from currency_nbp_archive order by date desc limit 3"; $ik=$db->query($wal_query); $wal=[]; while($walutki = $db->fetchByAssoc ( $ik)){ $wal[$walutki['currency_id']]=$walutki['value']; } while ( $r = $db->fetchByAssoc ( $w ) ) { $rrr = $db->fetchByAssoc ( $db->query ( "select id from ecmstockdocouts where ecmsale_id='" . $r ['id'] . "' and deleted='0'" ) ); if ($_REQUEST ['wz'] == 1 && $rrr ['id']) continue; $ww = $db->query ( "select quantity,price_netto as price,ecmvat_value from ecmsaleitems where ecmsale_id='" . $r ['id'] . "' and deleted='0'" ); $total_netto = 0; $total_brutto = 0; $total_invoice = 0; $total_vat = 0; $total_qty = 0; while ( $rr = $db->fetchByAssoc ( $ww ) ) { $total_qty += $rr ['quantity']; $total_netto += ($rr ['quantity'] * $rr ['price']); $total_brutto += $rr ['quantity'] * $rr ['price'] * (1 + $rr ['ecmvat_value'] / 100); $total_vat += $rr ['quantity'] * $rr ['price'] * ($rr ['ecmvat_value'] / 100); } if ($rrr ['id']) { $rinv = $db->fetchByAssoc ( $db->query ( "select id, total_netto from ecminvoiceouts where wz_id='" . $rrr ['id'] . "' AND deleted='0'" ) ); $total_invoice = $rinv ['total_netto']; // $wi=$db->query("select price,quantity from ecminvoiceoutitems where ecminvoiceout_id='".$rinv['id']."' and deleted='0'"); // while($ri=$db->fetchByAssoc($wi)){ // $total_invoice+=$ri['quantity']*$ri['price']; // } } else { $inv = null; $wi = null; $ri = null; $rwz = null; } $rsale = $db->fetchByAssoc ( $db->query ( "select sum(quantity*price_netto) as qty from ecmsaleitems where ecmsale_id='" . $r ['id'] . "'" ) ); $rwz = $db->fetchByAssoc ( $db->query ( "select id from ecmstockdocouts where ecmsale_id='" . $r ['id'] . "' and deleted='0'" ) ); $rwzi = $db->fetchByAssoc ( $db->query ( "select sum(quantity*price_sell) as qty from ecmstockdocoutitems where ecmstockdocout_id='" . $rwz ['id'] . "'" ) ); $ecmstockdocout_id = $rwz ['id']; if ($ecmstockdocout_id) { $sum_wz_qty += $rwzi ['qty']; $sum_sale_qty += $rsale ['qty']; } $qty_diff = $rwzi ['qty'] - $rsale ['qty']; $diff_minus = $diff_plus = 0; $rst = $rsale ['qty']; $rwt = $rwzi ['qty']; $percent = number_format ( (100 * $rwzi ['qty'] / $rsale ['qty']), 2, ",", "." ) . "%"; $order_total=0; $wz_total=0; $wz_green=0; $wz_red=0; if ($ecmstockdocout_id) { $pr=0; $wsale = $db->query ( "select quantity,price_netto as price,code,ecmproduct_id from ecmsaleitems where deleted='0' and ecmsale_id='" . $r ['id'] . "' order by code" ); while ( $rsale = $db->fetchByAssoc ( $wsale ) ) { $qty = 0; $wwz = $db->query ( "select quantity,price_sell from ecmstockdocoutitems where deleted='0' and ecmproduct_id='" . $rsale ['ecmproduct_id'] . "' and ecmstockdocout_id='" . $ecmstockdocout_id . "'" ); while ( $rwz = $db->fetchByAssoc ( $wwz ) ) { $qty += $rwz ['quantity'] * $rwz ['price_sell']; } if ($rsale ['quantity'] * $rsale ['price'] > $qty) $color = "red"; elseif ($rsale ['quantity'] * $rsale ['price'] < $qty) $color = "green"; else $color = "black"; if ($rsale ['quantity'] * $rsale ['price'] > $qty) $diff_minus += $qty - $rsale ['quantity'] * $rsale ['price']; if ($rsale ['quantity'] * $rsale ['price'] < $qty) $diff_plus += $qty - $rsale ['quantity'] * $rsale ['price']; $sum [$rsale ['ecmproduct_id']] ['wz'] += $qty; $sum [$rsale ['ecmproduct_id']] ['sale'] += $rsale ['quantity'] * $rsale ['price']; $rpro = $db->fetchByAssoc ( $db->query ( "select deliverydate,name from ecmproducts where id='" . $rsale ['ecmproduct_id'] . "'" ) ); $stock_q = $db->fetchByAssoc ( $db->query ( "select sum(quantity) as quantity from ecmstockoperations where product_id='" . $rsale ['ecmproduct_id'] . "'" ) ); if ($color == "red" && $rpro ['deliverydate'] != "0000-00-00") $eta = $rpro ['deliverydate']; else $eta = ""; $order=$rsale ['quantity'] * $rsale ['price']; $result_array[$i]['products'][$pr]['id']=$rsale ['ecmproduct_id']; $result_array[$i]['products'][$pr]['code']=$rsale ['code']; $result_array[$i]['products'][$pr]['name']=$rpro['name']; $result_array[$i]['products'][$pr]['stock']=$rpro['name']; $result_array[$i]['products'][$pr]['order']=$order; $result_array[$i]['products'][$pr]['quantity']=$stock_q['quantity']; $result_array[$i]['products'][$pr]['wz']=$qty; $result_array[$i]['products'][$pr]['eta']=$eta; //totals $order_total+=$order; $wz_total+=$qty; $pr++; } } if($r['type']!='gratis'){ // guziczki kochane $rwz = $db->fetchByAssoc ( $db->query ( "select id from ecmstockdocouts where ecmsale_id='" . $r ['id'] . "' and deleted='0'" ) ); $rfv = $db->fetchByAssoc ( $db->query ( "select id,document_no from ecminvoiceouts where wz_id='" . $rwz ['id'] . "' and deleted='0' and canceled='0'" ) ); if ($rwz ['id'] && $rfv ['id']) { $sw='yes'; $sw_id=$rfv ['id']; $sw_nr=$rfv ['document_no']; } elseif ($rwz ['id'] && ! $rfv ['id']) { $sw_id=$rwz ['id']; $sw='no'; } else { $tmp = ''; $sw='none'; $sw_id=''; } $t .= $tmp; $rrr = $db->fetchByAssoc ( $db->query ( "select id,document_no from ecmstockdocouts where ecmsale_id='" . $r ['id'] . "' and deleted='0'" ) ); if ($rrr ['id']) { $ed = "disabled"; $title = $rrr ['document_no']; $wz_idd=$rrr['id']; } else { $onclick = ' onclick="javascript:window.open(\'index.php?module=EcmStockDocOuts&action=EditView&parent_doc_type=EcmSales&parent_doc_id=' . $r ['id'] . '\',\'_newtab\');"'; $ed = "enabled"; $title = "Create WZ"; } } else { $rw = $db->fetchByAssoc ( $db->query ( "select id,document_no from ecmstockdocinsideouts where ecmsale_id='" . $r ['id'] . "'" ) ); if($rw['id']!=''){ $rwed = "disabled"; $rw_t = $rw ['document_no']; $rw_id=$rw['id']; } else { $rwonclick = ' onclick="javascript:window.open(\'index.php?module=EcmStockDocinsideOuts&action=EditView&parent_doc_type=EcmSales&parent_doc_id=' . $r ['id'] . '\',\'_newtab\');"'; $rwed = "enabled"; $rw_t = "Utwórz RW"; } } $result_array[$i]['wz_switch']=$ed; $result_array[$i]['wz_name']=$title; $result_array[$i]['wz_id']=$wz_idd; $result_array[$i]['rw_switch']=$rwed; $result_array[$i]['rw_name']=$rw_t; $result_array[$i]['rw_id']=$rw_id; $result_array[$i]['type']=$r['type']; $result_array[$i]['fv_switch']=$sw; $result_array[$i]['fv_id']=$sw_id; $result_array[$i]['fv_name']=$sw_nr; $result_array[$i]['products']['order_total']=$order_total; $result_array[$i]['products']['wz_total']=$wz_total; $result_array[$i]['products']['minus']=$diff_minus; $result_array[$i]['products']['plus']=$diff_plus; $result_array[$i]['position']=$i+1; $result_array[$i]['id']=$r['id']; $result_array[$i]['number']=$r['number']; $result_array[$i]['document_no']=$r['document_no']; $result_array[$i]['parent_name']=$r['parent_name']; $result_array[$i]['parent_id']=$r['parent_id']; $result_array[$i]['delivery_date']=$r['delivery_date']; $result_array[$i]['send_date']=$r['send_date']; $result_array[$i]['send_accepted']=$r['send_accepted']; $result_array[$i]['quantity']=$total_qty ; $result_array[$i]['total_netto']=$total_netto ; $result_array[$i]['total_brutto']=$total_brutto ; $result_array[$i]['total_vat']=$total_vat ; $result_array[$i]['total_invoice']=$total_invoice ; $result_array[$i]['percent']=$percent; $result_array[$i]['currency']=$r['currency_id']; $i++; $sum_total_qty += $total_qty; $sum_total_netto += $total_netto * ($r['currency_id']!='PLN' ? $wal[$r['currency_id']] : 1); $sum_total_brutto += $total_brutto * ($r['currency_id']!='PLN' ? $wal[$r['currency_id']] : 1); $sum_total_invoice += $total_invoice * ($r['currency_id']!='PLN' ? $wal[$r['currency_id']] : 1); $sum_total_vat += $total_vat * ($r['currency_id']!='PLN' ? $wal[$r['currency_id']] : 1); $percent = (100 * $sum_wz_qty / $sum_sale_qty); } $result_array['total_quantity']=$sum_total_qty; $result_array['total_netto']=$sum_total_netto; $result_array['total_brutto']=$sum_total_brutto; $result_array['total_invoice']=$sum_total_invoice; $result_array['total_vat']=$sum_total_vat; $result_array['total_percent']=$percent; $rst = 0; $rwt = 0; $diff_plus = $diff_minus = 0; $c1=0; $ww = $db->query ( "select id from ecmproducts where deleted='0' order by code asc" ); while ( $rr = $db->fetchByAssoc ( $ww ) ) { $k = $rr ['id']; if (! $sum [$k]) continue; $rpro = $db->fetchByAssoc ( $db->query ( "select code,deliverydate from ecmproducts where id='" . $k . "'" ) ); if ($sum [$k] ['wz'] < $sum [$k] ['sale']) $color = "red"; elseif ($sum [$k] ['wz'] > $sum [$k] ['sale']) $color = "green"; else $color = "black"; $rst += $sum [$k] ['sale']; $rwt += $sum [$k] ['wz']; if ($sum [$k] ['sale'] > $sum [$k] ['wz']) $diff_minus += $sum [$k] ['wz'] - $sum [$k] ['sale']; if ($sum [$k] ['sale'] < $sum [$k] ['wz']) $diff_plus += $sum [$k] ['wz'] - $sum [$k] ['sale']; if ($color == "red" && $rpro ['deliverydate'] != "0000-00-00") $eta = $rpro ['deliverydate']; else $eta = ""; $result_array['total_product'][$c1]['code']=$rpro ['code']; $result_array['total_product'][$c1]['id']=$k; $result_array['total_product'][$c1]['order']=$sum [$k] ['sale']; $result_array['total_product'][$c1]['wz']=$sum [$k] ['wz']; $result_array['total_product'][$c1]['eta']=$eta; $c1++; } $result_array['total_product']['order_total']=$rst; $result_array['total_product']['wz_total']=$rwt; $result_array['total_product']['minus']=$diff_minus; $result_array['total_product']['plus']=$diff_plus; return $result_array; } function createPdfFileName($format=true) { global $mod_strings; $arr1 = Array('\\', '/', ':', '*', '?' , '"', '<', '>', '|', ' '); $arr2 = Array('', '', '', '', '', '\'', '[', ']', '', '_'); $tmp = $this->document_no; if($format) $tmp = str_replace($arr1, $arr2, $mod_strings['LBL_PDF_FILENAME'].$tmp.'.pdf'); else $tmp = $mod_strings['LBL_PDF_FILENAME'].$tmp.'.pdf'; //$mod = return_module_language($current_language, 'EcmInvoiceOuts'); //return urlencode( // return $mod['LBL_PDF_INVOICE_FILE_NAME'].$tmp.'.pdf';//); return $tmp; //); } function UploadXML(){ $allowedExts = array("xml"); $temp = explode(".", $_FILES["file"]["name"]); $extension = end($temp); $name=date("Y_d_m").str_replace(" ","",str_replace("_","",str_replace(".","",microtime()))).'.'.$extension; if ($_FILES["file"]["error"] > 0) { return '0'; } else { if (file_exists("modules/EcmSales/upload_xml/" . $_FILES["file"]["name"])) { return '0'; } else { move_uploaded_file($_FILES["file"]["tmp_name"], "modules/EcmSales/upload_xml/" . $name); return $name; } } } function CreateMultiPDF($post){ ini_set('max_execution_time', 9999999999); $filename=array(); global $current_user; foreach($post as $id){ $strPath = dirname ( __FILE__ ) . "\\"; if($id=='')continue; $this->retrieve ( $id ); // $pdf2 = new PDFMerger; //$ab [] = $this->createPdfFileName (); $ch = curl_init (); curl_setopt ( $ch, CURLOPT_URL, 'https://'.$_SERVER['SERVER_ADDR'].'/index.php?action=Authenticate&module=Users&return_module=Users&return_action=Login&user_name=db&user_password=rudemodz&login_theme=Sugar&login_language=en_us' ); // curl_setopt($ch, CURLOPT_POSTFIELDS,'user_name=db&user_password='.$pass.''); curl_setopt ( $ch, CURLOPT_POST, 1 ); curl_setopt ( $ch, CURLOPT_HEADER, 0 ); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); curl_setopt ( $ch, CURLOPT_FOLLOWLOCATION, 1 ); curl_setopt ( $ch, CURLOPT_COOKIEJAR, 'cookie.txt' ); curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, 1 ); curl_setopt ( $ch, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.3) Gecko/20070309 Firefox/2.0.0.3" ); curl_setopt ( $ch, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.3) Gecko/20070309 Firefox/2.0.0.3" ); $page = curl_exec ( $ch ); // echo $pass = md5('rudemodz'); $up = 'https://'.$_SERVER['SERVER_ADDR'].'/index.php?module=EcmSales&action=createPDF&to_pdf=1&show_img=0&show_ean=0&show_ean2=0&show_recipient_code=0&record=' . $id . ''; curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, true ); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); curl_setopt ( $ch, CURLOPT_URL, $up ); $page = curl_exec ( $ch ); $fp = fopen ( 'pdftmp/' . $this->createPdfFileName () . '', 'w' ); fwrite ( $fp, $page ); fclose ( $fp ); $filename [] = $this->createPdfFileName (); } $fp = fopen ( 'generatorfifi_'.$current_user->user_name.'.php', 'w' ); $s = "user_name .'_'. date ( "hysmd" ); foreach ( $filename as $k ) { $s .= "->addPDF('pdftmp/" . $k . "', 'all')\n"; } $s .= "->merge('file', 'pdftmp/" . $file; $s .= ".pdf');"; // $b=microtime(); fwrite ( $fp, $s ); fclose ( $fp ); // echo microtime(); $up = 'https://'.$_SERVER['SERVER_ADDR'].'/generatorfifi_'.$current_user->user_name.'.php'; curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, true ); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); curl_setopt ( $ch, CURLOPT_URL, $up ); $page = curl_exec ( $ch ); return $file.'.pdf'; } } ?>