2010-05-20 18:11:38 -04:00
|
|
|
<%--
|
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one
|
|
|
|
* or more contributor license agreements. See the NOTICE file
|
|
|
|
* distributed with this work for additional information
|
|
|
|
* regarding copyright ownership. The ASF licenses this file
|
|
|
|
* to you under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance
|
|
|
|
* with the License. You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing,
|
|
|
|
* software distributed under the License is distributed on an
|
|
|
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
|
|
* KIND, either express or implied. See the License for the
|
|
|
|
* specific language governing permissions and limitations
|
|
|
|
* under the License.
|
|
|
|
--%>
|
2010-05-26 17:47:02 -04:00
|
|
|
<!-- =========================================================================== -->
|
|
|
|
<!-- This JSP page demonstrates changing status of a Purchase Order. -->
|
|
|
|
<!-- =========================================================================== -->
|
2010-05-20 18:11:38 -04:00
|
|
|
<%@page import="openbook.server.OpenBookService"%>
|
|
|
|
<%@page import="openbook.domain.Book"%>
|
|
|
|
<%@page import="openbook.domain.Customer"%>
|
|
|
|
<%@page import="openbook.domain.ShoppingCart"%>
|
|
|
|
<%@page import="openbook.domain.PurchaseOrder"%>
|
|
|
|
<%@page import="openbook.domain.LineItem"%>
|
|
|
|
<%@page import="openbook.util.JSPUtility"%>
|
|
|
|
<%@page import="java.util.Map"%>
|
|
|
|
<%@page import="java.util.List"%>
|
|
|
|
|
|
|
|
<%@include file="header.jsp"%>
|
|
|
|
|
2010-05-26 17:47:02 -04:00
|
|
|
<div id="help">
|
|
|
|
<h3>Optimistic semantics and Orphan Delete</h3>
|
|
|
|
|
|
|
|
This page displays all the orders placed by the current users.
|
|
|
|
This page also allows to
|
|
|
|
<A HREF="generated-html/openbook/server/OpenBookServiceImpl.java.html#deliver" type="popup">
|
|
|
|
<em>deliver</em></A> an order. Delivering an order essentially amounts to
|
|
|
|
decrementing the inventory for each line item,
|
|
|
|
<A href="generated-html/openbook/domain/PurchaseOrder.java.html#setDelivered" type="popup">changing the status</A>
|
|
|
|
which, as an interesting side-effect, nullifies the Line Items.
|
|
|
|
<ul>
|
|
|
|
<li><b>Optimistic Semantics</b>: Delivery is one of the operations that may fail due to
|
|
|
|
optimistic transaction model used by OpenBooks and which is also the default transaction model
|
|
|
|
proposed in JPA. The optimistic transaction model promoted that an Order can <em>always</em>
|
|
|
|
be placed, even if the inventory is inadequate. Only while fulfilling the order in a separate
|
|
|
|
transaction, the insufficient inventory may fail to deliver an order.
|
|
|
|
</li>
|
|
|
|
<li><b>Orphan Delete</b>: JPA 2.0 had added support for composite relation via new orphan delete
|
|
|
|
functionality. To demonstrate its effect, on delivery an Order nullifies its Line Items. As a
|
|
|
|
result, the Line Items gets deleted from the database as they are no more referred. That is why,
|
|
|
|
for pending orders, you can see their line items -- but once an order is delivered its line items
|
|
|
|
are no more available.
|
|
|
|
</li>
|
|
|
|
</ul>
|
|
|
|
</div>
|
2010-05-20 18:11:38 -04:00
|
|
|
<div id="content" style="display: block">
|
|
|
|
|
|
|
|
<%
|
|
|
|
OpenBookService service = (OpenBookService)session.getAttribute(KEY_SERVICE);
|
|
|
|
if (service == null) {
|
|
|
|
%>
|
|
|
|
<jsp:forward page="<%= PAGE_HOME %>"></jsp:forward>
|
|
|
|
<%
|
|
|
|
}
|
|
|
|
if (ACTION_DELIVER.equals(request.getParameter(KEY_ACTION))) {
|
|
|
|
String oid = request.getParameter(KEY_OID);
|
|
|
|
PurchaseOrder order = (PurchaseOrder)session.getAttribute(oid);
|
|
|
|
service.deliver(order);
|
|
|
|
}
|
|
|
|
|
|
|
|
Customer customer = (Customer)session.getAttribute(KEY_USER);
|
|
|
|
List<PurchaseOrder> orders = service.getOrders(null, customer);
|
2010-05-26 17:47:02 -04:00
|
|
|
if (orders.isEmpty()) {
|
|
|
|
%>
|
|
|
|
<%= customer.getName() %>, you have not placed any order yet.<br>
|
|
|
|
<%
|
|
|
|
return;
|
|
|
|
}
|
2010-05-20 18:11:38 -04:00
|
|
|
%>
|
|
|
|
|
2010-05-26 17:47:02 -04:00
|
|
|
<table>
|
|
|
|
<caption><%= customer.getName() %>, you have placed <%= orders.size() %> orders</caption>
|
2010-05-20 18:11:38 -04:00
|
|
|
<thead>
|
|
|
|
<tr>
|
2010-05-26 17:47:02 -04:00
|
|
|
<th>ID</th> <th>Total</th> <th>Placed On</th> <th>Status</th> <th>Delivered On</th> <th></th>
|
2010-05-20 18:11:38 -04:00
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tfoot>
|
|
|
|
</tfoot>
|
|
|
|
<tbody>
|
|
|
|
<%
|
|
|
|
int i = 0;
|
|
|
|
for (PurchaseOrder order : orders) {
|
|
|
|
session.setAttribute(""+order.getId(), order);
|
|
|
|
%>
|
2010-05-26 17:47:02 -04:00
|
|
|
<TR class="<%= i++%2 == 0 ? ROW_STYLE_EVEN : ROW_STYLE_ODD %>">
|
2010-05-20 18:11:38 -04:00
|
|
|
<TD> <A HREF="<%=
|
|
|
|
JSPUtility.encodeURL(PAGE_ORDERS,
|
|
|
|
KEY_ACTION, ACTION_DETAILS,
|
|
|
|
KEY_OID, order.getId()) %>"> <%= order.getId() %></A></TD>
|
|
|
|
<TD> <%= order.getTotal() %> </TD>
|
|
|
|
<TD> <%= JSPUtility.format(order.getPlacedOn()) %> </TD>
|
|
|
|
<TD> <%= order.getStatus() %> </TD>
|
|
|
|
<%
|
2010-05-26 17:47:02 -04:00
|
|
|
if (order.isDelivered()) {
|
2010-05-20 18:11:38 -04:00
|
|
|
%>
|
2010-05-26 17:47:02 -04:00
|
|
|
<TD> <%= JSPUtility.format(order.getDeliveredOn()) %> </TD>
|
|
|
|
<TD> </TD>
|
2010-05-20 18:11:38 -04:00
|
|
|
<%
|
|
|
|
} else {
|
|
|
|
%>
|
2010-05-26 17:47:02 -04:00
|
|
|
<TD> </TD>
|
|
|
|
<TD> <A HREF="<%= JSPUtility.encodeURL(PAGE_ORDERS, KEY_ACTION, ACTION_DELIVER,
|
|
|
|
KEY_OID, order.getId()) %>">Deliver</A></TD>
|
2010-05-20 18:11:38 -04:00
|
|
|
<%
|
|
|
|
}
|
|
|
|
%>
|
|
|
|
</TR>
|
|
|
|
<%
|
|
|
|
}
|
|
|
|
%>
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
|
|
|
|
|
|
|
|
<%
|
|
|
|
if (ACTION_DETAILS.equals(request.getParameter(KEY_ACTION))) {
|
|
|
|
String oid = request.getParameter(KEY_OID);
|
|
|
|
PurchaseOrder order = (PurchaseOrder)session.getAttribute(oid);
|
|
|
|
List<LineItem> items = order.getItems();
|
2010-05-26 17:47:02 -04:00
|
|
|
if (items == null) {
|
|
|
|
if (order.isDelivered()) {
|
2010-05-20 18:11:38 -04:00
|
|
|
%>
|
2010-05-26 17:47:02 -04:00
|
|
|
Order <%= order.getId() %> has been delivered. Line items of delivered orders are automatically
|
|
|
|
deleted due to orphan delete nature of Master-Details relationship.
|
|
|
|
<% } else {
|
|
|
|
%>
|
|
|
|
Order <%= order.getId() %> has no line items. This is an implementation error because
|
|
|
|
pending orders must have at least one line item by design.
|
|
|
|
<%
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
%>
|
|
|
|
<table>
|
|
|
|
<caption><%= items.size() %> line items of Order <%= order.getId() %></caption>
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th>Title</th> <th>Price</th> <th>Quantity</th> <th>Cost</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
2010-05-20 18:11:38 -04:00
|
|
|
<%
|
2010-05-26 17:47:02 -04:00
|
|
|
int j = 0;
|
|
|
|
for (LineItem item : items) {
|
2010-05-20 18:11:38 -04:00
|
|
|
%>
|
2010-05-26 17:47:02 -04:00
|
|
|
<TR class="<%= j++%2 == 0 ? ROW_STYLE_EVEN : ROW_STYLE_ODD %>">
|
|
|
|
<TD> <%= item.getBook().getTitle() %> </TD>
|
|
|
|
<TD> <%= JSPUtility.format(item.getBook().getPrice()) %> </TD>
|
|
|
|
<TD> <%= item.getQuantity() %> </TD>
|
|
|
|
<TD> <%= JSPUtility.format(item.getBook().getPrice() * item.getQuantity()) %> </TD>
|
|
|
|
</TR>
|
2010-05-20 18:11:38 -04:00
|
|
|
<%
|
2010-05-26 17:47:02 -04:00
|
|
|
}
|
2010-05-20 18:11:38 -04:00
|
|
|
%>
|
2010-05-26 17:47:02 -04:00
|
|
|
<TR>
|
|
|
|
<TD>Total</TD><TD><%= JSPUtility.format(order.getTotal()) %></TD>
|
|
|
|
</TR>
|
|
|
|
</tbody>
|
|
|
|
</table>
|
2010-05-20 18:11:38 -04:00
|
|
|
<%
|
|
|
|
}
|
|
|
|
}
|
|
|
|
%>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<%@include file="footer.jsp"%>
|