root / trunk / web / dojo / dojox / mobile / app / TextBox.js
History | View | Annotate | Download (3.94 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["dojox.mobile.app.TextBox"]){ |
9 |
dojo._hasResource["dojox.mobile.app.TextBox"]=true; |
10 |
dojo.provide("dojox.mobile.app.TextBox");
|
11 |
dojo.experimental("dojox.mobile.app.TextBox");
|
12 |
dojo.require("dojox.mobile.app._Widget");
|
13 |
dojo.require("dojox.mobile.app._FormWidget");
|
14 |
dojo.declare("dojox.mobile.app.TextBox",dojox.mobile.app._FormValueWidget,{trim:false,uppercase:false,lowercase:false,propercase:false,maxLength:"",selectOnClick:false,placeHolder:"",baseClass:"mblTextBox",attributeMap:dojo.delegate(dojox.mobile.app._FormValueWidget.prototype.attributeMap,{maxLength:"focusNode"}),buildRendering:function(){ |
15 |
var _1=this.srcNodeRef; |
16 |
if(!_1||_1.tagName!="INPUT"){ |
17 |
_1=dojo.create("input",{});
|
18 |
} |
19 |
dojo.attr(_1,{type:"text",value:dojo.attr(this.srcNodeRef,"value")||"",placeholder:this.placeHolder||null}); |
20 |
this.domNode=this.textbox=this.focusNode=_1; |
21 |
},_setPlaceHolderAttr:function(v){ |
22 |
this.placeHolder=v;
|
23 |
if(this.textbox){ |
24 |
dojo.attr(this.textbox,"placeholder",v); |
25 |
} |
26 |
},_getValueAttr:function(){ |
27 |
return this.parse(this.get("displayedValue"),this.constraints); |
28 |
},_setValueAttr:function(_2,_3,_4){ |
29 |
var _5;
|
30 |
if(_2!==undefined){ |
31 |
_5=this.filter(_2);
|
32 |
if(typeof _4!="string"){ |
33 |
if(_5!==null&&((typeof _5!="number")||!isNaN(_5))){ |
34 |
_4=this.filter(this.format(_5,this.constraints)); |
35 |
}else{
|
36 |
_4="";
|
37 |
} |
38 |
} |
39 |
} |
40 |
if(_4!=null&&_4!=undefined&&((typeof _4)!="number"||!isNaN(_4))&&this.textbox.value!=_4){ |
41 |
this.textbox.value=_4;
|
42 |
} |
43 |
this.inherited(arguments,[_5,_3]); |
44 |
},displayedValue:"",_getDisplayedValueAttr:function(){ |
45 |
return this.filter(this.textbox.value); |
46 |
},_setDisplayedValueAttr:function(_6){ |
47 |
if(_6===null||_6===undefined){ |
48 |
_6="";
|
49 |
}else{
|
50 |
if(typeof _6!="string"){ |
51 |
_6=String(_6); |
52 |
} |
53 |
} |
54 |
this.textbox.value=_6;
|
55 |
this._setValueAttr(this.get("value"),undefined,_6); |
56 |
},format:function(_7,_8){ |
57 |
return ((_7==null||_7==undefined)?"":(_7.toString?_7.toString():_7)); |
58 |
},parse:function(_9,_a){ |
59 |
return _9;
|
60 |
},_refreshState:function(){ |
61 |
},_onInput:function(e){ |
62 |
if(e&&e.type&&/key/i.test(e.type)&&e.keyCode){ |
63 |
switch(e.keyCode){
|
64 |
case dojo.keys.SHIFT:
|
65 |
case dojo.keys.ALT:
|
66 |
case dojo.keys.CTRL:
|
67 |
case dojo.keys.TAB:
|
68 |
return;
|
69 |
} |
70 |
} |
71 |
if(this.intermediateChanges){ |
72 |
var _b=this; |
73 |
setTimeout(function(){
|
74 |
_b._handleOnChange(_b.get("value"),false); |
75 |
},0);
|
76 |
} |
77 |
this._refreshState();
|
78 |
},postCreate:function(){ |
79 |
this.textbox.setAttribute("value",this.textbox.value); |
80 |
this.inherited(arguments); |
81 |
if(dojo.isMoz||dojo.isOpera){
|
82 |
this.connect(this.textbox,"oninput",this._onInput); |
83 |
}else{
|
84 |
this.connect(this.textbox,"onkeydown",this._onInput); |
85 |
this.connect(this.textbox,"onkeyup",this._onInput); |
86 |
this.connect(this.textbox,"onpaste",this._onInput); |
87 |
this.connect(this.textbox,"oncut",this._onInput); |
88 |
} |
89 |
},_blankValue:"",filter:function(_c){ |
90 |
if(_c===null){ |
91 |
return this._blankValue; |
92 |
} |
93 |
if(typeof _c!="string"){ |
94 |
return _c;
|
95 |
} |
96 |
if(this.trim){ |
97 |
_c=dojo.trim(_c); |
98 |
} |
99 |
if(this.uppercase){ |
100 |
_c=_c.toUpperCase(); |
101 |
} |
102 |
if(this.lowercase){ |
103 |
_c=_c.toLowerCase(); |
104 |
} |
105 |
if(this.propercase){ |
106 |
_c=_c.replace(/[^\s]+/g,function(_d){ |
107 |
return _d.substring(0,1).toUpperCase()+_d.substring(1); |
108 |
}); |
109 |
} |
110 |
return _c;
|
111 |
},_setBlurValue:function(){ |
112 |
this._setValueAttr(this.get("value"),true); |
113 |
},_onBlur:function(e){ |
114 |
if(this.disabled){ |
115 |
return;
|
116 |
} |
117 |
this._setBlurValue();
|
118 |
this.inherited(arguments); |
119 |
if(this._selectOnClickHandle){ |
120 |
this.disconnect(this._selectOnClickHandle); |
121 |
} |
122 |
if(this.selectOnClick&&dojo.isMoz){ |
123 |
this.textbox.selectionStart=this.textbox.selectionEnd=undefined; |
124 |
} |
125 |
},_onFocus:function(by){ |
126 |
if(this.disabled||this.readOnly){ |
127 |
return;
|
128 |
} |
129 |
if(this.selectOnClick&&by=="mouse"){ |
130 |
this._selectOnClickHandle=this.connect(this.domNode,"onmouseup",function(){ |
131 |
this.disconnect(this._selectOnClickHandle); |
132 |
var _e;
|
133 |
_e=this.textbox.selectionStart==this.textbox.selectionEnd; |
134 |
if(_e){
|
135 |
this.selectInputText(this.textbox); |
136 |
} |
137 |
}); |
138 |
} |
139 |
this._refreshState();
|
140 |
this.inherited(arguments); |
141 |
},reset:function(){ |
142 |
this.textbox.value=""; |
143 |
this.inherited(arguments); |
144 |
}}); |
145 |
} |