1 // TODO onlineevent offlineevent, netspeed
\r
2 // local への通信に対しては、netspeed を更新しない
\r
5 xhrGet : function( url ){
\r
6 return new X_NET_Queue( X_NET_TYPE_XHR, { method : 'GET', url : url } );
\r
9 xhrPost : function( url, data ){
\r
10 return new X_NET_Queue( X_NET_TYPE_XHR, { method : 'POST', url : url, postbody : postbody } );
\r
13 formGet : function(){
\r
17 formPost : function(){
\r
22 // TODO iframe useful or not.
\r
23 // TODO file: では http: は使えない
\r
24 jsonp : function( url, useIframe ){
\r
25 return new X_NET_Queue( X_NET_TYPE_JSONP, url );
\r
28 image : function( url, needSize, useIframe ){
\r
29 return new X_NET_Queue( X_NET_TYPE_IMAGE, url );
\r
34 amountQueue : function(){
\r
35 return X_NET_QUEUE_LIST.length;
\r
41 var X_NET_IWrapper = function(){};
\r
42 X_NET_IWrapper.prototype.load = function(){};
\r
43 X_NET_IWrapper.prototype.cancel = function(){};
\r
44 X_NET_IWrapper.prototype.reset = function(){};
\r
47 var X_NET_TYPE_XHR = 1,
\r
48 X_NET_TYPE_JSONP = 2,
\r
49 X_NET_TYPE_FORM = 3,
\r
50 X_NET_TYPE_IMAGE = 4,
\r
52 X_NET_QUEUE_LIST = [],
\r
59 X_NET_currentWrapper,
\r
62 X_NET_Queue = X.EventDispatcher.inherits(
\r
64 X.Class.POOL_OBJECT,
\r
69 Constructor : function( type, data ){
\r
73 this.listen( X.Event.COMPLETE, X_NET_proxyDispatch );
\r
75 X_NET_QUEUE_LIST[ X_NET_QUEUE_LIST.length ] = this;
\r
76 !X_NET_currentQueue && X_NET_shiftQueue();
\r
80 return this === X_NET_currentQueue && X_NET_currentWrapper._busy;
\r
83 cancel : function(){
\r
84 var i = X_NET_QUEUE_LIST.indexOf( this );
\r
86 X_NET_QUEUE_LIST.splice( i, 1 );
\r
87 this.asyncDispatch( { type : X.Event.CANCELED } );
\r
89 if( this === X_NET_currentQueue ){
\r
90 X_NET_currentWrapper.cancel();
\r
96 function X_NET_proxyDispatch( e ){
\r
98 case X.Event.BEFORE_KILL_INSTANCE :
\r
100 case X.Event.KILL_INSTANCE :
\r
102 case X.Event.KILL_INSTANCE_CANCELED :
\r
104 case X.Event.PROGRESS :
\r
105 console.log( 'q: ' + e.type );
\r
106 this.dispatch( e );
\r
108 case X.Event.SUCCESS :
\r
109 case X.Event.ERROR :
\r
110 case X.Event.TIMEOUT :
\r
111 case X.Event.CANCELED :
\r
112 console.log( 'q: ' + e.type );
\r
113 this.dispatch( e );
\r
114 this.asyncDispatch( { type : X.Event.COMPLETE } );
\r
116 case X.Event.COMPLETE :
\r
117 console.log( 'complete. then kill()' );
\r
119 X_NET_shiftQueue();
\r
124 function X_NET_shiftQueue(){
\r
127 if( X_NET_currentQueue ){
\r
128 if( X_NET_currentWrapper._busy ) return;
\r
129 X_NET_currentWrapper
\r
130 .unlisten( [ X.Event.PROGRESS, X.Event.SUCCESS, X.Event.ERROR, X.Event.TIMEOUT ], X_NET_currentQueue, X_NET_proxyDispatch )
\r
132 X_NET_currentQueue = X_NET_currentWrapper = null;
\r
135 if( !X_NET_QUEUE_LIST.length ) return;
\r
137 queue = X_NET_QUEUE_LIST.shift();
\r
139 switch( queue.type ){
\r
140 case X_NET_TYPE_XHR :
\r
141 X_NET_currentWrapper = X_NET_XHRWrapper;
\r
143 case X_NET_TYPE_JSONP :
\r
144 X_NET_currentWrapper = X_NET_JSONPWrapper;
\r
146 case X_NET_TYPE_FORM :
\r
147 X_NET_currentWrapper = X_NET_FormWrapper;
\r
149 case X_NET_TYPE_IMAGE :
\r
150 X_NET_currentWrapper = X_NET_ImageWrapper;
\r
154 X_NET_currentWrapper.listen( [X.Event.PROGRESS, X.Event.SUCCESS, X.Event.ERROR, X.Event.TIMEOUT ], X_NET_currentQueue = queue, X_NET_proxyDispatch );
\r
156 X_NET_currentWrapper.load( queue.data );
\r