root / trunk / web / dojo / dojox / widget / Toaster.js @ 12
History | View | Annotate | Download (4.85 KB)
1 | 9 | andrej.cim | /*
|
---|---|---|---|
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["dojox.widget.Toaster"]){ |
||
9 | dojo._hasResource["dojox.widget.Toaster"]=true; |
||
10 | dojo.provide("dojox.widget.Toaster");
|
||
11 | dojo.require("dojo.fx");
|
||
12 | dojo.require("dojo.window");
|
||
13 | dojo.require("dijit._Widget");
|
||
14 | dojo.require("dijit._Templated");
|
||
15 | dojo.declare("dojox.widget.Toaster",[dijit._Widget,dijit._Templated],{templateString:"<div class=\"dijitToasterClip\" dojoAttachPoint=\"clipNode\"><div class=\"dijitToasterContainer\" dojoAttachPoint=\"containerNode\" dojoAttachEvent=\"onclick:onSelect\"><div class=\"dijitToasterContent\" dojoAttachPoint=\"contentNode\"></div></div></div>",messageTopic:"",messageTypes:{MESSAGE:"message",WARNING:"warning",ERROR:"error",FATAL:"fatal"},defaultType:"message",positionDirection:"br-up",positionDirectionTypes:["br-up","br-left","bl-up","bl-right","tr-down","tr-left","tl-down","tl-right"],duration:2000,slideDuration:500,separator:"<hr></hr>",postCreate:function(){ |
||
16 | this.inherited(arguments); |
||
17 | this.hide();
|
||
18 | dojo.body().appendChild(this.domNode);
|
||
19 | if(this.messageTopic){ |
||
20 | dojo.subscribe(this.messageTopic,this,"_handleMessage"); |
||
21 | } |
||
22 | },_handleMessage:function(_1){ |
||
23 | if(dojo.isString(_1)){
|
||
24 | this.setContent(_1);
|
||
25 | }else{
|
||
26 | this.setContent(_1.message,_1.type,_1.duration);
|
||
27 | } |
||
28 | },_capitalize:function(w){ |
||
29 | return w.substring(0,1).toUpperCase()+w.substring(1); |
||
30 | },setContent:function(_2,_3,_4){ |
||
31 | _4=_4||this.duration;
|
||
32 | if(this.slideAnim){ |
||
33 | if(this.slideAnim.status()!="playing"){ |
||
34 | this.slideAnim.stop();
|
||
35 | } |
||
36 | if(this.slideAnim.status()=="playing"||(this.fadeAnim&&this.fadeAnim.status()=="playing")){ |
||
37 | setTimeout(dojo.hitch(this,function(){ |
||
38 | this.setContent(_2,_3,_4);
|
||
39 | }),50);
|
||
40 | return;
|
||
41 | } |
||
42 | } |
||
43 | for(var _5 in this.messageTypes){ |
||
44 | dojo.removeClass(this.containerNode,"dijitToaster"+this._capitalize(this.messageTypes[_5])); |
||
45 | } |
||
46 | dojo.style(this.containerNode,"opacity",1); |
||
47 | this._setContent(_2);
|
||
48 | dojo.addClass(this.containerNode,"dijitToaster"+this._capitalize(_3||this.defaultType)); |
||
49 | this.show();
|
||
50 | var _6=dojo.marginBox(this.containerNode); |
||
51 | this._cancelHideTimer();
|
||
52 | if(this.isVisible){ |
||
53 | this._placeClip();
|
||
54 | if(!this._stickyMessage){ |
||
55 | this._setHideTimer(_4);
|
||
56 | } |
||
57 | }else{
|
||
58 | var _7=this.containerNode.style; |
||
59 | var pd=this.positionDirection; |
||
60 | if(pd.indexOf("-up")>=0){ |
||
61 | _7.left=0+"px"; |
||
62 | _7.top=_6.h+10+"px"; |
||
63 | }else{
|
||
64 | if(pd.indexOf("-left")>=0){ |
||
65 | _7.left=_6.w+10+"px"; |
||
66 | _7.top=0+"px"; |
||
67 | }else{
|
||
68 | if(pd.indexOf("-right")>=0){ |
||
69 | _7.left=0-_6.w-10+"px"; |
||
70 | _7.top=0+"px"; |
||
71 | }else{
|
||
72 | if(pd.indexOf("-down")>=0){ |
||
73 | _7.left=0+"px"; |
||
74 | _7.top=0-_6.h-10+"px"; |
||
75 | }else{
|
||
76 | throw new Error(this.id+".positionDirection is invalid: "+pd); |
||
77 | } |
||
78 | } |
||
79 | } |
||
80 | } |
||
81 | this.slideAnim=dojo.fx.slideTo({node:this.containerNode,top:0,left:0,duration:this.slideDuration}); |
||
82 | this.connect(this.slideAnim,"onEnd",function(_8,_9){ |
||
83 | this.fadeAnim=dojo.fadeOut({node:this.containerNode,duration:1000}); |
||
84 | this.connect(this.fadeAnim,"onEnd",function(_a){ |
||
85 | this.isVisible=false; |
||
86 | this.hide();
|
||
87 | }); |
||
88 | this._setHideTimer(_4);
|
||
89 | this.connect(this,"onSelect",function(_b){ |
||
90 | this._cancelHideTimer();
|
||
91 | this._stickyMessage=false; |
||
92 | this.fadeAnim.play();
|
||
93 | }); |
||
94 | this.isVisible=true; |
||
95 | }); |
||
96 | this.slideAnim.play();
|
||
97 | } |
||
98 | },_setContent:function(_c){ |
||
99 | if(dojo.isFunction(_c)){
|
||
100 | _c(this);
|
||
101 | return;
|
||
102 | } |
||
103 | if(_c&&this.isVisible){ |
||
104 | _c=this.contentNode.innerHTML+this.separator+_c; |
||
105 | } |
||
106 | this.contentNode.innerHTML=_c;
|
||
107 | },_cancelHideTimer:function(){ |
||
108 | if(this._hideTimer){ |
||
109 | clearTimeout(this._hideTimer);
|
||
110 | this._hideTimer=null; |
||
111 | } |
||
112 | },_setHideTimer:function(_d){ |
||
113 | this._cancelHideTimer();
|
||
114 | if(_d>0){ |
||
115 | this._cancelHideTimer();
|
||
116 | this._hideTimer=setTimeout(dojo.hitch(this,function(_e){ |
||
117 | if(this.bgIframe&&this.bgIframe.iframe){ |
||
118 | this.bgIframe.iframe.style.display="none"; |
||
119 | } |
||
120 | this._hideTimer=null; |
||
121 | this._stickyMessage=false; |
||
122 | this.fadeAnim.play();
|
||
123 | }),_d); |
||
124 | }else{
|
||
125 | this._stickyMessage=true; |
||
126 | } |
||
127 | },_placeClip:function(){ |
||
128 | var _f=dojo.window.getBox();
|
||
129 | var _10=dojo.marginBox(this.containerNode); |
||
130 | var _11=this.clipNode.style; |
||
131 | _11.height=_10.h+"px";
|
||
132 | _11.width=_10.w+"px";
|
||
133 | var pd=this.positionDirection; |
||
134 | if(pd.match(/^t/)){ |
||
135 | _11.top=_f.t+"px";
|
||
136 | }else{
|
||
137 | if(pd.match(/^b/)){ |
||
138 | _11.top=(_f.h-_10.h-2+_f.t)+"px"; |
||
139 | } |
||
140 | } |
||
141 | if(pd.match(/^[tb]r-/)){ |
||
142 | _11.left=(_f.w-_10.w-1-_f.l)+"px"; |
||
143 | }else{
|
||
144 | if(pd.match(/^[tb]l-/)){ |
||
145 | _11.left=0+"px"; |
||
146 | } |
||
147 | } |
||
148 | _11.clip="rect(0px, "+_10.w+"px, "+_10.h+"px, 0px)"; |
||
149 | if(dojo.isIE){
|
||
150 | if(!this.bgIframe){ |
||
151 | this.clipNode.id=dijit.getUniqueId("dojox_widget_Toaster_clipNode"); |
||
152 | this.bgIframe=new dijit.BackgroundIframe(this.clipNode); |
||
153 | } |
||
154 | var _12=this.bgIframe.iframe; |
||
155 | if(_12){
|
||
156 | _12.style.display="block";
|
||
157 | } |
||
158 | } |
||
159 | },onSelect:function(e){ |
||
160 | },show:function(){ |
||
161 | dojo.style(this.domNode,"display","block"); |
||
162 | this._placeClip();
|
||
163 | if(!this._scrollConnected){ |
||
164 | this._scrollConnected=dojo.connect(window,"onscroll",this,this._placeClip); |
||
165 | } |
||
166 | },hide:function(){ |
||
167 | dojo.style(this.domNode,"display","none"); |
||
168 | if(this._scrollConnected){ |
||
169 | dojo.disconnect(this._scrollConnected);
|
||
170 | this._scrollConnected=false; |
||
171 | } |
||
172 | dojo.style(this.containerNode,"opacity",1); |
||
173 | }}); |
||
174 | } |