/
ContactPanel.mxml
191 lines (154 loc) · 6.62 KB
/
ContactPanel.mxml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
<?xml version="1.0" encoding="utf-8"?>
<mx:Canvas
xmlns:mx="http://www.adobe.com/2006/mxml"
initialize="initComp()">
<mx:Script>
<![CDATA[
import mx.validators.ValidationResult;
import mx.controls.Alert;
import mx.collections.ArrayCollection;
import flash.net.*;
import com.adobe.cairngorm.control.CairngormEventDispatcher;
import com.af.cep.commands.events.*;
import com.af.cep.model.AddContact;
import com.af.cep.vo.ContactVO;
import com.af.cep.model.ModelLocator;
[Bindable]
public var model : ModelLocator = ModelLocator.getInstance();
[Bindable]
public var addcontact : AddContact;
[Bindable]
public var contacts : ArrayCollection;
private function initComp():void {
//Cheat to do the datagrid updates
model.contactDG = dgContact;
// Get a list of contacts from the database.
//var event : GetContactsEvent = new GetContactsEvent();
//CairngormEventDispatcher.getInstance().dispatchEvent( event );
var contact:ContactVO = new ContactVO;
contact.name = "Chris Giametta";
contact.email = "chris.giametta@myemail.com";
contact.objectIdentifier = 0;
model.contacts.addItem(contact);
contact = new ContactVO;
contact.name = "Kristi Giametta";
contact.email = "kristi.giametta@myemail.com";
contact.objectIdentifier = 1;
model.contacts.addItem(contact);
contact = new ContactVO;
contact.name = "Kaitlyn Giametta";
contact.email = "kaitybug.giametta@myemail.com";
contact.objectIdentifier = 1;
model.contacts.addItem(contact);
contact = new ContactVO;
contact.name = "Cole Giametta";
contact.email = "cole.giametta@myemail.com";
contact.objectIdentifier = 1;
model.contacts.addItem(contact);
}
public function selectContact():void {
if(dgContact.selectedItem != null)
{
fullName.text = dgContact.selectedItem.name;
emailAddress.text = dgContact.selectedItem.email;
}
}
public function addContact() : void {
// bind to the addcontact model
addcontact = model.addcontact;
var contactVO : ContactVO = new ContactVO();
contactVO.name = fullName.text;
contactVO.email = emailAddress.text;
// Bind the new contact to the contactVO model object
model.addcontact.contactVO = contactVO;
var event : AddContactEvent = new AddContactEvent( contactVO );
CairngormEventDispatcher.getInstance().dispatchEvent( event );
clearFormItems();
}
public function deleteContact():void {
if(dgContact.selectedItem != null)
{
var contactVO : ContactVO = new ContactVO();
contactVO = ContactVO(dgContact.selectedItem);
var event : DeleteContactEvent = new DeleteContactEvent( contactVO );
CairngormEventDispatcher.getInstance().dispatchEvent( event );
clearFormItems();
}
}
public function updateContact():void {
if(dgContact.selectedItem != null)
{
// bind to the addcontact model
addcontact = model.addcontact;
var contactVO : ContactVO = new ContactVO();
contactVO.name = fullName.text;
contactVO.email = emailAddress.text;
contactVO.objectIdentifier = dgContact.selectedItem.objectIdentifier;
var event : UpdateContactEvent = new UpdateContactEvent( contactVO );
CairngormEventDispatcher.getInstance().dispatchEvent( event );
model.contact = contactVO;
clearFormItems();
}
}
public function clearFormItems():void {
fullName.text = "";
emailAddress.text = "";
}
public function navigateToAF(event:MouseEvent):void {
var u:URLRequest = new URLRequest("http://www.appfoundation.com");
navigateToURL(u,"_blank");
}
]]>
</mx:Script>
<mx:Binding source="model.contacts" destination="dgContact.dataProvider" />
<mx:Panel styleName="CustomPanelBlueGrey">
<mx:Panel height="100%" styleName="CustomPanelBlueGreen">
<mx:VBox height="100%">
<mx:ApplicationControlBar x="2" y="2" paddingTop="0" paddingLeft="3" horizontalGap="0"
width="100%" height="22" styleName="ApplicationControlBarBlack" cornerRadius="4">
<mx:Image source="assets/images/icon_halfArrowYellow.png"/>
<mx:Label text="MY CONTACTS" fontWeight="bold" color="white" fontSize="13" />
</mx:ApplicationControlBar>
<mx:HBox height="100%" styleName="greyFill">
<mx:VBox>
<mx:Form id="addcontactForm" width="100%">
<mx:HBox width="100%" horizontalAlign="left">
<mx:Text text="Maintain Contacts:" fontSize="12"/>
</mx:HBox>
<mx:FormItem label="Name: " width="100%">
<mx:TextInput id="fullName" width="100%" color="black"/>
</mx:FormItem>
<mx:FormItem label="Email: " width="100%">
<mx:TextInput id="emailAddress" width="100%" color="black"/>
</mx:FormItem>
<mx:HBox width="100%" horizontalAlign="right">
<mx:Button label="Add Contact" enabled="{ !addcontact.isPending }" click="addContact()" />
<mx:Button label="Update Contact" enabled="{ !addcontact.isPending }" click="updateContact()" />
<mx:Button label="Delete Contact" enabled="{ !addcontact.isPending }" click="deleteContact()" />
</mx:HBox>
</mx:Form>
</mx:VBox>
<mx:VRule height="100%" strokeColor="#DDDDDD"/>
<mx:VBox paddingTop="15" paddingLeft="15" paddingRight="15" paddingBottom="15">
<mx:Text text="Contact List:" fontSize="12"/>
<mx:DataGrid id="dgContact" height="243" color="white"
styleName="greyFill" change="selectContact()" click="selectContact()">
<mx:columns>
<mx:DataGridColumn headerText="Name" dataField="name"/>
<mx:DataGridColumn headerText="Email" dataField="email"/>
</mx:columns>
</mx:DataGrid>
</mx:VBox>
</mx:HBox>
</mx:VBox>
</mx:Panel>
<mx:HBox width="100%" >
<mx:Image source="assets/images/icon_appFoundationSmall.png" click="navigateToAF(event)"
alpha=".75" rollOverEffect="alphaFadeIn" rollOutEffect="alphaFadeOut"
toolTip="AppFoundation"/>
</mx:HBox>
</mx:Panel>
<!-- Effects -->
<mx:Fade id="alphaFadeOut" duration="350" alphaFrom="1.0" alphaTo="0.75"/>
<mx:Fade id="alphaFadeIn" duration="350" alphaFrom="0.75" alphaTo="1.0"/>
</mx:Canvas>