Partial Fix #5654 - roojspacker - get it working as a doc tool...
[roojs1] / docs / symbols / src / Roo_bootstrap_MessageBox.js.html
1 <html><head><title>../roojs1/Roo/bootstrap/MessageBox.js</title><link rel="stylesheet" type="text/css" href="../../../css/highlight-js.css"/></head><body class="highlightpage"><code class="jsdoc-pretty"><span class="jsdoc-comment">/*
2  * - LGPL
3  *
4  * messagebox - can be used as a replace
5  * 
6  */
7 /**
8  * @class Roo.MessageBox
9  * Utility class for generating different styles of message boxes.  The alias Roo.Msg can also be used.
10  * Example usage:
11  *&lt;pre&gt;&lt;code&gt;
12 // Basic alert:
13 Roo.Msg.alert('Status', 'Changes saved successfully.');
14
15 // Prompt for user data:
16 Roo.Msg.prompt('Name', 'Please enter your name:', function(btn, text){
17     if (btn == 'ok'){
18         // process text value...
19     }
20 });
21
22 // Show a dialog using config options:
23 Roo.Msg.show({
24    title:'Save Changes?',
25    msg: 'Your are closing a tab that has unsaved changes. Would you like to save your changes?',
26    buttons: Roo.Msg.YESNOCANCEL,
27    fn: processResult,
28    animEl: 'elId'
29 });
30 &lt;/code&gt;&lt;/pre&gt;
31  * @singleton
32  */
33 </span><span class="jsdoc-var">Roo.bootstrap.MessageBox </span><span class="jsdoc-syntax">= </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(){
34     </span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">dlg</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">opt</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">mask</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">waitTimer</span><span class="jsdoc-syntax">;
35     </span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">bodyEl</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">msgEl</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">textboxEl</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">textareaEl</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">progressEl</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">pp</span><span class="jsdoc-syntax">;
36     </span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">activeTextEl</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">bwidth</span><span class="jsdoc-syntax">;
37
38     
39     </span><span class="jsdoc-comment">// private
40     </span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">handleButton </span><span class="jsdoc-syntax">= </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">button</span><span class="jsdoc-syntax">){
41         </span><span class="jsdoc-var">dlg.hide</span><span class="jsdoc-syntax">();
42         </span><span class="jsdoc-var">Roo.callback</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.fn</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">opt.scope</span><span class="jsdoc-syntax">||</span><span class="jsdoc-var">window</span><span class="jsdoc-syntax">, [</span><span class="jsdoc-var">button</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">activeTextEl.dom.value</span><span class="jsdoc-syntax">], 1);
43     };
44
45     </span><span class="jsdoc-comment">// private
46     </span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">handleHide </span><span class="jsdoc-syntax">= </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(){
47         </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt </span><span class="jsdoc-syntax">&amp;&amp; </span><span class="jsdoc-var">opt.cls</span><span class="jsdoc-syntax">){
48             </span><span class="jsdoc-var">dlg.el.removeClass</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.cls</span><span class="jsdoc-syntax">);
49         }
50         </span><span class="jsdoc-comment">//if(waitTimer){
51         //    Roo.TaskMgr.stop(waitTimer);
52         //    waitTimer = null;
53         //}
54     </span><span class="jsdoc-syntax">};
55
56     </span><span class="jsdoc-comment">// private
57     </span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">updateButtons </span><span class="jsdoc-syntax">= </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">b</span><span class="jsdoc-syntax">){
58         </span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">width </span><span class="jsdoc-syntax">= 0;
59         </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(!</span><span class="jsdoc-var">b</span><span class="jsdoc-syntax">){
60             </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">[</span><span class="jsdoc-string">&quot;ok&quot;</span><span class="jsdoc-syntax">]</span><span class="jsdoc-var">.hide</span><span class="jsdoc-syntax">();
61             </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">[</span><span class="jsdoc-string">&quot;cancel&quot;</span><span class="jsdoc-syntax">]</span><span class="jsdoc-var">.hide</span><span class="jsdoc-syntax">();
62             </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">[</span><span class="jsdoc-string">&quot;yes&quot;</span><span class="jsdoc-syntax">]</span><span class="jsdoc-var">.hide</span><span class="jsdoc-syntax">();
63             </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">[</span><span class="jsdoc-string">&quot;no&quot;</span><span class="jsdoc-syntax">]</span><span class="jsdoc-var">.hide</span><span class="jsdoc-syntax">();
64             </span><span class="jsdoc-comment">//dlg.footer.dom.style.display = 'none';
65             </span><span class="jsdoc-keyword">return </span><span class="jsdoc-var">width</span><span class="jsdoc-syntax">;
66         }
67         </span><span class="jsdoc-var">dlg.footerEl.dom.style.display </span><span class="jsdoc-syntax">= </span><span class="jsdoc-string">''</span><span class="jsdoc-syntax">;
68         </span><span class="jsdoc-keyword">for</span><span class="jsdoc-syntax">(</span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">k </span><span class="jsdoc-keyword">in </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">){
69             </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-keyword">typeof </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">[</span><span class="jsdoc-var">k</span><span class="jsdoc-syntax">] != </span><span class="jsdoc-string">&quot;function&quot;</span><span class="jsdoc-syntax">){
70                 </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">b</span><span class="jsdoc-syntax">[</span><span class="jsdoc-var">k</span><span class="jsdoc-syntax">]){
71                     </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">[</span><span class="jsdoc-var">k</span><span class="jsdoc-syntax">]</span><span class="jsdoc-var">.show</span><span class="jsdoc-syntax">();
72                     </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">[</span><span class="jsdoc-var">k</span><span class="jsdoc-syntax">]</span><span class="jsdoc-var">.setText</span><span class="jsdoc-syntax">(</span><span class="jsdoc-keyword">typeof </span><span class="jsdoc-var">b</span><span class="jsdoc-syntax">[</span><span class="jsdoc-var">k</span><span class="jsdoc-syntax">] == </span><span class="jsdoc-string">&quot;string&quot; </span><span class="jsdoc-syntax">? </span><span class="jsdoc-var">b</span><span class="jsdoc-syntax">[</span><span class="jsdoc-var">k</span><span class="jsdoc-syntax">] : </span><span class="jsdoc-var">Roo.bootstrap.MessageBox.buttonText</span><span class="jsdoc-syntax">[</span><span class="jsdoc-var">k</span><span class="jsdoc-syntax">]);
73                     </span><span class="jsdoc-var">width </span><span class="jsdoc-syntax">+= </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">[</span><span class="jsdoc-var">k</span><span class="jsdoc-syntax">]</span><span class="jsdoc-var">.el.getWidth</span><span class="jsdoc-syntax">()+15;
74                 }</span><span class="jsdoc-keyword">else</span><span class="jsdoc-syntax">{
75                     </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">[</span><span class="jsdoc-var">k</span><span class="jsdoc-syntax">]</span><span class="jsdoc-var">.hide</span><span class="jsdoc-syntax">();
76                 }
77             }
78         }
79         </span><span class="jsdoc-keyword">return </span><span class="jsdoc-var">width</span><span class="jsdoc-syntax">;
80     };
81
82     </span><span class="jsdoc-comment">// private
83     </span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">handleEsc </span><span class="jsdoc-syntax">= </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">d</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">k</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">e</span><span class="jsdoc-syntax">){
84         </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt </span><span class="jsdoc-syntax">&amp;&amp; </span><span class="jsdoc-var">opt.closable </span><span class="jsdoc-syntax">!== </span><span class="jsdoc-keyword">false</span><span class="jsdoc-syntax">){
85             </span><span class="jsdoc-var">dlg.hide</span><span class="jsdoc-syntax">();
86         }
87         </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">e</span><span class="jsdoc-syntax">){
88             </span><span class="jsdoc-var">e.stopEvent</span><span class="jsdoc-syntax">();
89         }
90     };
91
92     </span><span class="jsdoc-keyword">return </span><span class="jsdoc-syntax">{
93         </span><span class="jsdoc-comment">/**
94          * Returns a reference to the underlying {@link Roo.BasicDialog} element
95          * @return {Roo.BasicDialog} The BasicDialog element
96          */
97         </span><span class="jsdoc-var">getDialog </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(){
98            </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(!</span><span class="jsdoc-var">dlg</span><span class="jsdoc-syntax">){
99                 </span><span class="jsdoc-var">dlg </span><span class="jsdoc-syntax">= </span><span class="jsdoc-keyword">new </span><span class="jsdoc-var">Roo.bootstrap.Modal</span><span class="jsdoc-syntax">( {
100                     </span><span class="jsdoc-comment">//draggable: true,
101                     //resizable:false,
102                     //constraintoviewport:false,
103                     //fixedcenter:true,
104                     //collapsible : false,
105                     //shim:true,
106                     //modal: true,
107                 //    width: 'auto',
108                   //  height:100,
109                     //buttonAlign:&quot;center&quot;,
110                     </span><span class="jsdoc-var">closeClick </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(){
111                         </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt </span><span class="jsdoc-syntax">&amp;&amp; </span><span class="jsdoc-var">opt.buttons </span><span class="jsdoc-syntax">&amp;&amp; </span><span class="jsdoc-var">opt.buttons.no </span><span class="jsdoc-syntax">&amp;&amp; !</span><span class="jsdoc-var">opt.buttons.cancel</span><span class="jsdoc-syntax">){
112                             </span><span class="jsdoc-var">handleButton</span><span class="jsdoc-syntax">(</span><span class="jsdoc-string">&quot;no&quot;</span><span class="jsdoc-syntax">);
113                         }</span><span class="jsdoc-keyword">else</span><span class="jsdoc-syntax">{
114                             </span><span class="jsdoc-var">handleButton</span><span class="jsdoc-syntax">(</span><span class="jsdoc-string">&quot;cancel&quot;</span><span class="jsdoc-syntax">);
115                         }
116                     }
117                 });
118                 </span><span class="jsdoc-var">dlg.render</span><span class="jsdoc-syntax">();
119                 </span><span class="jsdoc-var">dlg.on</span><span class="jsdoc-syntax">(</span><span class="jsdoc-string">&quot;hide&quot;</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">handleHide</span><span class="jsdoc-syntax">);
120                 </span><span class="jsdoc-var">mask </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">dlg.mask</span><span class="jsdoc-syntax">;
121                 </span><span class="jsdoc-comment">//dlg.addKeyListener(27, handleEsc);
122                 </span><span class="jsdoc-var">buttons </span><span class="jsdoc-syntax">= {};
123                 </span><span class="jsdoc-var">this.buttons </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">;
124                 </span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">bt </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">this.buttonText</span><span class="jsdoc-syntax">;
125                 </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">[</span><span class="jsdoc-string">&quot;ok&quot;</span><span class="jsdoc-syntax">] = </span><span class="jsdoc-var">dlg.addButton</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">bt</span><span class="jsdoc-syntax">[</span><span class="jsdoc-string">&quot;ok&quot;</span><span class="jsdoc-syntax">], </span><span class="jsdoc-var">handleButton.createCallback</span><span class="jsdoc-syntax">(</span><span class="jsdoc-string">&quot;ok&quot;</span><span class="jsdoc-syntax">));
126                 </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">[</span><span class="jsdoc-string">&quot;yes&quot;</span><span class="jsdoc-syntax">] = </span><span class="jsdoc-var">dlg.addButton</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">bt</span><span class="jsdoc-syntax">[</span><span class="jsdoc-string">&quot;yes&quot;</span><span class="jsdoc-syntax">], </span><span class="jsdoc-var">handleButton.createCallback</span><span class="jsdoc-syntax">(</span><span class="jsdoc-string">&quot;yes&quot;</span><span class="jsdoc-syntax">));
127                 </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">[</span><span class="jsdoc-string">&quot;no&quot;</span><span class="jsdoc-syntax">] = </span><span class="jsdoc-var">dlg.addButton</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">bt</span><span class="jsdoc-syntax">[</span><span class="jsdoc-string">&quot;no&quot;</span><span class="jsdoc-syntax">], </span><span class="jsdoc-var">handleButton.createCallback</span><span class="jsdoc-syntax">(</span><span class="jsdoc-string">&quot;no&quot;</span><span class="jsdoc-syntax">));
128                 </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">[</span><span class="jsdoc-string">&quot;cancel&quot;</span><span class="jsdoc-syntax">] = </span><span class="jsdoc-var">dlg.addButton</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">bt</span><span class="jsdoc-syntax">[</span><span class="jsdoc-string">&quot;cancel&quot;</span><span class="jsdoc-syntax">], </span><span class="jsdoc-var">handleButton.createCallback</span><span class="jsdoc-syntax">(</span><span class="jsdoc-string">&quot;cancel&quot;</span><span class="jsdoc-syntax">));
129                 </span><span class="jsdoc-comment">//Roo.log(buttons);
130                 </span><span class="jsdoc-var">bodyEl </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">dlg.bodyEl.createChild</span><span class="jsdoc-syntax">({
131
132                     </span><span class="jsdoc-var">html</span><span class="jsdoc-syntax">:</span><span class="jsdoc-string">'&lt;span class=&quot;roo-mb-text&quot;&gt;&lt;/span&gt;&lt;br /&gt;&lt;input type=&quot;text&quot; class=&quot;roo-mb-input&quot; /&gt;' </span><span class="jsdoc-syntax">+
133                         </span><span class="jsdoc-string">'&lt;textarea class=&quot;roo-mb-textarea&quot;&gt;&lt;/textarea&gt;' </span><span class="jsdoc-syntax">+
134                         </span><span class="jsdoc-string">'&lt;div class=&quot;roo-mb-progress-wrap&quot;&gt;&lt;div class=&quot;roo-mb-progress&quot;&gt;&lt;div class=&quot;roo-mb-progress-bar&quot;&gt;&amp;#160;&lt;/div&gt;&lt;/div&gt;&lt;/div&gt;'
135                 </span><span class="jsdoc-syntax">});
136                 </span><span class="jsdoc-var">msgEl </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">bodyEl.dom.firstChild</span><span class="jsdoc-syntax">;
137                 </span><span class="jsdoc-var">textboxEl </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">Roo.get</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">bodyEl.dom.childNodes</span><span class="jsdoc-syntax">[2]);
138                 </span><span class="jsdoc-var">textboxEl.enableDisplayMode</span><span class="jsdoc-syntax">();
139                 </span><span class="jsdoc-var">textboxEl.addKeyListener</span><span class="jsdoc-syntax">([10,13], </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(){
140                     </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">dlg.isVisible</span><span class="jsdoc-syntax">() &amp;&amp; </span><span class="jsdoc-var">opt </span><span class="jsdoc-syntax">&amp;&amp; </span><span class="jsdoc-var">opt.buttons</span><span class="jsdoc-syntax">){
141                         </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.buttons.ok</span><span class="jsdoc-syntax">){
142                             </span><span class="jsdoc-var">handleButton</span><span class="jsdoc-syntax">(</span><span class="jsdoc-string">&quot;ok&quot;</span><span class="jsdoc-syntax">);
143                         }</span><span class="jsdoc-keyword">else if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.buttons.yes</span><span class="jsdoc-syntax">){
144                             </span><span class="jsdoc-var">handleButton</span><span class="jsdoc-syntax">(</span><span class="jsdoc-string">&quot;yes&quot;</span><span class="jsdoc-syntax">);
145                         }
146                     }
147                 });
148                 </span><span class="jsdoc-var">textareaEl </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">Roo.get</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">bodyEl.dom.childNodes</span><span class="jsdoc-syntax">[3]);
149                 </span><span class="jsdoc-var">textareaEl.enableDisplayMode</span><span class="jsdoc-syntax">();
150                 </span><span class="jsdoc-var">progressEl </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">Roo.get</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">bodyEl.dom.childNodes</span><span class="jsdoc-syntax">[4]);
151                 </span><span class="jsdoc-var">progressEl.enableDisplayMode</span><span class="jsdoc-syntax">();
152                 
153                 </span><span class="jsdoc-comment">// This is supposed to be the progessElement.. but I think it's controlling the height of everything..
154                 </span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">pf </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">progressEl.dom.firstChild</span><span class="jsdoc-syntax">;
155                 </span><span class="jsdoc-keyword">if </span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">pf</span><span class="jsdoc-syntax">) {
156                     </span><span class="jsdoc-var">pp </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">Roo.get</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">pf.firstChild</span><span class="jsdoc-syntax">);
157                     </span><span class="jsdoc-var">pp.setHeight</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">pf.offsetHeight</span><span class="jsdoc-syntax">);
158                 }
159                 
160             }
161             </span><span class="jsdoc-keyword">return </span><span class="jsdoc-var">dlg</span><span class="jsdoc-syntax">;
162         },
163
164         </span><span class="jsdoc-comment">/**
165          * Updates the message box body text
166          * @param {String} text (optional) Replaces the message box element's innerHTML with the specified string (defaults to
167          * the XHTML-compliant non-breaking space character '&amp;amp;#160;')
168          * @return {Roo.MessageBox} This message box
169          */
170         </span><span class="jsdoc-var">updateText </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">text</span><span class="jsdoc-syntax">)
171         {
172             </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(!</span><span class="jsdoc-var">dlg.isVisible</span><span class="jsdoc-syntax">() &amp;&amp; !</span><span class="jsdoc-var">opt.width</span><span class="jsdoc-syntax">){
173                 </span><span class="jsdoc-var">dlg.dialogEl.setStyle</span><span class="jsdoc-syntax">({ </span><span class="jsdoc-string">'max-width' </span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">this.maxWidth</span><span class="jsdoc-syntax">});
174                 </span><span class="jsdoc-comment">// dlg.resizeTo(this.maxWidth, 100); // forcing the height breaks long alerts()
175             </span><span class="jsdoc-syntax">}
176             </span><span class="jsdoc-var">msgEl.innerHTML </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">text </span><span class="jsdoc-syntax">|| </span><span class="jsdoc-string">'&amp;#160;'</span><span class="jsdoc-syntax">;
177       
178             </span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">cw </span><span class="jsdoc-syntax">=  </span><span class="jsdoc-var">Math.max</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">msgEl.offsetWidth</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">msgEl.parentNode.scrollWidth</span><span class="jsdoc-syntax">);
179             </span><span class="jsdoc-comment">//Roo.log(&quot;guesed size: &quot; + JSON.stringify([cw,msgEl.offsetWidth, msgEl.parentNode.scrollWidth]));
180             </span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">w </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">Math.max</span><span class="jsdoc-syntax">(
181                     </span><span class="jsdoc-var">Math.min</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.width </span><span class="jsdoc-syntax">|| </span><span class="jsdoc-var">cw </span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">this.maxWidth</span><span class="jsdoc-syntax">), 
182                     </span><span class="jsdoc-var">Math.max</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.minWidth </span><span class="jsdoc-syntax">|| </span><span class="jsdoc-var">this.minWidth</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">bwidth</span><span class="jsdoc-syntax">)
183             );
184             </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.prompt</span><span class="jsdoc-syntax">){
185                 </span><span class="jsdoc-var">activeTextEl.setWidth</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">w</span><span class="jsdoc-syntax">);
186             }
187             </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">dlg.isVisible</span><span class="jsdoc-syntax">()){
188                 </span><span class="jsdoc-var">dlg.fixedcenter </span><span class="jsdoc-syntax">= </span><span class="jsdoc-keyword">false</span><span class="jsdoc-syntax">;
189             }
190             </span><span class="jsdoc-comment">// to big, make it scroll. = But as usual stupid IE does not support
191             // !important..
192             
193             </span><span class="jsdoc-keyword">if </span><span class="jsdoc-syntax">( </span><span class="jsdoc-var">bodyEl.getHeight</span><span class="jsdoc-syntax">() &gt; (</span><span class="jsdoc-var">Roo.lib.Dom.getViewHeight</span><span class="jsdoc-syntax">() - 100)) {
194                 </span><span class="jsdoc-var">bodyEl.setHeight </span><span class="jsdoc-syntax">( </span><span class="jsdoc-var">Roo.lib.Dom.getViewHeight</span><span class="jsdoc-syntax">() - 100 );
195                 </span><span class="jsdoc-var">bodyEl.dom.style.overflowY </span><span class="jsdoc-syntax">= </span><span class="jsdoc-string">'auto' </span><span class="jsdoc-syntax">+ ( </span><span class="jsdoc-var">Roo.isIE </span><span class="jsdoc-syntax">? </span><span class="jsdoc-string">'' </span><span class="jsdoc-syntax">: </span><span class="jsdoc-string">' !important'</span><span class="jsdoc-syntax">);
196             } </span><span class="jsdoc-keyword">else </span><span class="jsdoc-syntax">{
197                 </span><span class="jsdoc-var">bodyEl.dom.style.height </span><span class="jsdoc-syntax">= </span><span class="jsdoc-string">''</span><span class="jsdoc-syntax">;
198                 </span><span class="jsdoc-var">bodyEl.dom.style.overflowY </span><span class="jsdoc-syntax">= </span><span class="jsdoc-string">''</span><span class="jsdoc-syntax">;
199             }
200             </span><span class="jsdoc-keyword">if </span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">cw </span><span class="jsdoc-syntax">&gt; </span><span class="jsdoc-var">w</span><span class="jsdoc-syntax">) {
201                 </span><span class="jsdoc-var">bodyEl.dom.style.get </span><span class="jsdoc-syntax">= </span><span class="jsdoc-string">'auto' </span><span class="jsdoc-syntax">+ ( </span><span class="jsdoc-var">Roo.isIE </span><span class="jsdoc-syntax">? </span><span class="jsdoc-string">'' </span><span class="jsdoc-syntax">: </span><span class="jsdoc-string">' !important'</span><span class="jsdoc-syntax">);
202             } </span><span class="jsdoc-keyword">else </span><span class="jsdoc-syntax">{
203                 </span><span class="jsdoc-var">bodyEl.dom.style.overflowX </span><span class="jsdoc-syntax">= </span><span class="jsdoc-string">''</span><span class="jsdoc-syntax">;
204             }
205             
206             </span><span class="jsdoc-var">dlg.setContentSize</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">w</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">bodyEl.getHeight</span><span class="jsdoc-syntax">());
207             </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">dlg.isVisible</span><span class="jsdoc-syntax">()){
208                 </span><span class="jsdoc-var">dlg.fixedcenter </span><span class="jsdoc-syntax">= </span><span class="jsdoc-keyword">true</span><span class="jsdoc-syntax">;
209             }
210             </span><span class="jsdoc-keyword">return </span><span class="jsdoc-var">this</span><span class="jsdoc-syntax">;
211         },
212
213         </span><span class="jsdoc-comment">/**
214          * Updates a progress-style message box's text and progress bar.  Only relevant on message boxes
215          * initiated via {@link Roo.MessageBox#progress} or by calling {@link Roo.MessageBox#show} with progress: true.
216          * @param {Number} value Any number between 0 and 1 (e.g., .5)
217          * @param {String} text (optional) If defined, the message box's body text is replaced with the specified string (defaults to undefined)
218          * @return {Roo.MessageBox} This message box
219          */
220         </span><span class="jsdoc-var">updateProgress </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">value</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">text</span><span class="jsdoc-syntax">){
221             </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">text</span><span class="jsdoc-syntax">){
222                 </span><span class="jsdoc-var">this.updateText</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">text</span><span class="jsdoc-syntax">);
223             }
224             
225             </span><span class="jsdoc-keyword">if </span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">pp</span><span class="jsdoc-syntax">) { </span><span class="jsdoc-comment">// weird bug on my firefox - for some reason this is not defined
226                 </span><span class="jsdoc-var">pp.setWidth</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">Math.floor</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">value</span><span class="jsdoc-syntax">*</span><span class="jsdoc-var">progressEl.dom.firstChild.offsetWidth</span><span class="jsdoc-syntax">));
227                 </span><span class="jsdoc-var">pp.setHeight</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">Math.floor</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">progressEl.dom.firstChild.offsetHeight</span><span class="jsdoc-syntax">));
228             }
229             </span><span class="jsdoc-keyword">return </span><span class="jsdoc-var">this</span><span class="jsdoc-syntax">;
230         },        
231
232         </span><span class="jsdoc-comment">/**
233          * Returns true if the message box is currently displayed
234          * @return {Boolean} True if the message box is visible, else false
235          */
236         </span><span class="jsdoc-var">isVisible </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(){
237             </span><span class="jsdoc-keyword">return </span><span class="jsdoc-var">dlg </span><span class="jsdoc-syntax">&amp;&amp; </span><span class="jsdoc-var">dlg.isVisible</span><span class="jsdoc-syntax">();  
238         },
239
240         </span><span class="jsdoc-comment">/**
241          * Hides the message box if it is displayed
242          */
243         </span><span class="jsdoc-var">hide </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(){
244             </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">this.isVisible</span><span class="jsdoc-syntax">()){
245                 </span><span class="jsdoc-var">dlg.hide</span><span class="jsdoc-syntax">();
246             }  
247         },
248
249         </span><span class="jsdoc-comment">/**
250          * Displays a new message box, or reinitializes an existing message box, based on the config options
251          * passed in. All functions (e.g. prompt, alert, etc) on MessageBox call this function internally.
252          * The following config object properties are supported:
253          * &lt;pre&gt;
254 Property    Type             Description
255 ----------  ---------------  ------------------------------------------------------------------------------------
256 animEl            String/Element   An id or Element from which the message box should animate as it opens and
257                                    closes (defaults to undefined)
258 buttons           Object/Boolean   A button config object (e.g., Roo.MessageBox.OKCANCEL or {ok:'Foo',
259                                    cancel:'Bar'}), or false to not show any buttons (defaults to false)
260 closable          Boolean          False to hide the top-right close button (defaults to true).  Note that
261                                    progress and wait dialogs will ignore this property and always hide the
262                                    close button as they can only be closed programmatically.
263 cls               String           A custom CSS class to apply to the message box element
264 defaultTextHeight Number           The default height in pixels of the message box's multiline textarea if
265                                    displayed (defaults to 75)
266 fn                Function         A callback function to execute after closing the dialog.  The arguments to the
267                                    function will be btn (the name of the button that was clicked, if applicable,
268                                    e.g. &quot;ok&quot;), and text (the value of the active text field, if applicable).
269                                    Progress and wait dialogs will ignore this option since they do not respond to
270                                    user actions and can only be closed programmatically, so any required function
271                                    should be called by the same code after it closes the dialog.
272 icon              String           A CSS class that provides a background image to be used as an icon for
273                                    the dialog (e.g., Roo.MessageBox.WARNING or 'custom-class', defaults to '')
274 maxWidth          Number           The maximum width in pixels of the message box (defaults to 600)
275 minWidth          Number           The minimum width in pixels of the message box (defaults to 100)
276 modal             Boolean          False to allow user interaction with the page while the message box is
277                                    displayed (defaults to true)
278 msg               String           A string that will replace the existing message box body text (defaults
279                                    to the XHTML-compliant non-breaking space character '&amp;#160;')
280 multiline         Boolean          True to prompt the user to enter multi-line text (defaults to false)
281 progress          Boolean          True to display a progress bar (defaults to false)
282 progressText      String           The text to display inside the progress bar if progress = true (defaults to '')
283 prompt            Boolean          True to prompt the user to enter single-line text (defaults to false)
284 proxyDrag         Boolean          True to display a lightweight proxy while dragging (defaults to false)
285 title             String           The title text
286 value             String           The string value to set into the active textbox element if displayed
287 wait              Boolean          True to display a progress bar (defaults to false)
288 width             Number           The width of the dialog in pixels
289 &lt;/pre&gt;
290          *
291          * Example usage:
292          * &lt;pre&gt;&lt;code&gt;
293 Roo.Msg.show({
294    title: 'Address',
295    msg: 'Please enter your address:',
296    width: 300,
297    buttons: Roo.MessageBox.OKCANCEL,
298    multiline: true,
299    fn: saveAddress,
300    animEl: 'addAddressBtn'
301 });
302 &lt;/code&gt;&lt;/pre&gt;
303          * @param {Object} config Configuration options
304          * @return {Roo.MessageBox} This message box
305          */
306         </span><span class="jsdoc-var">show </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">options</span><span class="jsdoc-syntax">)
307         {
308             
309             </span><span class="jsdoc-comment">// this causes nightmares if you show one dialog after another
310             // especially on callbacks..
311              
312             </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">this.isVisible</span><span class="jsdoc-syntax">()){
313                 
314                 </span><span class="jsdoc-var">this.hide</span><span class="jsdoc-syntax">();
315                 </span><span class="jsdoc-var">Roo.log</span><span class="jsdoc-syntax">(</span><span class="jsdoc-string">&quot;[Roo.Messagebox] Show called while message displayed:&quot; </span><span class="jsdoc-syntax">);
316                 </span><span class="jsdoc-var">Roo.log</span><span class="jsdoc-syntax">(</span><span class="jsdoc-string">&quot;Old Dialog Message:&quot; </span><span class="jsdoc-syntax">+  </span><span class="jsdoc-var">msgEl.innerHTML </span><span class="jsdoc-syntax">);
317                 </span><span class="jsdoc-var">Roo.log</span><span class="jsdoc-syntax">(</span><span class="jsdoc-string">&quot;New Dialog Message:&quot; </span><span class="jsdoc-syntax">+  </span><span class="jsdoc-var">options.msg </span><span class="jsdoc-syntax">)
318                 </span><span class="jsdoc-comment">//this.alert(&quot;ERROR&quot;, &quot;Multiple dialogs where displayed at the same time&quot;);
319                 //throw &quot;Roo.MessageBox ERROR : Multiple dialogs where displayed at the same time&quot;;
320                 
321             </span><span class="jsdoc-syntax">}
322             </span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">d </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">this.getDialog</span><span class="jsdoc-syntax">();
323             </span><span class="jsdoc-var">opt </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">options</span><span class="jsdoc-syntax">;
324             </span><span class="jsdoc-var">d.setTitle</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.title </span><span class="jsdoc-syntax">|| </span><span class="jsdoc-string">&quot;&amp;#160;&quot;</span><span class="jsdoc-syntax">);
325             </span><span class="jsdoc-var">d.closeEl.setDisplayed</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.closable </span><span class="jsdoc-syntax">!== </span><span class="jsdoc-keyword">false</span><span class="jsdoc-syntax">);
326             </span><span class="jsdoc-var">activeTextEl </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">textboxEl</span><span class="jsdoc-syntax">;
327             </span><span class="jsdoc-var">opt.prompt </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">opt.prompt </span><span class="jsdoc-syntax">|| (</span><span class="jsdoc-var">opt.multiline </span><span class="jsdoc-syntax">? </span><span class="jsdoc-keyword">true </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">false</span><span class="jsdoc-syntax">);
328             </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.prompt</span><span class="jsdoc-syntax">){
329                 </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.multiline</span><span class="jsdoc-syntax">){
330                     </span><span class="jsdoc-var">textboxEl.hide</span><span class="jsdoc-syntax">();
331                     </span><span class="jsdoc-var">textareaEl.show</span><span class="jsdoc-syntax">();
332                     </span><span class="jsdoc-var">textareaEl.setHeight</span><span class="jsdoc-syntax">(</span><span class="jsdoc-keyword">typeof </span><span class="jsdoc-var">opt.multiline </span><span class="jsdoc-syntax">== </span><span class="jsdoc-string">&quot;number&quot; </span><span class="jsdoc-syntax">?
333                         </span><span class="jsdoc-var">opt.multiline </span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">this.defaultTextHeight</span><span class="jsdoc-syntax">);
334                     </span><span class="jsdoc-var">activeTextEl </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">textareaEl</span><span class="jsdoc-syntax">;
335                 }</span><span class="jsdoc-keyword">else</span><span class="jsdoc-syntax">{
336                     </span><span class="jsdoc-var">textboxEl.show</span><span class="jsdoc-syntax">();
337                     </span><span class="jsdoc-var">textareaEl.hide</span><span class="jsdoc-syntax">();
338                 }
339             }</span><span class="jsdoc-keyword">else</span><span class="jsdoc-syntax">{
340                 </span><span class="jsdoc-var">textboxEl.hide</span><span class="jsdoc-syntax">();
341                 </span><span class="jsdoc-var">textareaEl.hide</span><span class="jsdoc-syntax">();
342             }
343             </span><span class="jsdoc-var">progressEl.setDisplayed</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.progress </span><span class="jsdoc-syntax">=== </span><span class="jsdoc-keyword">true</span><span class="jsdoc-syntax">);
344             </span><span class="jsdoc-var">this.updateProgress</span><span class="jsdoc-syntax">(0);
345             </span><span class="jsdoc-var">activeTextEl.dom.value </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">opt.value </span><span class="jsdoc-syntax">|| </span><span class="jsdoc-string">&quot;&quot;</span><span class="jsdoc-syntax">;
346             </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.prompt</span><span class="jsdoc-syntax">){
347                 </span><span class="jsdoc-var">dlg.setDefaultButton</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">activeTextEl</span><span class="jsdoc-syntax">);
348             }</span><span class="jsdoc-keyword">else</span><span class="jsdoc-syntax">{
349                 </span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">bs </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">opt.buttons</span><span class="jsdoc-syntax">;
350                 </span><span class="jsdoc-keyword">var </span><span class="jsdoc-var">db </span><span class="jsdoc-syntax">= </span><span class="jsdoc-keyword">null</span><span class="jsdoc-syntax">;
351                 </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">bs </span><span class="jsdoc-syntax">&amp;&amp; </span><span class="jsdoc-var">bs.ok</span><span class="jsdoc-syntax">){
352                     </span><span class="jsdoc-var">db </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">[</span><span class="jsdoc-string">&quot;ok&quot;</span><span class="jsdoc-syntax">];
353                 }</span><span class="jsdoc-keyword">else if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">bs </span><span class="jsdoc-syntax">&amp;&amp; </span><span class="jsdoc-var">bs.yes</span><span class="jsdoc-syntax">){
354                     </span><span class="jsdoc-var">db </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">[</span><span class="jsdoc-string">&quot;yes&quot;</span><span class="jsdoc-syntax">];
355                 }
356                 </span><span class="jsdoc-var">dlg.setDefaultButton</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">db</span><span class="jsdoc-syntax">);
357             }
358             </span><span class="jsdoc-var">bwidth </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">updateButtons</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.buttons</span><span class="jsdoc-syntax">);
359             </span><span class="jsdoc-var">this.updateText</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.msg</span><span class="jsdoc-syntax">);
360             </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.cls</span><span class="jsdoc-syntax">){
361                 </span><span class="jsdoc-var">d.el.addClass</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">opt.cls</span><span class="jsdoc-syntax">);
362             }
363             </span><span class="jsdoc-var">d.proxyDrag </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">opt.proxyDrag </span><span class="jsdoc-syntax">=== </span><span class="jsdoc-keyword">true</span><span class="jsdoc-syntax">;
364             </span><span class="jsdoc-var">d.modal </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">opt.modal </span><span class="jsdoc-syntax">!== </span><span class="jsdoc-keyword">false</span><span class="jsdoc-syntax">;
365             </span><span class="jsdoc-var">d.mask </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">opt.modal </span><span class="jsdoc-syntax">!== </span><span class="jsdoc-keyword">false </span><span class="jsdoc-syntax">? </span><span class="jsdoc-var">mask </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">false</span><span class="jsdoc-syntax">;
366             </span><span class="jsdoc-keyword">if</span><span class="jsdoc-syntax">(!</span><span class="jsdoc-var">d.isVisible</span><span class="jsdoc-syntax">()){
367                 </span><span class="jsdoc-comment">// force it to the end of the z-index stack so it gets a cursor in FF
368                 </span><span class="jsdoc-var">document.body.appendChild</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">dlg.el.dom</span><span class="jsdoc-syntax">);
369                 </span><span class="jsdoc-var">d.animateTarget </span><span class="jsdoc-syntax">= </span><span class="jsdoc-keyword">null</span><span class="jsdoc-syntax">;
370                 </span><span class="jsdoc-var">d.show</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">options.animEl</span><span class="jsdoc-syntax">);
371             }
372             </span><span class="jsdoc-keyword">return </span><span class="jsdoc-var">this</span><span class="jsdoc-syntax">;
373         },
374
375         </span><span class="jsdoc-comment">/**
376          * Displays a message box with a progress bar.  This message box has no buttons and is not closeable by
377          * the user.  You are responsible for updating the progress bar as needed via {@link Roo.MessageBox#updateProgress}
378          * and closing the message box when the process is complete.
379          * @param {String} title The title bar text
380          * @param {String} msg The message box body text
381          * @return {Roo.MessageBox} This message box
382          */
383         </span><span class="jsdoc-var">progress </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">title</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">msg</span><span class="jsdoc-syntax">){
384             </span><span class="jsdoc-var">this.show</span><span class="jsdoc-syntax">({
385                 </span><span class="jsdoc-var">title </span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">title</span><span class="jsdoc-syntax">,
386                 </span><span class="jsdoc-var">msg </span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">msg</span><span class="jsdoc-syntax">,
387                 </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">false</span><span class="jsdoc-syntax">,
388                 </span><span class="jsdoc-var">progress</span><span class="jsdoc-syntax">:</span><span class="jsdoc-keyword">true</span><span class="jsdoc-syntax">,
389                 </span><span class="jsdoc-var">closable</span><span class="jsdoc-syntax">:</span><span class="jsdoc-keyword">false</span><span class="jsdoc-syntax">,
390                 </span><span class="jsdoc-var">minWidth</span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">this.minProgressWidth</span><span class="jsdoc-syntax">,
391                 </span><span class="jsdoc-var">modal </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">true
392             </span><span class="jsdoc-syntax">});
393             </span><span class="jsdoc-keyword">return </span><span class="jsdoc-var">this</span><span class="jsdoc-syntax">;
394         },
395
396         </span><span class="jsdoc-comment">/**
397          * Displays a standard read-only message box with an OK button (comparable to the basic JavaScript Window.alert).
398          * If a callback function is passed it will be called after the user clicks the button, and the
399          * id of the button that was clicked will be passed as the only parameter to the callback
400          * (could also be the top-right close button).
401          * @param {String} title The title bar text
402          * @param {String} msg The message box body text
403          * @param {Function} fn (optional) The callback function invoked after the message box is closed
404          * @param {Object} scope (optional) The scope of the callback function
405          * @return {Roo.MessageBox} This message box
406          */
407         </span><span class="jsdoc-var">alert </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">title</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">msg</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">fn</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">scope</span><span class="jsdoc-syntax">)
408         {
409             </span><span class="jsdoc-var">this.show</span><span class="jsdoc-syntax">({
410                 </span><span class="jsdoc-var">title </span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">title</span><span class="jsdoc-syntax">,
411                 </span><span class="jsdoc-var">msg </span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">msg</span><span class="jsdoc-syntax">,
412                 </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">this.OK</span><span class="jsdoc-syntax">,
413                 </span><span class="jsdoc-var">fn</span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">fn</span><span class="jsdoc-syntax">,
414                 </span><span class="jsdoc-var">closable </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">false</span><span class="jsdoc-syntax">,
415                 </span><span class="jsdoc-var">scope </span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">scope</span><span class="jsdoc-syntax">,
416                 </span><span class="jsdoc-var">modal </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">true
417             </span><span class="jsdoc-syntax">});
418             </span><span class="jsdoc-keyword">return </span><span class="jsdoc-var">this</span><span class="jsdoc-syntax">;
419         },
420
421         </span><span class="jsdoc-comment">/**
422          * Displays a message box with an infinitely auto-updating progress bar.  This can be used to block user
423          * interaction while waiting for a long-running process to complete that does not have defined intervals.
424          * You are responsible for closing the message box when the process is complete.
425          * @param {String} msg The message box body text
426          * @param {String} title (optional) The title bar text
427          * @return {Roo.MessageBox} This message box
428          */
429         </span><span class="jsdoc-var">wait </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">msg</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">title</span><span class="jsdoc-syntax">){
430             </span><span class="jsdoc-var">this.show</span><span class="jsdoc-syntax">({
431                 </span><span class="jsdoc-var">title </span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">title</span><span class="jsdoc-syntax">,
432                 </span><span class="jsdoc-var">msg </span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">msg</span><span class="jsdoc-syntax">,
433                 </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">false</span><span class="jsdoc-syntax">,
434                 </span><span class="jsdoc-var">closable</span><span class="jsdoc-syntax">:</span><span class="jsdoc-keyword">false</span><span class="jsdoc-syntax">,
435                 </span><span class="jsdoc-var">progress</span><span class="jsdoc-syntax">:</span><span class="jsdoc-keyword">true</span><span class="jsdoc-syntax">,
436                 </span><span class="jsdoc-var">modal</span><span class="jsdoc-syntax">:</span><span class="jsdoc-keyword">true</span><span class="jsdoc-syntax">,
437                 </span><span class="jsdoc-var">width</span><span class="jsdoc-syntax">:300,
438                 </span><span class="jsdoc-var">wait</span><span class="jsdoc-syntax">:</span><span class="jsdoc-keyword">true
439             </span><span class="jsdoc-syntax">});
440             </span><span class="jsdoc-var">waitTimer </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">Roo.TaskMgr.start</span><span class="jsdoc-syntax">({
441                 </span><span class="jsdoc-var">run</span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">i</span><span class="jsdoc-syntax">){
442                     </span><span class="jsdoc-var">Roo.MessageBox.updateProgress</span><span class="jsdoc-syntax">(((((</span><span class="jsdoc-var">i</span><span class="jsdoc-syntax">+20)%20)+1)*5)*</span><span class="jsdoc-var">.</span><span class="jsdoc-syntax">01);
443                 },
444                 </span><span class="jsdoc-var">interval</span><span class="jsdoc-syntax">: 1000
445             });
446             </span><span class="jsdoc-keyword">return </span><span class="jsdoc-var">this</span><span class="jsdoc-syntax">;
447         },
448
449         </span><span class="jsdoc-comment">/**
450          * Displays a confirmation message box with Yes and No buttons (comparable to JavaScript's Window.confirm).
451          * If a callback function is passed it will be called after the user clicks either button, and the id of the
452          * button that was clicked will be passed as the only parameter to the callback (could also be the top-right close button).
453          * @param {String} title The title bar text
454          * @param {String} msg The message box body text
455          * @param {Function} fn (optional) The callback function invoked after the message box is closed
456          * @param {Object} scope (optional) The scope of the callback function
457          * @return {Roo.MessageBox} This message box
458          */
459         </span><span class="jsdoc-var">confirm </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">title</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">msg</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">fn</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">scope</span><span class="jsdoc-syntax">){
460             </span><span class="jsdoc-var">this.show</span><span class="jsdoc-syntax">({
461                 </span><span class="jsdoc-var">title </span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">title</span><span class="jsdoc-syntax">,
462                 </span><span class="jsdoc-var">msg </span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">msg</span><span class="jsdoc-syntax">,
463                 </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">this.YESNO</span><span class="jsdoc-syntax">,
464                 </span><span class="jsdoc-var">fn</span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">fn</span><span class="jsdoc-syntax">,
465                 </span><span class="jsdoc-var">scope </span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">scope</span><span class="jsdoc-syntax">,
466                 </span><span class="jsdoc-var">modal </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">true
467             </span><span class="jsdoc-syntax">});
468             </span><span class="jsdoc-keyword">return </span><span class="jsdoc-var">this</span><span class="jsdoc-syntax">;
469         },
470
471         </span><span class="jsdoc-comment">/**
472          * Displays a message box with OK and Cancel buttons prompting the user to enter some text (comparable to
473          * JavaScript's Window.prompt).  The prompt can be a single-line or multi-line textbox.  If a callback function
474          * is passed it will be called after the user clicks either button, and the id of the button that was clicked
475          * (could also be the top-right close button) and the text that was entered will be passed as the two
476          * parameters to the callback.
477          * @param {String} title The title bar text
478          * @param {String} msg The message box body text
479          * @param {Function} fn (optional) The callback function invoked after the message box is closed
480          * @param {Object} scope (optional) The scope of the callback function
481          * @param {Boolean/Number} multiline (optional) True to create a multiline textbox using the defaultTextHeight
482          * property, or the height in pixels to create the textbox (defaults to false / single-line)
483          * @return {Roo.MessageBox} This message box
484          */
485         </span><span class="jsdoc-var">prompt </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">function</span><span class="jsdoc-syntax">(</span><span class="jsdoc-var">title</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">msg</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">fn</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">scope</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">multiline</span><span class="jsdoc-syntax">){
486             </span><span class="jsdoc-var">this.show</span><span class="jsdoc-syntax">({
487                 </span><span class="jsdoc-var">title </span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">title</span><span class="jsdoc-syntax">,
488                 </span><span class="jsdoc-var">msg </span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">msg</span><span class="jsdoc-syntax">,
489                 </span><span class="jsdoc-var">buttons</span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">this.OKCANCEL</span><span class="jsdoc-syntax">,
490                 </span><span class="jsdoc-var">fn</span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">fn</span><span class="jsdoc-syntax">,
491                 </span><span class="jsdoc-var">minWidth</span><span class="jsdoc-syntax">:250,
492                 </span><span class="jsdoc-var">scope </span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">scope</span><span class="jsdoc-syntax">,
493                 </span><span class="jsdoc-var">prompt</span><span class="jsdoc-syntax">:</span><span class="jsdoc-keyword">true</span><span class="jsdoc-syntax">,
494                 </span><span class="jsdoc-var">multiline</span><span class="jsdoc-syntax">: </span><span class="jsdoc-var">multiline</span><span class="jsdoc-syntax">,
495                 </span><span class="jsdoc-var">modal </span><span class="jsdoc-syntax">: </span><span class="jsdoc-keyword">true
496             </span><span class="jsdoc-syntax">});
497             </span><span class="jsdoc-keyword">return </span><span class="jsdoc-var">this</span><span class="jsdoc-syntax">;
498         },
499
500         </span><span class="jsdoc-comment">/**
501          * Button config that displays a single OK button
502          * @type Object
503          */
504         </span><span class="jsdoc-var">OK </span><span class="jsdoc-syntax">: {</span><span class="jsdoc-var">ok</span><span class="jsdoc-syntax">:</span><span class="jsdoc-keyword">true</span><span class="jsdoc-syntax">},
505         </span><span class="jsdoc-comment">/**
506          * Button config that displays Yes and No buttons
507          * @type Object
508          */
509         </span><span class="jsdoc-var">YESNO </span><span class="jsdoc-syntax">: {</span><span class="jsdoc-var">yes</span><span class="jsdoc-syntax">:</span><span class="jsdoc-keyword">true</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">no</span><span class="jsdoc-syntax">:</span><span class="jsdoc-keyword">true</span><span class="jsdoc-syntax">},
510         </span><span class="jsdoc-comment">/**
511          * Button config that displays OK and Cancel buttons
512          * @type Object
513          */
514         </span><span class="jsdoc-var">OKCANCEL </span><span class="jsdoc-syntax">: {</span><span class="jsdoc-var">ok</span><span class="jsdoc-syntax">:</span><span class="jsdoc-keyword">true</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">cancel</span><span class="jsdoc-syntax">:</span><span class="jsdoc-keyword">true</span><span class="jsdoc-syntax">},
515         </span><span class="jsdoc-comment">/**
516          * Button config that displays Yes, No and Cancel buttons
517          * @type Object
518          */
519         </span><span class="jsdoc-var">YESNOCANCEL </span><span class="jsdoc-syntax">: {</span><span class="jsdoc-var">yes</span><span class="jsdoc-syntax">:</span><span class="jsdoc-keyword">true</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">no</span><span class="jsdoc-syntax">:</span><span class="jsdoc-keyword">true</span><span class="jsdoc-syntax">, </span><span class="jsdoc-var">cancel</span><span class="jsdoc-syntax">:</span><span class="jsdoc-keyword">true</span><span class="jsdoc-syntax">},
520
521         </span><span class="jsdoc-comment">/**
522          * The default height in pixels of the message box's multiline textarea if displayed (defaults to 75)
523          * @type Number
524          */
525         </span><span class="jsdoc-var">defaultTextHeight </span><span class="jsdoc-syntax">: 75,
526         </span><span class="jsdoc-comment">/**
527          * The maximum width in pixels of the message box (defaults to 600)
528          * @type Number
529          */
530         </span><span class="jsdoc-var">maxWidth </span><span class="jsdoc-syntax">: 600,
531         </span><span class="jsdoc-comment">/**
532          * The minimum width in pixels of the message box (defaults to 100)
533          * @type Number
534          */
535         </span><span class="jsdoc-var">minWidth </span><span class="jsdoc-syntax">: 100,
536         </span><span class="jsdoc-comment">/**
537          * The minimum width in pixels of the message box if it is a progress-style dialog.  This is useful
538          * for setting a different minimum width than text-only dialogs may need (defaults to 250)
539          * @type Number
540          */
541         </span><span class="jsdoc-var">minProgressWidth </span><span class="jsdoc-syntax">: 250,
542         </span><span class="jsdoc-comment">/**
543          * An object containing the default button text strings that can be overriden for localized language support.
544          * Supported properties are: ok, cancel, yes and no.
545          * Customize the default text like so: Roo.MessageBox.buttonText.yes = &quot;S?&quot;;
546          * @type Object
547          */
548         </span><span class="jsdoc-var">buttonText </span><span class="jsdoc-syntax">: {
549             </span><span class="jsdoc-var">ok </span><span class="jsdoc-syntax">: </span><span class="jsdoc-string">&quot;OK&quot;</span><span class="jsdoc-syntax">,
550             </span><span class="jsdoc-var">cancel </span><span class="jsdoc-syntax">: </span><span class="jsdoc-string">&quot;Cancel&quot;</span><span class="jsdoc-syntax">,
551             </span><span class="jsdoc-var">yes </span><span class="jsdoc-syntax">: </span><span class="jsdoc-string">&quot;Yes&quot;</span><span class="jsdoc-syntax">,
552             </span><span class="jsdoc-var">no </span><span class="jsdoc-syntax">: </span><span class="jsdoc-string">&quot;No&quot;
553         </span><span class="jsdoc-syntax">}
554     };
555 }();
556
557 </span><span class="jsdoc-comment">/**
558  * Shorthand for {@link Roo.MessageBox}
559  */
560 </span><span class="jsdoc-var">Roo.MessageBox </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">Roo.MessageBox </span><span class="jsdoc-syntax">|| </span><span class="jsdoc-var">Roo.bootstrap.MessageBox</span><span class="jsdoc-syntax">;
561 </span><span class="jsdoc-var">Roo.Msg </span><span class="jsdoc-syntax">= </span><span class="jsdoc-var">Roo.Msg </span><span class="jsdoc-syntax">|| </span><span class="jsdoc-var">Roo.MessageBox</span><span class="jsdoc-syntax">;
562 </span></code></body></html>