No display of shipping if there are no shipping costs on sales documents or views.
[fa-stable.git] / sales / view / view_sales_order.php
1 <?php
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_SALESTRANSVIEW';
13 $path_to_root = "../..";
14 include_once($path_to_root . "/sales/includes/cart_class.inc");
15
16 include_once($path_to_root . "/includes/session.inc");
17 include_once($path_to_root . "/includes/date_functions.inc");
18
19 include_once($path_to_root . "/sales/includes/sales_ui.inc");
20 include_once($path_to_root . "/sales/includes/sales_db.inc");
21
22 $js = "";
23 if ($use_popup_windows)
24         $js .= get_js_open_window(900, 600);
25
26 if ($_GET['trans_type'] == ST_SALESQUOTE)
27 {
28         page(_($help_context = "View Sales Quotation"), true, false, "", $js);
29         display_heading(sprintf(_("Sales Quotation #%d"),$_GET['trans_no']));
30 }       
31 else
32 {
33         page(_($help_context = "View Sales Order"), true, false, "", $js);
34         display_heading(sprintf(_("Sales Order #%d"),$_GET['trans_no']));
35 }
36
37 if (isset($_SESSION['View']))
38 {
39         unset ($_SESSION['View']);
40 }
41
42 $_SESSION['View'] = new Cart($_GET['trans_type'], $_GET['trans_no']);
43
44 start_table(TABLESTYLE2, "width='95%'", 5);
45
46 if ($_GET['trans_type'] != ST_SALESQUOTE)
47 {
48         echo "<tr valign=top><td>";
49         display_heading2(_("Order Information"));
50         echo "</td><td>";
51         display_heading2(_("Deliveries"));
52         echo "</td><td>";
53         display_heading2(_("Invoices/Credits"));
54         echo "</td></tr>";
55 }       
56
57 echo "<tr valign=top><td>";
58
59 start_table(TABLESTYLE, "width='95%'");
60 label_row(_("Customer Name"), $_SESSION['View']->customer_name, "class='tableheader2'",
61         "colspan=3");
62 start_row();
63 label_cells(_("Customer Order Ref."), $_SESSION['View']->cust_ref, "class='tableheader2'");
64 label_cells(_("Deliver To Branch"), $_SESSION['View']->deliver_to, "class='tableheader2'");
65 end_row();
66 start_row();
67 label_cells(_("Ordered On"), $_SESSION['View']->document_date, "class='tableheader2'");
68 if ($_GET['trans_type'] == ST_SALESQUOTE)
69         label_cells(_("Valid until"), $_SESSION['View']->due_date, "class='tableheader2'");
70 else
71         label_cells(_("Requested Delivery"), $_SESSION['View']->due_date, "class='tableheader2'");
72 end_row();
73 start_row();
74 label_cells(_("Order Currency"), $_SESSION['View']->customer_currency, "class='tableheader2'");
75 label_cells(_("Deliver From Location"), $_SESSION['View']->location_name, "class='tableheader2'");
76 end_row();
77
78 label_row(_("Payment Terms"), $_SESSION['View']->payment_terms['terms'], "class='tableheader2'", "colspan=3");
79 label_row(_("Delivery Address"), nl2br($_SESSION['View']->delivery_address),
80         "class='tableheader2'", "colspan=3");
81 label_row(_("Reference"), $_SESSION['View']->reference, "class='tableheader2'", "colspan=3");
82 label_row(_("Telephone"), $_SESSION['View']->phone, "class='tableheader2'", "colspan=3");
83 label_row(_("E-mail"), "<a href='mailto:" . $_SESSION['View']->email . "'>" . $_SESSION['View']->email . "</a>",
84         "class='tableheader2'", "colspan=3");
85 label_row(_("Comments"), nl2br($_SESSION['View']->Comments), "class='tableheader2'", "colspan=3");
86 end_table();
87
88 if ($_GET['trans_type'] != ST_SALESQUOTE)
89 {
90         echo "</td><td valign='top'>";
91
92         start_table(TABLESTYLE);
93         display_heading2(_("Delivery Notes"));
94
95
96         $th = array(_("#"), _("Ref"), _("Date"), _("Total"));
97         table_header($th);
98
99         $dn_numbers = array();
100         $delivery_total = 0;
101
102         if ($result = get_sales_child_documents(ST_SALESORDER, $_GET['trans_no'])) {
103
104                 $k = 0;
105                 while ($del_row = db_fetch($result))
106                 {
107
108                         alt_table_row_color($k);
109                         $dn_numbers[] = $del_row["trans_no"];
110                         $this_total = $del_row["ov_freight"]+ $del_row["ov_amount"] + $del_row["ov_freight_tax"]  + $del_row["ov_gst"] ;
111                         $delivery_total += $this_total;
112
113                         label_cell(get_customer_trans_view_str($del_row["type"], $del_row["trans_no"]));
114                         label_cell($del_row["reference"]);
115                         label_cell(sql2date($del_row["tran_date"]));
116                         amount_cell($this_total);
117                         end_row();
118                 }
119         }
120
121         label_row(null, price_format($delivery_total), " ", "colspan=4 align=right");
122
123         end_table();
124         echo "</td><td valign='top'>";
125
126         start_table(TABLESTYLE);
127         display_heading2(_("Sales Invoices"));
128
129         $th = array(_("#"), _("Ref"), _("Date"), _("Total"));
130         table_header($th);
131         
132         $inv_numbers = array();
133         $invoices_total = 0;
134
135         if ($result = get_sales_child_documents(ST_CUSTDELIVERY, $dn_numbers)) {
136
137                 $k = 0;
138
139                 while ($inv_row = db_fetch($result))
140                 {
141                         alt_table_row_color($k);
142
143                         $this_total = $inv_row["ov_freight"] + $inv_row["ov_freight_tax"]  + $inv_row["ov_gst"] + $inv_row["ov_amount"];
144                         $invoices_total += $this_total;
145
146                         $inv_numbers[] = $inv_row["trans_no"];
147                         label_cell(get_customer_trans_view_str($inv_row["type"], $inv_row["trans_no"]));
148                         label_cell($inv_row["reference"]);
149                         label_cell(sql2date($inv_row["tran_date"]));
150                         amount_cell($this_total);
151                         end_row();
152                 }
153         }
154         label_row(null, price_format($invoices_total), " ", "colspan=4 align=right");
155
156         end_table();
157
158         display_heading2(_("Credit Notes"));
159
160         start_table(TABLESTYLE);
161         $th = array(_("#"), _("Ref"), _("Date"), _("Total"));
162         table_header($th);
163         
164         $credits_total = 0;
165         
166         if ($result = get_sales_child_documents(ST_SALESINVOICE, $inv_numbers)) {
167                 $k = 0;
168
169                 while ($credits_row = db_fetch($result))
170                 {
171
172                         alt_table_row_color($k);
173
174                         $this_total = $credits_row["ov_freight"] + $credits_row["ov_freight_tax"]  + $credits_row["ov_gst"] + $credits_row["ov_amount"];
175                         $credits_total += $this_total;
176
177                         label_cell(get_customer_trans_view_str($credits_row["type"], $credits_row["trans_no"]));
178                         label_cell($credits_row["reference"]);
179                         label_cell(sql2date($credits_row["tran_date"]));
180                         amount_cell(-$this_total);
181                         end_row();
182
183                 }
184
185         }
186         label_row(null, "<font color=red>" . price_format(-$credits_total) . "</font>",
187                 " ", "colspan=4 align=right");
188
189         end_table();
190
191         echo "</td></tr>";
192
193         end_table();
194 }
195 echo "<center>";
196 if ($_SESSION['View']->so_type == 1)
197         display_note(_("This Sales Order is used as a Template."), 0, 0, "class='currentfg'");
198 display_heading2(_("Line Details"));
199
200 start_table(TABLESTYLE, "width='95%'");
201 $th = array(_("Item Code"), _("Item Description"), _("Quantity"), _("Unit"),
202         _("Price"), _("Discount"), _("Total"), _("Quantity Delivered"));
203 table_header($th);
204
205 $k = 0;  //row colour counter
206
207 foreach ($_SESSION['View']->line_items as $stock_item) {
208
209         $line_total = round2($stock_item->quantity * $stock_item->price * (1 - $stock_item->discount_percent),
210            user_price_dec());
211
212         alt_table_row_color($k);
213
214         label_cell($stock_item->stock_id);
215         label_cell($stock_item->item_description);
216         $dec = get_qty_dec($stock_item->stock_id);
217         qty_cell($stock_item->quantity, false, $dec);
218         label_cell($stock_item->units);
219         amount_cell($stock_item->price);
220         amount_cell($stock_item->discount_percent * 100);
221         amount_cell($line_total);
222
223         qty_cell($stock_item->qty_done, false, $dec);
224         end_row();
225 }
226
227 if ($_SESSION['View']->freight_cost != 0.0)
228         label_row(_("Shipping"), price_format($_SESSION['View']->freight_cost),
229                 "align=right colspan=6", "nowrap align=right", 1);
230
231 $sub_tot = $_SESSION['View']->get_items_total() + $_SESSION['View']->freight_cost;
232
233 $display_sub_tot = price_format($sub_tot);
234
235 label_row(_("Sub Total"), $display_sub_tot, "align=right colspan=6",
236         "nowrap align=right", 1);
237
238 $taxes = $_SESSION['View']->get_taxes();
239
240 $tax_total = display_edit_tax_items($taxes, 6, $_SESSION['View']->tax_included,2);
241
242 $display_total = price_format($sub_tot + $tax_total);
243
244 start_row();
245 label_cells(_("Amount Total"), $display_total, "colspan=6 align='right'","align='right'");
246 label_cell('', "colspan=2");
247 end_row();
248 end_table(2);
249
250 end_page(true, false, false, $_GET['trans_type'], $_GET['trans_no']);
251
252 ?>