X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=admin%2Fdb%2Fcompany_db.inc;h=c7e7c1aeff890945ba6a3b88bdde9229eb07ad8c;hb=7618d9d62ee39a932f56565a4ce25d965bf53462;hp=ed2b18f1356ae1653d1e319a7bf21d89160bbc04;hpb=4f57367b97832827258d1140ca423a26cf714142;p=fa-stable.git diff --git a/admin/db/company_db.inc b/admin/db/company_db.inc index ed2b18f1..c7e7c1ae 100644 --- a/admin/db/company_db.inc +++ b/admin/db/company_db.inc @@ -9,176 +9,107 @@ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the License here . ***********************************************************************/ +include_once($path_to_root. "/admin/db/payment_terms_db.inc"); -function update_company_gl_setup($retained_act, $profit_loss_act, $debtors_act, $pyt_discount_act, $creditors_act, - $freight_act, - $exchange_diff_act, - $bank_charge_act, - $default_sales_act, - $default_sales_discount_act, - $default_prompt_payment_act, - $default_inventory_act, - $default_cogs_act, - $default_adj_act, - $default_inv_sales_act, - $default_assembly_act, - $allow_negative_stock, - $po_over_receive, - $po_over_charge, - $accumulate_shipping, - $legal_text, - $past_due_days, - $default_credit_limit, - $default_workorder_required, - $default_dim_required, - $default_delivery_required) +/* + Update main or gl company setup. +*/ +function update_company_prefs($params) { - $sql = "UPDATE ".TB_PREF."company SET - retained_earnings_act=".db_escape($retained_act).", profit_loss_year_act=".db_escape($profit_loss_act).", - debtors_act=".db_escape($debtors_act).", pyt_discount_act=".db_escape($pyt_discount_act).", - creditors_act=".db_escape($creditors_act).", - freight_act=".db_escape($freight_act).", - exchange_diff_act=".db_escape($exchange_diff_act).", - bank_charge_act=".db_escape($bank_charge_act).", - default_sales_act=".db_escape($default_sales_act).", - default_sales_discount_act=".db_escape($default_sales_discount_act).", - default_prompt_payment_act=".db_escape($default_prompt_payment_act).", - default_inventory_act=".db_escape($default_inventory_act).", - default_cogs_act=".db_escape($default_cogs_act).", - default_adj_act=".db_escape($default_adj_act).", - default_inv_sales_act=".db_escape($default_inv_sales_act).", - default_assembly_act=".db_escape($default_assembly_act).", - allow_negative_stock=$allow_negative_stock, - po_over_receive=$po_over_receive, - po_over_charge=$po_over_charge, - accumulate_shipping=$accumulate_shipping, - legal_text=".db_escape($legal_text).", - past_due_days=$past_due_days, - default_credit_limit=$default_credit_limit, - default_workorder_required=$default_workorder_required, - default_dim_required=$default_dim_required, - default_delivery_required=$default_delivery_required - WHERE coy_code=1"; - - db_query($sql, "The company gl setup could not be updated "); -} - -function update_company_setup($coy_name, $coy_no, $gst_no, $tax_prd, $tax_last, - $postal_address, $phone, $fax, $email, $coy_logo, $domicile, $Dimension, - $curr_default, $f_year, $no_item_list, $no_customer_list, $no_supplier_list, - $base_sales, $time_zone, $add_pct, $round_to) -{ - if ($f_year == null) - $f_year = 0; - $sql = "UPDATE ".TB_PREF."company SET coy_name=".db_escape($coy_name).", - coy_no = ".db_escape($coy_no).", - gst_no=".db_escape($gst_no).", - tax_prd=$tax_prd, - tax_last=$tax_last, - postal_address =".db_escape($postal_address).", - phone=".db_escape($phone).", fax=".db_escape($fax).", - email=".db_escape($email).", - coy_logo=".db_escape($coy_logo).", - domicile=".db_escape($domicile).", - use_dimension=$Dimension, - no_item_list=$no_item_list, - no_customer_list=$no_customer_list, - no_supplier_list=$no_supplier_list, - curr_default=".db_escape($curr_default).", - f_year=$f_year, - base_sales=$base_sales, - time_zone=$time_zone, - add_pct=$add_pct, - round_to=$round_to - WHERE coy_code=1"; - - db_query($sql, "The company setup could not be updated "); -} - -function get_company_prefs($tbpref = TB_PREF) -{ - $sql = "SELECT * FROM ".$tbpref."company WHERE coy_code=1"; - - $result = db_query($sql, "The company preferences could not be retrieved"); + begin_transaction(__FUNCTION__, func_get_args()); - if (db_num_rows($result) == 0) - display_db_error("FATAL : Could not find company prefs", $sql); + $sql = "UPDATE ".TB_PREF."sys_prefs SET value = "; + foreach($params as $name => $value) { + if (!db_query($sql. db_escape($value). " WHERE name=".db_escape($name), + "The company prefferences could not be updated ")) + return false; + // update cached value + $_SESSION['SysPrefs']->prefs[$name] = $value; + } - return db_fetch($result); + commit_transaction(); + return true; } - -function get_company_pref($pref_name, $tbpref = TB_PREF) +/* + Get company preferences. Returns cached values from global variable SysPrefs + or retrieved from database if SysPrefs values are not set. + $prefs can be preference name, array of names, or null for all preferences. + +*/ +function get_company_pref($prefs = null) { - $prefs = get_company_prefs($tbpref); - return $prefs[$pref_name]; -} + global $SysPrefs, $db_version; -// fiscal year routines -function add_fiscalyear($from_date, $to_date, $closed) -{ - $from = date2sql($from_date); - $to = date2sql($to_date); + if (!isset($SysPrefs->prefs)) // just after first login or reset + $SysPrefs->refresh(); - $sql = "INSERT INTO ".TB_PREF."fiscal_year (begin, end, closed) - VALUES (".db_escape($from).",".db_escape($to).", $closed)"; + $all = $SysPrefs->prefs; - db_query($sql, "could not add fiscal year"); -} + if ($prefs && is_string($prefs)) + return @$all[$prefs]; -function update_fiscalyear($id, $closed) -{ - $sql = "UPDATE ".TB_PREF."fiscal_year SET closed=$closed - WHERE id=".db_escape($id); + if (!is_array($all)) + $all = array(); - db_query($sql, "could not update fiscal year"); + return $all; } -function get_all_fiscalyears() +function get_company_prefs() { - $sql = "SELECT * FROM ".TB_PREF."fiscal_year ORDER BY begin"; - - return db_query($sql, "could not get all fiscal years"); + return get_company_pref(null); } -function get_fiscalyear($id) +function set_company_pref($pref, $category, $type, $length, $value) { - $sql = "SELECT * FROM ".TB_PREF."fiscal_year WHERE id=".db_escape($id); + begin_transaction(__FUNCTION__, func_get_args()); + + $sql = "REPLACE `".TB_PREF."sys_prefs` SET `name`=".db_escape($pref).", `category`=".db_escape($category) + .", `type`=".db_escape($type).", `length`=".db_escape($length).", `value`=".db_escape($value); + $result = db_query($sql, "cannot set company pref"); - $result = db_query($sql, "could not get fiscal year"); + commit_transaction(); + return $result; - return db_fetch($result); } -function get_current_fiscalyear() +function get_base_sales_type() { - $year = get_company_pref('f_year'); - - $sql = "SELECT * FROM ".TB_PREF."fiscal_year WHERE id=$year"; + return get_company_pref('base_sales'); +} - $result = db_query($sql, "could not get current fiscal year"); +function get_company_extensions($id = -1) { + global $path_to_root; - return db_fetch($result); + $file = $path_to_root.($id == -1 ? '' : '/company/'.(int)$id).'/installed_extensions.php'; + $installed_extensions = array(); + if (is_file($file)) { + include($file); + } + return $installed_extensions; } -function delete_fiscalyear($id) +//--------------------------------------------------------------------------------------------- +// +// Resets $theme references in users records to 'default'. +// +function clean_user_themes($theme) { - begin_transaction(); - - $sql="DELETE FROM ".TB_PREF."fiscal_year WHERE id=".db_escape($id); + global $db_connections, $db; - db_query($sql, "could not delete fiscal year"); + begin_transaction(__FUNCTION__, func_get_args()); - commit_transaction(); -} + $comp = user_company(); -function get_base_sales_type() -{ - $sql = "SELECT base_sales FROM ".TB_PREF."company WHERE coy_code=1"; + $connections = $db_connections; // do not use db_connections directly here, or script will hang due to db_connections usage inside the loop + foreach ($connections as $n => $conn) { + $db = $_SESSION["wa_current_user"]->set_db_connection($n); + $sql = "UPDATE {$conn['tbpref']}users SET theme='default' WHERE theme='$theme'"; + if (!db_query($sql, 'Cannot update user theme settings')) + return false; + } + $db = $_SESSION["wa_current_user"]->set_db_connection($comp); + $_SESSION['wa_current_user']->prefs->theme = 'default'; - $result = db_query($sql, "could not get base sales type"); - $myrow = db_fetch($result); - return $myrow[0]; + commit_transaction(); + return true; } - - -?> \ No newline at end of file