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.TreeDocIconExtension");
|
|
|
12 |
dojo.require("dojo.widget.HtmlWidget");
|
|
|
13 |
dojo.require("dojo.widget.TreeExtension");
|
|
|
14 |
dojo.widget.defineWidget("dojo.widget.TreeDocIconExtension", [dojo.widget.TreeExtension], {templateCssString:"\n/* CSS for TreeDocIconExtension */\n\n\n/* long vertical line under docIcon, connecting w/ children */\n.TreeStateChildrenYes-ExpandOpen .TreeIconContent {\n background-image : url('../templates/images/TreeV3/i_long.gif');\n background-repeat : no-repeat;\n background-position: 18px 9px;\n}\n\n/* close has higher priority */\n.TreeStateChildrenYes-ExpandClosed .TreeIconContent {\n background-image : url();\n}\n\n/* higher priotity: same length and appear after background-definition */\n.TreeStateChildrenNo-ExpandLeaf .TreeIconContent {\n background-image : url();\n}\n\n.TreeStateChildrenNo-ExpandClosed .TreeIconContent {\n background-image : url();\n}\n\n.TreeStateChildrenNo-ExpandOpen .TreeIconContent {\n background-image : url();\n}\n\n\n/* highest priority */\n.TreeIconDocument {\n background-image: url('../templates/images/TreeV3/document.gif');\n}\n\n.TreeExpandOpen .TreeIconFolder {\n background-image: url('../templates/images/TreeV3/open.gif');\n}\n\n.TreeExpandClosed .TreeIconFolder {\n background-image: url('../templates/images/TreeV3/closed.gif');\n}\n\n/* generic class for docIcon */\n.TreeIcon {\n width: 18px;\n height: 18px;\n float: left;\n display: inline;\n background-repeat : no-repeat;\n}\n\ndiv.TreeContent {\n margin-left: 36px;\n}\n", templateCssPath:dojo.uri.moduleUri("dojo.widget", "templates/TreeDocIcon.css"), listenTreeEvents:["afterChangeTree", "afterSetFolder", "afterUnsetFolder"], listenNodeFilter:function (elem) {
|
|
|
15 |
return elem instanceof dojo.widget.Widget;
|
|
|
16 |
}, getnodeDocType:function (node) {
|
|
|
17 |
var nodeDocType = node.getnodeDocType();
|
|
|
18 |
if (!nodeDocType) {
|
|
|
19 |
nodeDocType = node.isFolder ? "Folder" : "Document";
|
|
|
20 |
}
|
|
|
21 |
return nodeDocType;
|
|
|
22 |
}, setnodeDocTypeClass:function (node) {
|
|
|
23 |
var reg = new RegExp("(^|\\s)" + node.tree.classPrefix + "Icon\\w+", "g");
|
|
|
24 |
var clazz = dojo.html.getClass(node.iconNode).replace(reg, "") + " " + node.tree.classPrefix + "Icon" + this.getnodeDocType(node);
|
|
|
25 |
dojo.html.setClass(node.iconNode, clazz);
|
|
|
26 |
}, onAfterSetFolder:function (message) {
|
|
|
27 |
if (message.source.iconNode) {
|
|
|
28 |
this.setnodeDocTypeClass(message.source);
|
|
|
29 |
}
|
|
|
30 |
}, onAfterUnsetFolder:function (message) {
|
|
|
31 |
this.setnodeDocTypeClass(message.source);
|
|
|
32 |
}, listenNode:function (node) {
|
|
|
33 |
node.contentIconNode = document.createElement("div");
|
|
|
34 |
var clazz = node.tree.classPrefix + "IconContent";
|
|
|
35 |
if (dojo.render.html.ie) {
|
|
|
36 |
clazz = clazz + " " + node.tree.classPrefix + "IEIconContent";
|
|
|
37 |
}
|
|
|
38 |
dojo.html.setClass(node.contentIconNode, clazz);
|
|
|
39 |
node.contentNode.parentNode.replaceChild(node.contentIconNode, node.expandNode);
|
|
|
40 |
node.iconNode = document.createElement("div");
|
|
|
41 |
dojo.html.setClass(node.iconNode, node.tree.classPrefix + "Icon" + " " + node.tree.classPrefix + "Icon" + this.getnodeDocType(node));
|
|
|
42 |
node.contentIconNode.appendChild(node.expandNode);
|
|
|
43 |
node.contentIconNode.appendChild(node.iconNode);
|
|
|
44 |
dojo.dom.removeNode(node.contentNode);
|
|
|
45 |
node.contentIconNode.appendChild(node.contentNode);
|
|
|
46 |
}, onAfterChangeTree:function (message) {
|
|
|
47 |
var _this = this;
|
|
|
48 |
if (!message.oldTree || !this.listenedTrees[message.oldTree.widgetId]) {
|
|
|
49 |
this.processDescendants(message.node, this.listenNodeFilter, this.listenNode);
|
|
|
50 |
}
|
|
|
51 |
}});
|
|
|
52 |
|