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 $page_security = 'SA_POSSETUP';
13 $path_to_root = "../..";
14 include_once($path_to_root . "/includes/session.inc");
16 page(_("POS settings"));
18 include_once($path_to_root . "/includes/ui.inc");
19 include_once($path_to_root . "/sales/includes/db/sales_points_db.inc");
21 simple_page_mode(true);
22 //----------------------------------------------------------------------------------------------------
24 function can_process()
26 if (strlen($_POST['name']) == 0)
28 display_error(_("The POS name cannot be empty."));
29 set_focus('pos_name');
32 if (!check_value('cash') && !check_value('credit'))
34 display_error(_("You must allow cash or credit sale."));
42 //----------------------------------------------------------------------------------------------------
44 if ($Mode=='ADD_ITEM' && can_process())
46 add_sales_point($_POST['name'], $_POST['location'], $_POST['account'],
47 check_value('cash'), check_value('credit'));
48 display_notification(_('New point of sale has been added'));
52 //----------------------------------------------------------------------------------------------------
54 if ($Mode=='UPDATE_ITEM' && can_process())
57 update_sales_point($selected_id, $_POST['name'], $_POST['location'],
58 $_POST['account'], check_value('cash'), check_value('credit'));
59 display_notification(_('Selected point of sale has been updated'));
63 //----------------------------------------------------------------------------------------------------
65 if ($Mode == 'Delete')
67 $sql = "SELECT * FROM ".TB_PREF."users WHERE print_profile=".db_escape($selected_id);
68 $res = db_query($sql, "canot check pos usage");
69 if (db_num_rows($res)) {
70 display_error(_("Cannot delete this POS because it is used in users setup."));
72 delete_sales_point($selected_id);
73 display_notification(_('Selected point of sale has been deleted'));
81 $sav = get_post('show_inactive');
83 $_POST['show_inactive'] = $sav;
85 //----------------------------------------------------------------------------------------------------
87 $result = get_all_sales_points(check_value('show_inactive'));
90 start_table("$table_style");
92 $th = array (_('POS Name'), _('Credit sale'), _('Cash sale'), _('Location'), _('Default account'),
94 inactive_control_column($th);
98 while ($myrow = db_fetch($result))
100 alt_table_row_color($k);
101 label_cell($myrow["pos_name"], "nowrap");
102 label_cell($myrow['credit_sale'] ? _('Yes') : _('No'));
103 label_cell($myrow['cash_sale'] ? _('Yes') : _('No'));
104 label_cell($myrow["location_name"], "");
105 label_cell($myrow["bank_account_name"], "");
106 inactive_control_cell($myrow["id"], $myrow["inactive"], "sales_pos", 'id');
107 edit_button_cell("Edit".$myrow['id'], _("Edit"));
108 delete_button_cell("Delete".$myrow['id'], _("Delete"));
112 inactive_control_row($th);
114 //----------------------------------------------------------------------------------------------------
116 $cash = db_has_cash_accounts();
118 if (!$cash) display_note(_("To have cash POS first define at least one cash bank account."));
120 start_table($table_style2);
122 if ($selected_id != -1)
125 if ($Mode == 'Edit') {
126 $myrow = get_sales_point($selected_id);
128 $_POST['name'] = $myrow["pos_name"];
129 $_POST['location'] = $myrow["pos_location"];
130 $_POST['account'] = $myrow["pos_account"];
131 if ($myrow["credit_sale"]) $_POST['credit_sale'] = 1;
132 if ($myrow["cash_sale"]) $_POST['cash_sale'] = 1;
134 hidden('selected_id', $selected_id);
137 text_row_ex(_("Point of Sale Name").':', 'name', 20, 30);
139 check_row(_('Allowed credit sale'), 'credit', check_value('credit_sale'));
140 check_row(_('Allowed cash sale'), 'cash', check_value('cash_sale'));
141 cash_accounts_list_row(_("Default cash account").':', 'account');
145 hidden('account', 0);
148 locations_list_row(_("POS location").':', 'location');
151 submit_add_or_update_center($selected_id == -1, '', 'both');