Subversion Repositories Applications.papyrus

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
1318 alexandre_ 1
/*
2
	Copyright (c) 2004-2006, The Dojo Foundation
3
	All Rights Reserved.
4
 
5
	Licensed under the Academic Free License version 2.1 or above OR the
6
	modified BSD license. For more information on Dojo licensing, see:
7
 
8
		http://dojotoolkit.org/community/licensing.shtml
9
*/
10
 
11
dojo.provide("dojo.widget.TreeLoadingControllerV3");
12
dojo.require("dojo.widget.TreeBasicControllerV3");
13
dojo.require("dojo.event.*");
14
dojo.require("dojo.json");
15
dojo.require("dojo.io.*");
16
dojo.require("dojo.Deferred");
17
dojo.require("dojo.DeferredList");
18
dojo.declare("dojo.Error", Error, function (message, extra) {
19
	this.message = message;
20
	this.extra = extra;
21
	this.stack = (new Error()).stack;
22
});
23
dojo.declare("dojo.CommunicationError", dojo.Error, function () {
24
	this.name = "CommunicationError";
25
});
26
dojo.declare("dojo.LockedError", dojo.Error, function () {
27
	this.name = "LockedError";
28
});
29
dojo.declare("dojo.FormatError", dojo.Error, function () {
30
	this.name = "FormatError";
31
});
32
dojo.declare("dojo.RpcError", dojo.Error, function () {
33
	this.name = "RpcError";
34
});
35
dojo.widget.defineWidget("dojo.widget.TreeLoadingControllerV3", dojo.widget.TreeBasicControllerV3, {RpcUrl:"", RpcActionParam:"action", preventCache:true, checkValidRpcResponse:function (type, obj) {
36
	if (type != "load") {
37
		var extra = {};
38
		for (var i = 1; i < arguments.length; i++) {
39
			dojo.lang.mixin(extra, arguments[i]);
40
		}
41
		return new dojo.CommunicationError(obj, extra);
42
	}
43
	if (typeof obj != "object") {
44
		return new dojo.FormatError("Wrong server answer format " + (obj && obj.toSource ? obj.toSource() : obj) + " type " + (typeof obj), obj);
45
	}
46
	if (!dojo.lang.isUndefined(obj.error)) {
47
		return new dojo.RpcError(obj.error, obj);
48
	}
49
	return false;
50
}, getDeferredBindHandler:function (deferred) {
51
	return dojo.lang.hitch(this, function (type, obj) {
52
		var error = this.checkValidRpcResponse.apply(this, arguments);
53
		if (error) {
54
			deferred.errback(error);
55
			return;
56
		}
57
		deferred.callback(obj);
58
	});
59
}, getRpcUrl:function (action) {
60
	if (this.RpcUrl == "local") {
61
		var dir = document.location.href.substr(0, document.location.href.lastIndexOf("/"));
62
		var localUrl = dir + "/local/" + action;
63
		return localUrl;
64
	}
65
	if (!this.RpcUrl) {
66
		dojo.raise("Empty RpcUrl: can't load");
67
	}
68
	var url = this.RpcUrl;
69
	if (url.indexOf("/") != 0) {
70
		var protocol = document.location.href.replace(/:\/\/.*/, "");
71
		var prefix = document.location.href.substring(protocol.length + 3);
72
		if (prefix.lastIndexOf("/") != prefix.length - 1) {
73
			prefix = prefix.replace(/\/[^\/]+$/, "/");
74
		}
75
		if (prefix.lastIndexOf("/") != prefix.length - 1) {
76
			prefix = prefix + "/";
77
		}
78
		url = protocol + "://" + prefix + url;
79
	}
80
	return url + (url.indexOf("?") > -1 ? "&" : "?") + this.RpcActionParam + "=" + action;
81
}, loadProcessResponse:function (node, result) {
82
	if (!dojo.lang.isArray(result)) {
83
		throw new dojo.FormatError("loadProcessResponse: Not array loaded: " + result);
84
	}
85
	node.setChildren(result);
86
}, runRpc:function (kw) {
87
	var _this = this;
88
	var deferred = new dojo.Deferred();
89
	dojo.io.bind({url:kw.url, handle:this.getDeferredBindHandler(deferred), mimetype:"text/javascript", preventCache:this.preventCache, sync:kw.sync, content:{data:dojo.json.serialize(kw.params)}});
90
	return deferred;
91
}, loadRemote:function (node, sync) {
92
	var _this = this;
93
	var params = {node:this.getInfo(node), tree:this.getInfo(node.tree)};
94
	var deferred = this.runRpc({url:this.getRpcUrl("getChildren"), sync:sync, params:params});
95
	deferred.addCallback(function (res) {
96
		return _this.loadProcessResponse(node, res);
97
	});
98
	return deferred;
99
}, batchExpandTimeout:0, recurseToLevel:function (widget, level, callFunc, callObj, skipFirst, sync) {
100
	if (level == 0) {
101
		return;
102
	}
103
	if (!skipFirst) {
104
		var deferred = callFunc.call(callObj, widget, sync);
105
	} else {
106
		var deferred = dojo.Deferred.prototype.makeCalled();
107
	}
108
	var _this = this;
109
	var recurseOnExpand = function () {
110
		var children = widget.children;
111
		var deferreds = [];
112
		for (var i = 0; i < children.length; i++) {
113
			deferreds.push(_this.recurseToLevel(children[i], level - 1, callFunc, callObj, sync));
114
		}
115
		return new dojo.DeferredList(deferreds);
116
	};
117
	deferred.addCallback(recurseOnExpand);
118
	return deferred;
119
}, expandToLevel:function (nodeOrTree, level, sync) {
120
	return this.recurseToLevel(nodeOrTree, nodeOrTree.isTree ? level + 1 : level, this.expand, this, nodeOrTree.isTree, sync);
121
}, loadToLevel:function (nodeOrTree, level, sync) {
122
	return this.recurseToLevel(nodeOrTree, nodeOrTree.isTree ? level + 1 : level, this.loadIfNeeded, this, nodeOrTree.isTree, sync);
123
}, loadAll:function (nodeOrTree, sync) {
124
	return this.loadToLevel(nodeOrTree, Number.POSITIVE_INFINITY, sync);
125
}, expand:function (node, sync) {
126
	var _this = this;
127
	var deferred = this.startProcessing(node);
128
	deferred.addCallback(function () {
129
		return _this.loadIfNeeded(node, sync);
130
	});
131
	deferred.addCallback(function (res) {
132
		dojo.widget.TreeBasicControllerV3.prototype.expand(node);
133
		return res;
134
	});
135
	deferred.addBoth(function (res) {
136
		_this.finishProcessing(node);
137
		return res;
138
	});
139
	return deferred;
140
}, loadIfNeeded:function (node, sync) {
141
	var deferred;
142
	if (node.state == node.loadStates.UNCHECKED && node.isFolder && !node.children.length) {
143
		deferred = this.loadRemote(node, sync);
144
	} else {
145
		deferred = new dojo.Deferred();
146
		deferred.callback();
147
	}
148
	return deferred;
149
}, runStages:function (check, prepare, make, finalize, expose, args) {
150
	var _this = this;
151
	if (check && !check.apply(this, args)) {
152
		return false;
153
	}
154
	var deferred = dojo.Deferred.prototype.makeCalled();
155
	if (prepare) {
156
		deferred.addCallback(function () {
157
			return prepare.apply(_this, args);
158
		});
159
	}
160
	if (make) {
161
		deferred.addCallback(function () {
162
			var res = make.apply(_this, args);
163
			return res;
164
		});
165
	}
166
	if (finalize) {
167
		deferred.addBoth(function (res) {
168
			finalize.apply(_this, args);
169
			return res;
170
		});
171
	}
172
	if (expose) {
173
		deferred.addCallback(function (res) {
174
			expose.apply(_this, args);
175
			return res;
176
		});
177
	}
178
	return deferred;
179
}, startProcessing:function (nodesArray) {
180
	var deferred = new dojo.Deferred();
181
	var nodes = dojo.lang.isArray(nodesArray) ? nodesArray : arguments;
182
	for (var i = 0; i < nodes.length; i++) {
183
		if (nodes[i].isLocked()) {
184
			deferred.errback(new dojo.LockedError("item locked " + nodes[i], nodes[i]));
185
			return deferred;
186
		}
187
		if (nodes[i].isTreeNode) {
188
			nodes[i].markProcessing();
189
		}
190
		nodes[i].lock();
191
	}
192
	deferred.callback();
193
	return deferred;
194
}, finishProcessing:function (nodesArray) {
195
	var nodes = dojo.lang.isArray(nodesArray) ? nodesArray : arguments;
196
	for (var i = 0; i < nodes.length; i++) {
197
		if (!nodes[i].hasLock()) {
198
			continue;
199
		}
200
		nodes[i].unlock();
201
		if (nodes[i].isTreeNode) {
202
			nodes[i].unmarkProcessing();
203
		}
204
	}
205
}, refreshChildren:function (nodeOrTree, sync) {
206
	return this.runStages(null, this.prepareRefreshChildren, this.doRefreshChildren, this.finalizeRefreshChildren, this.exposeRefreshChildren, arguments);
207
}, prepareRefreshChildren:function (nodeOrTree, sync) {
208
	var deferred = this.startProcessing(nodeOrTree);
209
	nodeOrTree.destroyChildren();
210
	nodeOrTree.state = nodeOrTree.loadStates.UNCHECKED;
211
	return deferred;
212
}, doRefreshChildren:function (nodeOrTree, sync) {
213
	return this.loadRemote(nodeOrTree, sync);
214
}, finalizeRefreshChildren:function (nodeOrTree, sync) {
215
	this.finishProcessing(nodeOrTree);
216
}, exposeRefreshChildren:function (nodeOrTree, sync) {
217
	nodeOrTree.expand();
218
}, move:function (child, newParent, index) {
219
	return this.runStages(this.canMove, this.prepareMove, this.doMove, this.finalizeMove, this.exposeMove, arguments);
220
}, doMove:function (child, newParent, index) {
221
	child.tree.move(child, newParent, index);
222
	return true;
223
}, prepareMove:function (child, newParent, index, sync) {
224
	var deferred = this.startProcessing(newParent);
225
	deferred.addCallback(dojo.lang.hitch(this, function () {
226
		return this.loadIfNeeded(newParent, sync);
227
	}));
228
	return deferred;
229
}, finalizeMove:function (child, newParent) {
230
	this.finishProcessing(newParent);
231
}, prepareCreateChild:function (parent, index, data, sync) {
232
	var deferred = this.startProcessing(parent);
233
	deferred.addCallback(dojo.lang.hitch(this, function () {
234
		return this.loadIfNeeded(parent, sync);
235
	}));
236
	return deferred;
237
}, finalizeCreateChild:function (parent) {
238
	this.finishProcessing(parent);
239
}, prepareClone:function (child, newParent, index, deep, sync) {
240
	var deferred = this.startProcessing(child, newParent);
241
	deferred.addCallback(dojo.lang.hitch(this, function () {
242
		return this.loadIfNeeded(newParent, sync);
243
	}));
244
	return deferred;
245
}, finalizeClone:function (child, newParent) {
246
	this.finishProcessing(child, newParent);
247
}});
248