root / trunk / web / dojo / dijit / Tooltip.js @ 10
History | View | Annotate | Download (4.85 KB)
1 |
/*
|
---|---|
2 |
Copyright (c) 2004-2010, The Dojo Foundation All Rights Reserved.
|
3 |
Available via Academic Free License >= 2.1 OR the modified BSD license.
|
4 |
see: http://dojotoolkit.org/license for details
|
5 |
*/
|
6 |
|
7 |
|
8 |
if(!dojo._hasResource["dijit.Tooltip"]){ |
9 |
dojo._hasResource["dijit.Tooltip"]=true; |
10 |
dojo.provide("dijit.Tooltip");
|
11 |
dojo.require("dijit._Widget");
|
12 |
dojo.require("dijit._Templated");
|
13 |
dojo.declare("dijit._MasterTooltip",[dijit._Widget,dijit._Templated],{duration:dijit.defaultDuration,templateString:dojo.cache("dijit","templates/Tooltip.html","<div class=\"dijitTooltip dijitTooltipLeft\" id=\"dojoTooltip\">\n\t<div class=\"dijitTooltipContainer dijitTooltipContents\" dojoAttachPoint=\"containerNode\" waiRole='alert'></div>\n\t<div class=\"dijitTooltipConnector\"></div>\n</div>\n"),postCreate:function(){ |
14 |
dojo.body().appendChild(this.domNode);
|
15 |
this.bgIframe=new dijit.BackgroundIframe(this.domNode); |
16 |
this.fadeIn=dojo.fadeIn({node:this.domNode,duration:this.duration,onEnd:dojo.hitch(this,"_onShow")}); |
17 |
this.fadeOut=dojo.fadeOut({node:this.domNode,duration:this.duration,onEnd:dojo.hitch(this,"_onHide")}); |
18 |
},show:function(_1,_2,_3,_4){ |
19 |
if(this.aroundNode&&this.aroundNode===_2){ |
20 |
return;
|
21 |
} |
22 |
if(this.fadeOut.status()=="playing"){ |
23 |
this._onDeck=arguments; |
24 |
return;
|
25 |
} |
26 |
this.containerNode.innerHTML=_1;
|
27 |
var _5=dijit.placeOnScreenAroundElement(this.domNode,_2,dijit.getPopupAroundAlignment((_3&&_3.length)?_3:dijit.Tooltip.defaultPosition,!_4),dojo.hitch(this,"orient")); |
28 |
dojo.style(this.domNode,"opacity",0); |
29 |
this.fadeIn.play();
|
30 |
this.isShowingNow=true; |
31 |
this.aroundNode=_2;
|
32 |
},orient:function(_6,_7,_8){ |
33 |
_6.className="dijitTooltip "+{"BL-TL":"dijitTooltipBelow dijitTooltipABLeft","TL-BL":"dijitTooltipAbove dijitTooltipABLeft","BR-TR":"dijitTooltipBelow dijitTooltipABRight","TR-BR":"dijitTooltipAbove dijitTooltipABRight","BR-BL":"dijitTooltipRight","BL-BR":"dijitTooltipLeft"}[_7+"-"+_8]; |
34 |
},_onShow:function(){ |
35 |
if(dojo.isIE){
|
36 |
this.domNode.style.filter=""; |
37 |
} |
38 |
},hide:function(_9){ |
39 |
if(this._onDeck&&this._onDeck[1]==_9){ |
40 |
this._onDeck=null; |
41 |
}else{
|
42 |
if(this.aroundNode===_9){ |
43 |
this.fadeIn.stop();
|
44 |
this.isShowingNow=false; |
45 |
this.aroundNode=null; |
46 |
this.fadeOut.play();
|
47 |
}else{
|
48 |
} |
49 |
} |
50 |
},_onHide:function(){ |
51 |
this.domNode.style.cssText=""; |
52 |
this.containerNode.innerHTML=""; |
53 |
if(this._onDeck){ |
54 |
this.show.apply(this,this._onDeck); |
55 |
this._onDeck=null; |
56 |
} |
57 |
}}); |
58 |
dijit.showTooltip=function(_a,_b,_c,_d){ |
59 |
if(!dijit._masterTT){
|
60 |
dijit._masterTT=new dijit._MasterTooltip();
|
61 |
} |
62 |
return dijit._masterTT.show(_a,_b,_c,_d);
|
63 |
}; |
64 |
dijit.hideTooltip=function(_e){ |
65 |
if(!dijit._masterTT){
|
66 |
dijit._masterTT=new dijit._MasterTooltip();
|
67 |
} |
68 |
return dijit._masterTT.hide(_e);
|
69 |
}; |
70 |
dojo.declare("dijit.Tooltip",dijit._Widget,{label:"",showDelay:400,connectId:[],position:[],constructor:function(){ |
71 |
this._nodeConnectionsById={};
|
72 |
},_setConnectIdAttr:function(_f){ |
73 |
for(var _10 in this._nodeConnectionsById){ |
74 |
this.removeTarget(_10);
|
75 |
} |
76 |
dojo.forEach(dojo.isArrayLike(_f)?_f:[_f],this.addTarget,this); |
77 |
},_getConnectIdAttr:function(){ |
78 |
var ary=[];
|
79 |
for(var id in this._nodeConnectionsById){ |
80 |
ary.push(id); |
81 |
} |
82 |
return ary;
|
83 |
},addTarget:function(id){ |
84 |
var _11=dojo.byId(id);
|
85 |
if(!_11){
|
86 |
return;
|
87 |
} |
88 |
if(_11.id in this._nodeConnectionsById){ |
89 |
return;
|
90 |
} |
91 |
this._nodeConnectionsById[_11.id]=[this.connect(_11,"onmouseenter","_onTargetMouseEnter"),this.connect(_11,"onmouseleave","_onTargetMouseLeave"),this.connect(_11,"onfocus","_onTargetFocus"),this.connect(_11,"onblur","_onTargetBlur")]; |
92 |
},removeTarget:function(_12){ |
93 |
var id=_12.id||_12;
|
94 |
if(id in this._nodeConnectionsById){ |
95 |
dojo.forEach(this._nodeConnectionsById[id],this.disconnect,this); |
96 |
delete this._nodeConnectionsById[id]; |
97 |
} |
98 |
},postCreate:function(){ |
99 |
dojo.addClass(this.domNode,"dijitTooltipData"); |
100 |
},startup:function(){ |
101 |
this.inherited(arguments); |
102 |
var ids=this.connectId; |
103 |
dojo.forEach(dojo.isArrayLike(ids)?ids:[ids],this.addTarget,this); |
104 |
},_onTargetMouseEnter:function(e){ |
105 |
this._onHover(e);
|
106 |
},_onTargetMouseLeave:function(e){ |
107 |
this._onUnHover(e);
|
108 |
},_onTargetFocus:function(e){ |
109 |
this._focus=true; |
110 |
this._onHover(e);
|
111 |
},_onTargetBlur:function(e){ |
112 |
this._focus=false; |
113 |
this._onUnHover(e);
|
114 |
},_onHover:function(e){ |
115 |
if(!this._showTimer){ |
116 |
var _13=e.target;
|
117 |
this._showTimer=setTimeout(dojo.hitch(this,function(){ |
118 |
this.open(_13);
|
119 |
}),this.showDelay);
|
120 |
} |
121 |
},_onUnHover:function(e){ |
122 |
if(this._focus){ |
123 |
return;
|
124 |
} |
125 |
if(this._showTimer){ |
126 |
clearTimeout(this._showTimer);
|
127 |
delete this._showTimer; |
128 |
} |
129 |
this.close();
|
130 |
},open:function(_14){ |
131 |
if(this._showTimer){ |
132 |
clearTimeout(this._showTimer);
|
133 |
delete this._showTimer; |
134 |
} |
135 |
dijit.showTooltip(this.label||this.domNode.innerHTML,_14,this.position,!this.isLeftToRight()); |
136 |
this._connectNode=_14;
|
137 |
this.onShow(_14,this.position); |
138 |
},close:function(){ |
139 |
if(this._connectNode){ |
140 |
dijit.hideTooltip(this._connectNode);
|
141 |
delete this._connectNode; |
142 |
this.onHide();
|
143 |
} |
144 |
if(this._showTimer){ |
145 |
clearTimeout(this._showTimer);
|
146 |
delete this._showTimer; |
147 |
} |
148 |
},onShow:function(_15,_16){ |
149 |
},onHide:function(){ |
150 |
},uninitialize:function(){ |
151 |
this.close();
|
152 |
this.inherited(arguments); |
153 |
}}); |
154 |
dijit.Tooltip.defaultPosition=["after","before"]; |
155 |
} |