X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=includes%2Fprefs%2Fsysprefs.inc;h=34e52bccb706a0d7355096ab7a288c87efbf31fe;hb=19ddc3939071044c8e94b628f1d6a039f50cc493;hp=426d3a78fcbd3512ca4996a38911f02f11d3be21;hpb=fbf51ab0febfd0885620abcab8738339d156ff45;p=fa-stable.git diff --git a/includes/prefs/sysprefs.inc b/includes/prefs/sysprefs.inc index 426d3a78..34e52bcc 100644 --- a/includes/prefs/sysprefs.inc +++ b/includes/prefs/sysprefs.inc @@ -11,22 +11,66 @@ ***********************************************************************/ include_once($path_to_root . "/admin/db/company_db.inc"); +/* + System and per company prefferences. + Object is created only with site wide preffernces. + After user login refresh method have to be called to re-initialize company specific settings. +*/ class sys_prefs { var $prefs; var $db_ok; // check whether database has been upgraded after src update. - function sys_prefs() + function __construct() { -// $this->prefs = get_company_prefs(); - + global $path_to_root; + + // retrieve set system wide preferences + include $path_to_root.'/config.default.php'; + if (file_exists($path_to_root.'/config.php')) + include $path_to_root.'/config.php'; + + foreach(get_defined_vars() as $name => $value) + $this->$name = $value; + + if (!@$this->time_zone) + $this->time_zone = ini_get('date.timezone'); + + if (!$this->time_zone) + $this->time_zone = 'Europe/Berlin'; + + if (!isset($this->use_popup_search)) + $this->use_popup_search = false; + + ini_set('date.timezone', $this->time_zone); } - + + /* + Re-initialize company preferrencies. + */ + function refresh() + { + global $db_version; + + $sql = "SELECT name, value FROM ".TB_PREF."sys_prefs"; + $result = @db_query($sql); // supress errors before 2.3 db structure upgrade + + if(!$result) + return null; + + while($pref = db_fetch_assoc($result)) { + $this->prefs[$pref['name']] = $pref['value']; + } + + // update current db status for info in log file + $this->db_ok = $this->prefs['version_id'] == $db_version; + } + function allow_negative_stock() { return $this->prefs['allow_negative_stock']; } - + /* Sherifoz 26.06.03 Proportion by which items can be received over the quantity that is specified in a purchase invoice The figure entered is interpreted as a percentage ie 10 means 0.1 or 10% not 10 times @@ -83,10 +127,63 @@ class sys_prefs function allocation_settled_allowance() { - global $config_allocation_settled_allowance; - return $config_allocation_settled_allowance; + return $this->config_allocation_settled_allowance; + } + + function no_zero_lines_amount() + { + return $this->prefs['no_zero_lines_amount']; + } + + function show_po_item_codes() + { + return $this->prefs['show_po_item_codes']; + } + + function accounts_alpha() + { + return $this->prefs['accounts_alpha']; + } + + function loc_notification() + { + return $this->prefs['loc_notification']; + } + + function print_invoice_no() + { + return $this->prefs['print_invoice_no']; + } + + function allow_negative_prices() + { + return $this->prefs['allow_negative_prices']; + } + + function print_item_images_on_quote() + { + return $this->prefs['print_item_images_on_quote']; + } + + function alternative_tax_include_on_docs() + { + return $this->prefs['alternative_tax_include_on_docs']; + } + + function suppress_tax_rates() + { + return $this->prefs['suppress_tax_rates']; + } + + function backup_dir($comp=null) + { + if (!isset($comp)) + $comp = user_company(); + + if (isset($this->backup_path)) + return sprintf($this->backup_path, $comp); + else + return $this->comp_path.'/'.$comp."/backup/"; } - } -?> \ No newline at end of file