various click-handling improvements/fixes
[potlatch2.git] / net / systemeD / halcyon / connection / Connection.as
1 package net.systemeD.halcyon.connection {
2
3     import flash.net.*;
4
5     import flash.events.EventDispatcher;
6     import flash.events.Event;
7
8         public class Connection extends EventDispatcher {
9
10         private static var connectionInstance:Connection = null;
11
12         protected static var policyURL:String;
13         protected static var apiBaseURL:String;
14         protected static var params:Object;
15
16         public static function getConnection(initparams:Object=null):Connection {
17             if ( connectionInstance == null ) {
18             
19                 params = initparams == null ? new Object() : initparams;
20                 policyURL = getParam("policy", "http://127.0.0.1:3000/api/crossdomain.xml");
21                 apiBaseURL = getParam("api", "http://127.0.0.1:3000/api/0.6/");
22                 var connectType:String = getParam("connection", "XML");
23                 
24                 if ( connectType == "XML" )
25                     connectionInstance = new XMLConnection();
26                 else
27                     connectionInstance = new AMFConnection();
28             }
29             return connectionInstance;
30         }
31
32         public static function getParam(name:String, defaultValue:String):String {
33             trace("Returning param "+name+" as "+(params[name] == null ? defaultValue : params[name]));
34             return params[name] == null ? defaultValue : params[name];
35         }
36
37         public static function get apiBase():String {
38             return apiBaseURL;
39         }
40
41         public static function get serverName():String {
42             return getParam("serverName", "Localhost");
43         }
44                 
45                 public static function getConnectionInstance():Connection {
46             return connectionInstance;
47                 }
48
49                 public function getEnvironment(responder:Responder):void {}
50
51         // connection events
52         public static var LOAD_STARTED:String = "load_started";
53         public static var LOAD_COMPLETED:String = "load_completed";
54         public static var SAVE_STARTED:String = "save_started";
55         public static var SAVE_COMPLETED:String = "save_completed";
56         public static var NEW_CHANGESET:String = "new_changeset";
57         public static var NEW_CHANGESET_ERROR:String = "new_changeset_error";
58         public static var NEW_NODE:String = "new_node";
59         public static var NEW_WAY:String = "new_way";
60         public static var NEW_RELATION:String = "new_relation";
61         public static var NEW_POI:String = "new_poi";
62         public static var TAG_CHANGE:String = "tag_change";
63         public static var NODE_MOVED:String = "node_moved";
64         public static var WAY_NODE_ADDED:String = "way_node_added";
65         public static var WAY_NODE_REMOVED:String = "way_node_removed";
66
67         // store the data we download
68         private var negativeID:Number = -1;
69         private var nodes:Object = {};
70         private var ways:Object = {};
71         private var relations:Object = {};
72         private var pois:Array = [];
73         private var changeset:Changeset = null;
74
75         protected function get nextNegative():Number {
76             return negativeID--;
77         }
78
79         protected function setNode(node:Node,queue:Boolean):void {
80             nodes[node.id] = node;
81             if (node.loaded) { sendEvent(new EntityEvent(NEW_NODE, node),queue); }
82         }
83
84         protected function setWay(way:Way,queue:Boolean):void {
85             ways[way.id] = way;
86             if (way.loaded) { sendEvent(new EntityEvent(NEW_WAY, way),queue); }
87         }
88
89         protected function setRelation(relation:Relation,queue:Boolean):void {
90             relations[relation.id] = relation;
91             if (relation.loaded) { sendEvent(new EntityEvent(NEW_RELATION, relation),queue); }
92         }
93
94         protected function renumberNode(oldID:Number, node:Node):void {
95             nodes[node.id] = node;
96             delete nodes[oldID];
97         }
98
99         protected function renumberWay(oldID:Number, way:Way):void {
100             ways[way.id] = way;
101             delete ways[oldID];
102         }
103
104         protected function renumberRelation(oldID:Number, relation:Relation):void {
105             relations[relation.id] = relation;
106             delete relations[oldID];
107         }
108
109                 public function sendEvent(e:*,queue:Boolean):void {
110                         // queue is only used for AMFConnection
111                         dispatchEvent(e);
112                 }
113
114         public function registerPOI(node:Node):void {
115             if ( pois.indexOf(node) < 0 ) {
116                 pois.push(node);
117                 sendEvent(new EntityEvent(NEW_POI, node),false);
118             }
119         }
120
121         protected function unregisterPOI(node:Node):void {
122             var index:uint = pois.indexOf(node);
123             if ( index >= 0 ) {
124                 pois.splice(index,1);
125             }
126         }
127
128         protected function setActiveChangeset(changeset:Changeset):void {
129             this.changeset = changeset;
130             sendEvent(new EntityEvent(NEW_CHANGESET, changeset),false);
131         }
132         
133         public function getNode(id:Number):Node {
134             return nodes[id];
135         }
136
137         public function getWay(id:Number):Way {
138             return ways[id];
139         }
140
141         public function getRelation(id:Number):Relation {
142             return relations[id];
143         }
144
145         public function createNode(tags:Object, lat:Number, lon:Number):Node {
146             var node:Node = new Node(nextNegative, 0, tags, true, lat, lon);
147             setNode(node,false);
148             return node;
149         }
150
151         public function createWay(tags:Object, nodes:Array):Way {
152             var way:Way = new Way(nextNegative, 0, tags, true, nodes.concat());
153             setWay(way,false);
154             return way;
155         }
156
157         public function createRelation(tags:Object, members:Array):Relation {
158             var relation:Relation = new Relation(nextNegative, 0, tags, true, members.concat());
159             setRelation(relation,false);
160             return relation;
161         }
162
163         public function getAllNodeIDs():Array {
164             var list:Array = [];
165             for each (var node:Node in nodes)
166                 list.push(node.id);
167             return list;
168         }
169
170         public function getAllWayIDs():Array {
171             var list:Array = [];
172             for each (var way:Way in ways)
173                 list.push(way.id);
174             return list;
175         }
176
177         public function getAllRelationIDs():Array {
178             var list:Array = [];
179             for each (var relation:Relation in relations)
180                 list.push(relation.id);
181             return list;
182         }
183
184         public function getActiveChangeset():Changeset {
185             return changeset;
186         }
187         
188         // these are functions that the Connection implementation is expected to
189         // provide. This class has some generic helpers for the implementation.
190                 public function loadBbox(left:Number, right:Number,
191                                                                 top:Number, bottom:Number):void {
192             }
193             
194             public function setAppID(id:Object):void {}
195             public function setAuthToken(id:Object):void {}
196             public function createChangeset(tags:Object):void {}
197             public function uploadChanges():void {}
198     }
199
200 }
201