'notes', ); function EcmStockDocIn() { parent::SugarBean (); $this->setupCustomFields ( 'EcmStockDocIns' ); 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 .= "ecmstockdocins.* ,users.user_name as assigned_user_name"; if($custom_join) { $query .= $custom_join['select']; } $query .= " FROM ecmstockdocins LEFT JOIN users ON ecmstockdocins.assigned_user_id=users.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($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 ecmstockdocins.name"; return $query; } function create_export_query($order_by, $where) { $custom_join = $this->custom_fields->getJOIN (); $query = "SELECT ecmstockdocins.*, users.user_name assigned_user_name"; if ($custom_join) { $query .= $custom_join ['select']; } $query .= " FROM ecmstockdocins "; $query .= " LEFT JOIN users ON ecmstockdocins.assigned_user_id=users.id"; if ($custom_join) { $query .= $custom_join ['join']; } $query .= ""; $where_auto = " ecmstockdocins.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 ecmstockdocins.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 ); } 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, 'EcmStockDocIns' ); $the_array = parent::get_list_view_data (); //get stocks 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'] ); $the_array ['TOTAL_NETTO'] = $tmp['total'] ; } $this->retrieve($this->id); $the_array['PARENT_NAME'] =''.$this->parent_name.''; $the_array['STOCK_NAME'] = $this->stock_name; $the_array['DOCUMENT_AUTOINCREMENT']=date('d.m.Y',strtotime($this->register_date)); $the_array['NUMBER']=''.$this->document_no.''; //create image options $u=new User(); $u->retrieve($this->created_by); $the_array['CREATED_BY'] =''.$u->first_name.' '.$u->last_name.''; unset($u); $op = ''; $the_array['OPTIONS'] = $op; return $the_array; } function getPriceFromDocument($product){ $zap=$this->db->query("select quantity,price,total from ecmstockdocinitems where id='".$product."'"); $dane=$this->db->fetchByAssoc($zap); return $dane; } function getStatusMenuInfo($inJSON = true) { global $app_list_strings; $arr = array (); foreach ( $app_list_strings ['ecmstockdocins_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 ''; return parent::create_new_list_query ( $order_by, $where, $filter, $params, $show_deleted, $join_type, $return_array, $parentbean, $singleSelect ); } 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, "ecmstockdocins.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->fromREST) { $current_user->id = '86e2871a-9d00-f756-6bba-59cce0c5db59'; } // generate number require_once ('modules/Accounts/Account.php'); $ac = new Account(); $ac->retrieve ($this->parent_id); if($this->parent_address_street=='' && $this->parent_address_city=='' && $this->parent_address_postalcode==''){ $this->parent_address_street=$ac->billing_address_street; $this->parent_address_city=$ac->billing_address_city; $this->parent_address_postalcode=$ac->billing_address_postalcode; $this->parent_address_country=$ac->billing_address_country; $this->parent_nip=$ac->to_vatid; } //add mz //get number format 2015-05-26 require_once('modules/EcmSysInfos/EcmSysInfo.php'); $EcmSysInfo = new EcmSysInfo(); $template = $EcmSysInfo->getFormatNumberForModule('EcmStockDocIns'); unset($EcmSysInfo); global $current_user; if (!$this->id || $this->id=='') { if ($template != "") { require_once('include/ECM/EcmDocumentNumberGenerator/EcmDocumentNumberGenerator.inc.php'); $dng = new EcmDocumentNumberGenerator('EcmStockDocIns',$this->register_date); $this->document_no= $dng->parseNumber($template, $this->stock_id); } } if($this->new_with_id==true){ require_once('modules/EcmSysInfos/EcmSysInfo.php'); $EcmSysInfo = new EcmSysInfo(); $template = $EcmSysInfo->getFormatNumberForModule('EcmStockDocIns'); if ($template != "") { require_once('include/ECM/EcmDocumentNumberGenerator/EcmDocumentNumberGenerator.inc.php'); $dng = new EcmDocumentNumberGenerator('EcmStockDocIns',$this->register_date); $this->document_no= $dng->parseNumber($template, $this->stock_id); } } $this->status = 'accepted'; $aa=explode('/',$this->document_no); $this->document_autoincrement=date("Ymd",strtotime($this->register_date)).''.sprintf('%03d',(string)((int)$aa[0])); $return_id = parent::save ( $check_notify ); if($this->new_with_id==true){ if($this->position_list!=''){ $this->position_list=unserialize($this->position_list); } $this->savePositionsSoap($return_id); $this->addDocument(); } else { $this->savePositions($return_id); } $this->setEcmPurchaseOrderStatus($this->po_id); //update total $db = $GLOBALS['db']; $r = $db->fetchByAssoc($db->query("SELECT sum(total) as sum FROM ecmstockdocinitems WHERE ecmstockdocin_id='$this->id' and deleted='0'")); $db->query("UPDATE ecmstockdocins SET total='".$r['sum']."' WHERE id='$this->id'"); if (!$this->fromREST) { header("Location: index.php?module=Documents&action=EditView&return_module=EcmStockDocIns&parent_type=EcmStockDocIns&ecmstockdocin_id=".$return_id); } return $return_id; } function addDocument(){ $doc = new Document(); $doc->document_name = $this->name; $doc->value=$this->total_brutto; $doc->left_paid=$this->total_brutto; $doc->category_id='return_note'; $doc->status=0; $doc->currency_id='PLN'; $doc->document_date=$this->register_date; $doc->active_date=$this->register_date; $doc->document_type='k'; $date = new DateTime($this->register_date); $date->modify("+120 days"); $doc->payment_date=$date->format("d.m.Y"); unset($_POST['parent_id']); $_POST['list_id'][0]=create_guid(); $_POST['parent_name'][0]=$this->parent_name; $_POST['parent_type'][0]='Accounts'; $_POST['parent_id'][0]=$this->parent_id; $_POST['list_id'][1]=create_guid(); $_POST['parent_name'][1]=$this->document_no; $_POST['parent_type'][1]='EcmStockDocIns'; $_POST['parent_id'][1]=$this->id; $vats = explode (",",$this->vats_summary); $_POST['tblAppendGrid_rowOrder']=''; $total=0; foreach ($vats as $key=>$value){ $stawka = explode (":",$value); if($stawka[0]!='undefined'){ if($stawka[1]!=''){ $vat = str_replace("%","",$stawka[0]); $netto = $stawka[1]/($vat/100); $_POST['tblAppendGrid_netto_' . $key]=$stawka[1]; $_POST['tblAppendGrid_vat_' . $key]=$stawka[2]; $_POST['tblAppendGrid_vat_id_' . $key]=$vat; $_POST['tblAppendGrid_vat_value_' . $key]=$stawka[0]; $_POST['tblAppendGrid_rowOrder'].=$key.','; $total=$total+($stawka[3]); } } } $doc->value=$total; $doc->left_paid=$total; $doc->save(); } function setEcmPurchaseOrderStatus($id){ $db = $GLOBALS['db']; $r = $db->fetchByAssoc($db->query("SELECT sum(quantity) as sum FROM ecmpurchaseorderitems WHERE ecmpurchaseorder_id='".$id."' and deleted='0'")); $db = $GLOBALS['db']; $r2 = $db->fetchByAssoc($db->query("SELECT sum(quantity) as sum FROM ecmstockdocinitems WHERE ecmstockdocin_id='".$this->id."' and deleted='0'")); if($r2['sum']==$r['sum']){ $db->query("UPDATE ecmpurchaseorders SET status='completed' WHERE id='$id'"); } else { $db->query("UPDATE ecmpurchaseorders SET status='partly_implemented' WHERE id='$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 .= ");"; $GLOBALS['db']->query("INSERT INTO log VALUES ('".mysql_real_escape_string($q)."')"); return $q; } function savePartNumber(){ $db = $GLOBALS['db']; $query="select value1 from operating_values where name='ecmproductsCodeIncrement' and id='1'"; $zap=$db->query($query); $res=$db->fetchByAssoc($zap); if($res['value1']==''){ $res['value1']=1; } else { $res['value1']++; } $query="update operating_values set value1='".$res['value1']."' where id='1'"; $db->query($query); return $res['value1']; } function savePositionsSoap($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]; require_once ("modules/EcmProducts/EcmProduct.php"); $pr = new EcmProduct (); $pr->retrieve_by_string_fields ( ['code'=>$p['product_code']] ); $p ['category_id'] = $pr->product_category_id; $p ['product_id']=$pr->id; $item_id = create_guid(); require_once ("modules/EcmProducts/EcmProduct.php"); $arr = array ( 'id' => $item_id, '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' => $pr->id, 'position' => $position, 'code' => $p ['product_code'], 'name' => $pr->name, 'price'=> ((empty ( $p ['price_netto'] ) || $p ['price_netto'] == '') ? 0 : $p ['price_netto']), 'price_fk'=> ((empty ( $p ['price_fk'] ) || $p ['price_fk'] == '') ? 0 : $p ['price_fk']), 'quantity' => ((empty ( $p ['quantity'] ) || $p ['quantity'] == '') ? 0 : $p ['quantity']), 'ecmvat_id' => $p ['ecmvat_id'], 'ecmvat_name' => $p ['ecmvat_name'], 'ecmvat_value' => $p ['ecmvat_value'], 'palet' => $p['palet'], 'waga' => $p['waga'], 'clo' => $p['clo'], 'dd_unit_id' => $p ['unit_id'], 'dd_unit_name' => $p['unit_name'], 'ecmproductcategory_id' => $p ['category_id'], 'is_consignment' => $p['product_is_consignment'], ); $p['price']=$p ['price_netto']; $p['ecmproduct_id'] = $p['product_id']; $this->db->query ( $this->constructInsertQuery ( $arr ) ); $this->db->query("update ecmproducts set srp_price='" . $p['price_netto'] . "' where id='" . $p['product_id'] . "'"); $query="update ecmproductcomponents set single_price='".$p['price_netto']."' where ecmcomponent_id='".$pr->id."'"; $this->db->query($query); $this->db->query("update ecmstockdocinitems set price='" . $p['price_netto'] . "',total='" . ($p['price_netto'] * $p['quantity']) . "' where id='" . $item_id . "'"); $this->insertProductsToStock ( $p, $id, $this->stock_id, $item_id); $position ++; } } 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]; require_once ("modules/EcmProducts/EcmProduct.php"); $pr = new EcmProduct (); $pr->retrieve ( $p ['product_id'] ); $p ['category_id'] = $pr->product_category_id; unset($pr); $item_id = create_guid(); require_once ("modules/EcmProducts/EcmProduct.php"); $arr = array ( 'id' => $item_id, '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'], 'price'=> ((empty ( $p ['price'] ) || $p ['price'] == '') ? 0 : $p ['price']), 'price_fk'=> ((empty ( $p ['price_fk'] ) || $p ['price_fk'] == '') ? 0 : $p ['price_fk']), 'quantity' => ((empty ( $p ['quantity'] ) || $p ['quantity'] == '') ? 0 : $p ['quantity']), 'ecmvat_id' => $p ['ecmvat_id'], 'ecmvat_name' => $p ['ecmvat_name'], 'ecmvat_value' => $p ['ecmvat_value'], 'palet' => $p['palet'], 'waga' => $p['waga'], 'clo' => $p['clo'], 'dd_unit_id' => $p ['unit_id'], 'dd_unit_name' => $p['unit_name'], 'ecmproductcategory_id' => $p ['category_id'], 'is_consignment' => $p['product_is_consignment'], ); $p['ecmproduct_id'] = $p['product_id']; $this->db->query ( $this->constructInsertQuery ( $arr ) ); $this->db->query("update ecmproducts set srp_price='" . $p['price'] . "' where id='" . $p['product_id'] . "'"); $query="update ecmproductcomponents set single_price='".$p['price']."' where ecmcomponent_id='".$p['product_id']."'"; $this->db->query($query); $this->db->query("update ecmstockdocinitems set price='" . $p['price'] . "',total='" . ($p['price'] * $p['quantity']) . "' where id='" . $item_id . "'"); $this->insertProductsToStock ( $p, $id, $this->stock_id, $item_id); $position ++; } } function getPosition($position) { if (! is_array ( $position )) return ''; global $timedate,$app_list_strings; $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'] = $position ['price']; $return_array ['price_fk'] = $position ['price_fk']; $return_array ['palet'] = $position ['palet']; $return_array ['waga'] = $position ['waga']; $return_array ['clo'] = $position ['clo']; $return_array ['total'] = $position ['total']; $return_array ['ecmvat_id'] = $position ['ecmvat_id']; $return_array ['ecmvat_name'] = $position ['ecmvat_name']; $return_array ['ecmvat_value'] = $position['ecmvat_value']; $return_array ['unit_id'] = $position ['dd_unit_id']; $return_array ['unit_name'] = $position ['dd_unit_name']; $return_array ['product_is_consignment'] = $position ['is_consignment']; $return_array['unit_precision'] = $app_list_strings['ecmproducts_unit_dom_precision'][$position ['dd_unit_id']]; $return_array['product_precision'] = $app_list_strings['ecmproducts_unit_dom_precision'][$position ['dd_unit_id']]; //check consignments $p = new EcmProduct(); $p->retrieve($position['ecmproduct_id']); //get consignments if ($p->is_consignment) { $c = $GLOBALS['db']->fetchByAssoc($GLOBALS['db']->query("SELECT IFNULL(part_no, '.') as part_no FROM ecmstockoperations WHERE documentitem_id='".$position['id']."'")); $return_array['part_no'] = $c['part_no']; } unset($p); 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; } // ***************************End Managing Positions*************************// //begin stock function insertProductsToStock($pl, $return_id, $stock_id, $itemid, $consignments = NULL) { require_once("modules/EcmStockOperations/EcmStockOperation.php"); $o = new EcmStockOperation(); global $app_list_strings; require_once("modules/EcmProducts/EcmProduct.php"); $o->product_id = $pl['ecmproduct_id']; $p = new EcmProduct(); $p->retrieve($pl['ecmproduct_id']); $o->product_code = $p->code; $o->product_name = $p->name; require_once("modules/EcmStocks/EcmStock.php"); $o->stock_id = $stock_id; $s = new EcmStock(); $s->retrieve($stock_id); $o->stock_name = $s->name; $o->parent_id = $return_id; $r = $GLOBALS['db']->fetchByAssoc($GLOBALS['db']->query("select document_no from ecmstockdocins where id='" . $return_id . "'")); $o->parent_name = $r['document_no']; $o->parent_type = "EcmStockDocIns"; //consignment if ($pl['product_is_consignment'] == '1') $o->part_no = $pl['product_consignment_part']; //$GLOBALS['db']->query("INSERT INTO log VALUES ('".$pl['quantity']."')"); $o->quantity = round($pl['quantity'],$app_list_strings['ecmproducts_unit_dom_precision'][$pl ['unit_id']]); $o->price = str_replace(",", ".", str_replace(".", "", $pl['price'])); $o->documentitem_id = $itemid; $o->type = 0; $oid = $o->save(); $GLOBALS['db']->query("update ecmstockoperations set price='" . $pl['price'] . "' where id='" . $oid . "'"); require_once("modules/EcmStockStates/EcmStockState.php"); $ss = new EcmStockState(); $ss->UpdateStockState($o->stock_id, $o->product_id); } //end stock 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($date) { $db = $GLOBALS['db']; $r = $db->fetchByAssoc($db->query("SELECT count(id) as c FROM ecmstockdocins WHERE deleted='0' AND YEAR(register_date)='".date('Y',strtotime($date)) ."'")); 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',strtotime($date)). $tmp; } function generateDocNumberStock($stock,$date) { $db = $GLOBALS['db']; $r = $db->fetchByAssoc($db->query("SELECT count(id) as c FROM ecmstockdocins WHERE deleted='0' AND YEAR(register_date)='".date('Y',strtotime($date))."' AND stock_id='".$stock."'")); $r2 = $db->fetchByAssoc($db->query("SELECT no FROM ecmstocks WHERE id='".$stock."'")); if (!$r || !$r['c'] || $r['c']=='') $count = 0; else $count = intval($r['c']); $count++; $tmp = strval($count); while (strlen($tmp) < 5) $tmp = '0'.$tmp; $number=date("Ymd",strtotime($date)).$tmp; $n = intval(substr($number, 8,5)); $y = substr($number,0,4); //has 3 digits? while (strlen($n) < 3) $n = '0'.$n; if($r2['no']!='')return ''.$n.'/'.$r2['no'].'/'.$y; else return ''.$n.'/'.$y; } 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 ''.$n.'/'.$y; } public static function getReceiptsList($where,$product_category){ global $db; //print_r($where); if(empty($where['ecmrecipes'])){ $query = "SELECT * FROM ecmstockdocins WHERE (canceled=0 OR canceled IS NULL) AND (deleted=0 OR deleted IS NULL) ORDER BY date_entered, register_date"; }else{ $query = "SELECT * FROM ecmstockdocins WHERE (canceled=0 OR canceled IS NULL) AND (deleted=0 OR deleted IS NULL) AND " . implode(" AND ", $where['ecmrecipes']) . ' ORDER BY date_entered, register_date'; } //print_r($query); $result = $db->query($query); $returnArray = []; $returnArr=[]; if($result->num_rows > 0){ $returnArray = array(); while ($row = $db->fetchByAssoc($result)){ $currency_value = 1; if($row['currency_value']!= ''){ $currency_value = $row['currency_value']; } $positionQuery = "SELECT ecmstockdocinitems.id as position_id, ecmstockdocinitems.name as position_name, ecmstockdocinitems.total as position_total_netto, ecmstockdocinitems.total as position_total_brutto, ecmstockdocinitems.price as position_price_purchase, ecmstockdocinitems.quantity as position_quantity, ecmstockdocinitems.dd_unit_id as position_unit_id, ecmstockdocinitems.dd_unit_name as position_unit_name, ecmstockdocinitems.total as position_total_netto_corrected, ecmstockdocinitems.quantity as position_quantity_corrected, ecmstockdocinitems.total as position_total_brutto_corrected, ecmstockdocinitems.ecmstockdocin_id as old_position_id, ecmstockdocinitems.code as position_code, ecmproducts.id as product_id, ecmproducts.product_netto_weight as position_weight FROM ecmstockdocinitems , ecmproducts ".($product_category!="" ? ',ecmproductcategories_bean' : '')." WHERE ecmstockdocinitems.ecmstockdocin_id='" . $row['id'] . "' AND ecmstockdocinitems.ecmproduct_id = ecmproducts.id ".($product_category!="" ? 'and ecmproductcategories_bean.bean_id=ecmproducts.id and ecmproductcategories_bean.ecmproductcategory_id= "'.$product_category.'"' : ''); if(count($where['ecmproducts'])>0){ $positionQuery .= ' AND '. implode(" AND ", $where['ecmproducts']); } $positionQuery .= " ORDER BY ecmstockdocinitems.position "; //print_r($positionQuery); //die(); $positionresult = $db->query($positionQuery); $positionArray = NULL; $i=0; if($positionresult->num_rows > 0){ $positionArray = array(); while ($rowposition = $db->fetchByAssoc($positionresult)){ $tmprow = array(); $tmprow['position_name'] = $rowposition['position_name']; $tmprow['position_id'] = $rowposition['position_id']; $tmprow['position_code'] = $rowposition['position_code']; $tmprow['position_total_netto'] = round($rowposition['position_total_netto'] * $currency_value,2); $tmprow['position_total_brutto'] = round($rowposition['position_total_brutto'] * $currency_value,2); $tmprow['position_total_price_purchase'] = round($rowposition['position_price_purchase'] * $rowposition['position_quantity'],2); $tmprow['position_weight'] = $rowposition['position_weight']; $tmprow['position_total_weight'] = round($rowposition['position_quantity']*$tmprow['position_weight'],6); $tmprow['position_quantity'] = $rowposition['position_quantity']; $tmprow['position_unit_id'] = $rowposition['position_unit_id']; $tmprow['position_unit_name'] = $rowposition['position_unit_name']; $tmprow['product_id'] = $rowposition['product_id']; //print_r($tmprow);die(); $positionArray[] = $tmprow; } //print_r($row);die(); $i++; } $row['position_list'] = $positionArray; $row['document_type'] = "EcmStockDocIn"; $returnArray[] = $row; } } //print_r($row);die(); return $returnArray; } } ?>