FileDocCategorySizeDatePackage
SimpleXML.javaAPI DocExample8443Mon Aug 27 20:13:00 BST 2007com.google.gwt.sample.simplexml.client

SimpleXML

public class SimpleXML extends Object implements com.google.gwt.core.client.EntryPoint
A very simple XML Example where we take a customer profile and display it on a page.

Fields Summary
private static final String
XML_LABEL_STYLE
private static final String
USER_TABLE_LABEL_STYLE
private static final String
USER_TABLE_STYLE
private static final String
NOTES_STYLE
Constructors Summary
Methods Summary
public voidonModuleLoad()


     
    HTTPRequest.asyncGet("customerRecord.xml", new ResponseTextHandler() {
      public void onCompletion(String responseText) {
        // In the real world, this text would come as a RPC response. This
        // technique is great for testing and samples though!
        renderXML(responseText);
      }

      private FlexTable createOrderTable(FlowPanel xmlParsed, String label) {
        HTML orderTableLabel = new HTML("<h2>" + label + "</h2>");
        xmlParsed.add(orderTableLabel);
        FlexTable orderTable = new FlexTable();
        orderTable.setStyleName(USER_TABLE_STYLE);
        orderTable.setBorderWidth(3);
        orderTable.getRowFormatter().setStyleName(0, USER_TABLE_LABEL_STYLE);
        orderTable.setText(0, 0, "Order ID");
        orderTable.setText(0, 1, "Item");
        orderTable.setText(0, 2, "Ordered On");
        orderTable.setText(0, 3, "Street");
        orderTable.setText(0, 4, "City");
        orderTable.setText(0, 5, "State");
        orderTable.setText(0, 6, "Zip");
        xmlParsed.add(orderTable);
        return orderTable;
      }

      /**
       * Creates the xml representation of xmlText. xmlText is assumed to have
       * been validated for structure on the server.
       * 
       * @param xmlText xml text
       * @param xmlParsed panel to display customer record
       */
      private void customerPane(String xmlText, FlowPanel xmlParsed) {
        Document customerDom = XMLParser.parse(xmlText);
        Element customerElement = customerDom.getDocumentElement();
        // Must do this if you ever use a raw node list that you expect to be
        // all elements.
        XMLParser.removeWhitespace(customerElement);

        // Customer Name
        String nameValue = getElementTextValue(customerElement, "name");
        String title = "<h1>" + nameValue + "</h1>";
        HTML titleHTML = new HTML(title);
        xmlParsed.add(titleHTML);

        // Customer Notes
        String notesValue = getElementTextValue(customerElement, "notes");
        Label notesText = new Label();
        notesText.setStyleName(NOTES_STYLE);
        notesText.setText(notesValue);
        xmlParsed.add(notesText);

        // Pending orders UI setup
        FlexTable pendingTable = createOrderTable(xmlParsed, "Pending Orders");
        FlexTable completedTable = createOrderTable(xmlParsed, "Completed");
        completedTable.setText(0, 7, "Shipped by");

        // Fill Orders Table
        NodeList orders = customerElement.getElementsByTagName("order");
        int pendingRowPos = 0;
        int completedRowPos = 0;
        for (int i = 0; i < orders.getLength(); i++) {
          Element order = (Element) orders.item(i);
          HTMLTable table;
          int rowPos;
          if (order.getAttribute("status").equals("pending")) {
            table = pendingTable;
            rowPos = ++pendingRowPos;
          } else {
            table = completedTable;
            rowPos = ++completedRowPos;
          }
          int columnPos = 0;
          fillInOrderTableRow(customerElement, order, table, rowPos, columnPos);
        }
      }

      private void fillInOrderTableRow(Element customerElement, Element order,
          HTMLTable table, int rowPos, int columnPos) {
        // Order ID
        String orderId = order.getAttribute("id");
        table.setText(rowPos, columnPos++, orderId);

        // Item
        Element item = (Element) order.getElementsByTagName("item").item(0);
        String itemUPC = item.getAttribute("upc");
        String itemName = item.getFirstChild().getNodeValue();
        Label itemLabel = new Label(itemUPC);
        itemLabel.setTitle(itemName);
        table.setWidget(rowPos, columnPos++, itemLabel);

        // Ordered On
        String orderedOnValue = getElementTextValue(customerElement,
          "orderedOn");
        table.setText(rowPos, columnPos++, orderedOnValue);

        // Address
        Element address = (Element) order.getElementsByTagName("address").item(
          0);
        XMLParser.removeWhitespace(address);
        NodeList lst = address.getChildNodes();
        for (int j = 0; j < lst.getLength(); j++) {
          Element next = (Element) lst.item(j);
          String addressPartText = next.getFirstChild().getNodeValue();
          table.setText(rowPos, columnPos++, addressPartText);
        }

        // Shipped By (optional attribute)
        NodeList shippedByList = order.getElementsByTagName("shippingInfo");
        if (shippedByList.getLength() == 1) {
          Element shippedBy = (Element) shippedByList.item(0);
          // Depending upon the shipper, different attributes might be
          // available, so XML carries the display info
          FlexTable shippedByTable = new FlexTable();
          shippedByTable.getRowFormatter().setStyleName(0,
            USER_TABLE_LABEL_STYLE);
          shippedByTable.setBorderWidth(1);
          NodeList shippedByParts = shippedBy.getChildNodes();
          for (int j = 0; j < shippedByParts.getLength(); j++) {
            Node next = shippedByParts.item(j);
            Element elem = (Element) next;
            shippedByTable.setText(0, j, elem.getAttribute("title"));
            shippedByTable.setText(1, j, elem.getFirstChild().getNodeValue());
          }
          table.setWidget(rowPos, columnPos++, shippedByTable);
        }
      }

      /**
       * Utility method to return the values of elements of the form <myTag>tag
       * value</myTag>
       */
      private String getElementTextValue(Element parent, String elementTag) {
        // If the xml is not coming from a known good source, this method would
        // have to include safety checks.
        return parent.getElementsByTagName(elementTag).item(0).getFirstChild()
          .getNodeValue();
      }

      private void renderXML(String xmlText) {
     
        final TabPanel tab = new TabPanel();
        final FlowPanel xmlSource = new FlowPanel();
        final FlowPanel xmlParsed = new FlowPanel();
        tab.add(xmlParsed, "Customer Pane");
        tab.add(xmlSource, "XML Source");
        tab.selectTab(0);
        RootPanel.get().add(tab);
        xmlPane(xmlText, xmlSource);
        customerPane(xmlText, xmlParsed);
      }

      /**
       * Show the raw XML.
       * 
       * @param xmlText
       * @param xmlSource
       */
      private void xmlPane(String xmlText, final FlowPanel xmlSource) {
        xmlText = xmlText.replaceAll("<", "<");
        xmlText = xmlText.replaceAll(">", ">");
        Label xml = new HTML("<pre>" + xmlText + "</pre>", false);
        xml.setStyleName(XML_LABEL_STYLE);
        xmlSource.add(xml);
      }
    });