2 /**********************************************************************
3 Copyright (C) FrontAccounting, LLC.
4 Released under the terms of the GNU General Public License, GPL,
5 as published by the Free Software Foundation, either version 3
6 of the License, or (at your option) any later version.
7 This program is distributed in the hope that it will be useful,
8 but WITHOUT ANY WARRANTY; without even the implied warranty of
9 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
10 See the License here <http://www.gnu.org/licenses/gpl-3.0.html>.
11 ***********************************************************************/
12 function add_account_type($id, $name, $class_id, $parent)
14 $sql = "INSERT INTO ".TB_PREF."chart_types (id, name, class_id, parent)
15 VALUES ($id, ".db_escape($name).", ".db_escape($class_id).", ".db_escape($parent).")";
17 return db_query($sql);
20 function update_account_type($id, $name, $class_id, $parent)
22 $sql = "UPDATE ".TB_PREF."chart_types SET name=".db_escape($name).",
23 class_id=".db_escape($class_id).", parent=".db_escape($parent)
24 ." WHERE id = ".db_escape($id);
26 return db_query($sql, "could not update account type");
29 function get_account_types($all=false, $class_id=false, $parent=false)
31 $sql = "SELECT * FROM ".TB_PREF."chart_types";
34 $sql .= " WHERE !inactive";
35 if ($class_id != false)
36 $sql .= " AND class_id=".db_escape($class_id);
38 $sql .= " AND parent <= 0";
39 elseif ($parent != false)
40 $sql .= " AND parent=".db_escape($parent);
41 $sql .= " ORDER BY class_id, id";
43 return db_query($sql, "could not get account types");
46 function get_account_type($id)
48 $sql = "SELECT * FROM ".TB_PREF."chart_types WHERE id = ".db_escape($id);
50 $result = db_query($sql, "could not get account type");
52 return db_fetch($result);
55 function get_account_type_name($id)
57 $sql = "SELECT name FROM ".TB_PREF."chart_types WHERE id = ".db_escape($id);
59 $result = db_query($sql, "could not get account type");
61 $row = db_fetch_row($result);
65 function delete_account_type($id)
67 $sql = "DELETE FROM ".TB_PREF."chart_types WHERE id = ".db_escape($id);
69 db_query($sql, "could not delete account type");
72 function add_account_class($id, $name, $ctype)
74 $sql = "INSERT INTO ".TB_PREF."chart_class (cid, class_name, ctype)
75 VALUES (".db_escape($id).", ".db_escape($name).", ".db_escape($ctype).")";
77 return db_query($sql);
80 function update_account_class($id, $name, $ctype)
82 $sql = "UPDATE ".TB_PREF."chart_class SET class_name=".db_escape($name).",
83 ctype=".db_escape($ctype)." WHERE cid = ".db_escape($id);
85 return db_query($sql);
88 function get_account_classes($all=false, $balance=-1)
90 $sql = "SELECT * FROM ".TB_PREF."chart_class";
92 $sql .= " WHERE !inactive";
94 $sql .= " AND ctype>".CL_EQUITY." OR ctype=0";
95 elseif ($balance == 1)
96 $sql .= " AND ctype>0 AND ctype<".CL_INCOME;
97 $sql .= " ORDER BY cid";
99 return db_query($sql, "could not get account classes");
102 function get_account_class($id)
104 $sql = "SELECT * FROM ".TB_PREF."chart_class WHERE cid = ".db_escape($id);
106 $result = db_query($sql, "could not get account type");
108 return db_fetch($result);
111 function get_account_class_name($id)
113 $sql = "SELECT class_name FROM ".TB_PREF."chart_class WHERE cid =".db_escape($id);
115 $result = db_query($sql, "could not get account type");
117 $row = db_fetch_row($result);
121 function delete_account_class($id)
123 $sql = "DELETE FROM ".TB_PREF."chart_class WHERE cid = ".db_escape($id);
125 db_query($sql, "could not delete account type");