Skip to main content

Flex - Add Edit Delete rows using Data Grid


With Flex, I was scraching head for few days to achive

(a) How to use DataGrid to add, edit and delete records

(b) How to move XML data into ArrayCollection.

Now, here is the solution....



<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"
backgroundAlpha="0" creationComplete="srv.send()">

<mx:Script>
import mx.collections.ArrayCollection;
import mx.rpc.events.FaultEvent;
import mx.rpc.events.ResultEvent;

[Bindable]
public var employees:ArrayCollection = new ArrayCollection();
private var xmldata:XML;

private function faultHandler(event:FaultEvent):void{
mx.controls.Alert.show(event.fault.message,"Error in getting result");
}

private function resultHandler(event:ResultEvent):void{
xmldata = new XML(event.result);

// Convert XML to ArrayCollection
for each(var s:XML in xmldata.employee){
employees.addItem(s);
}
}

private function addRow():void
{
if (frmName.text != "")
employees.addItem( {name: frmName.text, email: email.text, phone: phone.text} );
}

private function updateRow():void
{
if (dg.selectedIndex != -1)
employees.setItemAt({name: frmName.text, email: email.text, phone: phone.text}, dg.selectedIndex);
}

private function deleteRow():void
{
if (dg.selectedIndex != -1)
{
employees.removeItemAt(dg.selectedIndex);
frmName.text="";
email.text="";
phone.text="";
}
}
</mx:Script>

<mx:HTTPService id="srv" url="employees.xml" useProxy="false" resultFormat="e4x"
result="resultHandler(event)" fault="faultHandler(event)"/>

<mx:HBox width="100%" height="100%">
<mx:DataGrid id="dg" width="100%" height="100%" dataProvider="{employees}">
<mx:columns>
<mx:Array>
<mx:DataGridColumn dataField="name" headerText="Name"/>
<mx:DataGridColumn dataField="phone" headerText="Phone"/>
<mx:DataGridColumn dataField="email" headerText="Email"/>
</mx:Array>
</mx:columns>
</mx:DataGrid>

<mx:Form width="100%" height="100%">
<mx:FormItem label="Name">
<mx:TextInput id="frmName" width="200" text="{dg.selectedItem.name}"/>
</mx:FormItem>

<mx:FormItem label="Email">
<mx:TextInput id="email" width="200" text="{dg.selectedItem.email}"/>
</mx:FormItem>

<mx:FormItem label="Phone">
<mx:TextInput id="phone" width="200" text="{dg.selectedItem.phone}"/>
</mx:FormItem>

<mx:FormItem>
<mx:HBox>
<mx:Button label="Update" click="updateRow()"/>
<mx:Button label="Add" click="addRow()"/>
<mx:Button label="Delete" click="deleteRow()"/>
</mx:HBox>
</mx:FormItem>
</mx:Form>
</mx:HBox>
</mx:Application>





And here is the emplyees.xml


<?xml version="1.0" encoding="UTF-8"?>
<employees>
<employee>
<name>Santhosh</name>
<phone>123456</phone>
<email>santhosh@gmail.com</email>
</employee>

<employee>
<name>Abhi</name>
<phone>7890</phone>
<email>abhi@gmail.com</email>
</employee>

</employees>

Comments

Popular posts from this blog

SAAS Simple Maturity Model

There are two architectural models – commonly referred as SAAS Maturity models- that describe the transition of a service to what is called Multi-tenant efficient, highly scalable application. The SAAS Maturity model described by Microsoft has four distinct stages and is illustrated below. Another similar well-known model for SaaS-maturity is known as Forrester-model but adds another stage known as "Dynamic Business Apps-as-a-service". The three key Attributes of a SAAS Architecture: Configurability: Metadata used to configure the way the application behaves for customers Multi-tenant Efficiency : Maximizing the sharing of resources across tenants Scalability: Maximizing concurrency, resource efficiency SAAS Simple Maturity Model (Microsoft, 2006) SaaS Maturity Model (Forres...

CXF Example –Web Service Using Spring and Maven

Apache CXF is an open source services framework. CXF helps you build Web Services using frontend programming APIs, like JAX-WS and JAX-RS. These services can speak a variety of protocols such as SOAP, XML/HTTP, RESTful HTTP, or CORBA and work over a variety of transports such as HTTP, JMS or JBI. Support for bottom up approach and top down approach. Support for Standards JAX-WS, JSR-181, SAAJ, JAX-RS SOAP 1.1, 1.2, WS-I BasicProfile, WS-Security, WS-Addressing, WS-RM, WS-Policy WSDL 1.1 MTOM Building Web Services – Example 1 Develop a simple Web Service using CXF framework. The example in this case is an InterestRate Service. Tools / technologies Version CXF 2.1 Maven 2.0 Tomcat apache-tomcat-6.0.24 JDK java version 1.6.0_20       The Application Scope The "Interest Rate Service" application demonstrates how easily you can develop a Web Service using CXF frame work. The WSDL service definition defines three operations. Below is the InterestRateService interface.   @WebS...

CXF Example –Web Service Client Using Spring

Continuing from my previous post on (CXF Example –Web Service Using Spring and Maven) , let's create a client application to consume the web service. Steps Generate POJOs from WSDL to access the Web Service using the tool wsdl2java as below. You can access the WSDL used in this example from here.   wsdl2java rateServiceWSDL.xml   WSDL2Java is a command line tool that generates Java classes from an existing WSDL document. Generated classes represent client stubs, server skeletons and data types that will helps you to write client side and server Java programs for Web services defined in the WSDL document.     Create a client-beans.xml as below: < beans xmlns = "http://www.springframework.org/schema/beans"      xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance" xmlns:jaxws = "http://cxf.apache.org/jaxws"      xsi:schemaLocation = " http://www.springframework.org/schema/beans http://www.springfram...