OSDN Git Service

Version 0.6.172, bugfix...
[pettanr/clientJs.git] / 0.6.x / js / 06_net / 00_XNet.js
index 6dbca99..af64b4d 100644 (file)
@@ -7,17 +7,16 @@
 \r
 \r
 /**\r
- * <p>busy() メソッドだけを持つ。通信用のプロパティは X.Pair によって隠蔽される\r
+ * <p>state() メソッドだけを持つ。通信用のプロパティは X.Pair によって隠蔽されています\r
  * <h4>通信のキャンセル</h4>\r
- * <p>kill() で通信待ち中はキャンセル&破棄、通信中の場合は通信の中断&破棄を行う。SUCCESS, ERROR, TIMEOUT イベント以降は kill() は無視される。\r
+ * <p>kill() で通信待ち中はキャンセル&破棄、通信中の場合は通信の中断&破棄を行う。\r
  * <h4>イベント</h4>\r
  * <dl>\r
  * <dt>X.Event.PROGRESS<dd>通信進行状況\r
  * <dt>X.Event.SUCCESS<dd>通信成功\r
- * <dt>X.Event.ERROR<dd>通信エラー\r
- * <dt>X.Event.TIMEOUT<dd>通信タイムアウト\r
- * <dt>X.Event.CANCELED<dd>通信のユーザー、プログラムによるキャンセル\r
- * <dt>X.Event.COMPLETE<dd>通信完了。SUCCESS, ERROR, TIMEOUT, CANCELED 後に発生。\r
+ * <dt>X.Event.ERROR<dd>通信エラー タイムアウトの場合、e.timeout == true で分かる。\r
+ * <dt>X.Event.CANCELED<dd>通信のユーザー、プログラムによるキャンセル。SUCCESS, ERROR, COMPLETE 後に kill()してもCANCELEDは呼ばれません。\r
+ * <dt>X.Event.COMPLETE<dd>通信完了。SUCCESS, ERROR, CANCELED 後に発生。\r
  * </dl>\r
  * <p>X.Net インスタンスは COMPLETE 後に自動で破棄される。\r
  * <h4>必須プロパティ</h4>\r
  * <dt>useFireWall<dd>異なるドメインに jsonp を読み込んだ後、xdomain iframe 通信を使ってデータを受け取る。不正なコードの実行を防ぐことが出来る、未実装\r
  * </dl>\r
  * \r
+ * <h4>Form 用プロパティ</h4>\r
+ * <dl>\r
+ * <dt>params<dd>url パラメータを object で渡すことが出来る。\r
+ * <dt>method<dd>'GET' or 'POST'\r
+ * <dt>target<dd>'_self', '_parent', '_top' の場合、ページから離脱する。target を指定せず同一ドメインの場合 response に body.innerHTML が返る。\r
+ * </dl>\r
+ * \r
  * @alias X.Net\r
  * @class 各種ネットワーク機能をラップしインターフェイスを共通化する。\r
  * @constructs Net\r
@@ -73,7 +79,7 @@
  * var net = X.Net( { jsonp : urlString, params : params, callbackName : callbackName, charset : charset, useFireWall : false } );\r
  * \r
  * // Form\r
- * var net = X.Net( { form : urlString, method : 'POST', target : '_self', params : {} } ); // _self, _parent, _top の場合、ページから離脱する\r
+ * var net = X.Net( { form : urlString, method : 'POST', target : '_self', params : {} } );\r
  * \r
  * // Image preload & getSize\r
  * var net = X.Net( { image : src, sizeDetection : true } );\r
@@ -84,9 +90,6 @@ X[ 'Net' ] = X_EventDispatcher[ 'inherits' ](
                'X.Net',\r
                X_Class.NONE,\r
                {\r
-                       'netType'    : '',\r
-                       'netName'    : '',\r
-                       'netVersion' : 0,\r
                        \r
                        'Constructor' : function( urlOrObject, opt_options ){\r
                                var opt, url, type, auth;\r
@@ -174,18 +177,20 @@ X[ 'Net' ] = X_EventDispatcher[ 'inherits' ](
                                \r
                                X_Pair_create( this, opt );\r
                                \r
-                               this[ 'listen' ]( [ X_EVENT_BEFORE_KILL_INSTANCE, X_EVENT_KILL_INSTANCE ], X_NET_proxyDispatch );\r
+                               this[ 'listen' ]( X_EVENT_KILL_INSTANCE, X_NET_proxyDispatch );\r
                                \r
                                X_NET_QUEUE_LIST[ X_NET_QUEUE_LIST.length ] = this;\r
                                !X_NET_currentQueue && X_NET_shiftQueue();\r
                        },\r
-                       \r
+\r
                /**\r
-                * 現在通信中か?調べる。false の場合、通信の順番待ちか、通信が終了している。\r
-                * @alias Net.prototype.busy\r
+                * 現在の状態。1:順番待ち, 2:通信中, 3:通信完了フェーズ\r
+                * @alias Net.prototype.state\r
                 */\r
-                       'busy' : function(){\r
-                               return this === X_NET_currentQueue && X_NET_currentWrapper._busy;\r
+                       'state' : function(){\r
+                               return this === X_NET_currentQueue ?\r
+                                       ( X_NET_completePhase ? 3 : 2 ) :\r
+                                       0 <= X_NET_QUEUE_LIST.indexOf( this ) ? 1 : 0;\r
                        }\r
                }\r
        );\r
@@ -228,21 +233,24 @@ function X_NET_proxyDispatch( e ){
        var i, flag, auth;\r
        \r
        switch( e.type ){\r
-               case X_EVENT_BEFORE_KILL_INSTANCE :\r
-                       if( this === X_NET_currentQueue && X_NET_completePhase ) return X_Callback_PREVENT_DEFAULT;\r
-                       break;\r
-               \r
                case X_EVENT_KILL_INSTANCE :\r
-                       i = X_NET_QUEUE_LIST.indexOf( this );\r
-                       \r
-                       if( i !== -1 ){\r
-                               X_NET_QUEUE_LIST.splice( i, 1 );\r
-                               flag = true;\r
+                       if( this === X_NET_currentQueue && X_NET_completePhase ){\r
+                               if( X_NET_completePhase === 1 ){\r
+                                       this[ 'unlisten' ]( X_EVENT_COMPLETE, X_NET_proxyDispatch )\r
+                                               [ 'dispatch' ]( X_EVENT_COMPLETE );\r
+                               };\r
+                               X_NET_shiftQueue();\r
+                               X_Pair_release( this );\r
+                               X_NET_completePhase = 0;\r
                        } else\r
                        if( this === X_NET_currentQueue ){\r
                                X_NET_currentWrapper.cancel();\r
                                X_NET_shiftQueue();\r
                                flag = true;\r
+                       } else\r
+                       if( ( i = X_NET_QUEUE_LIST.indexOf( this ) ) !== -1 ){\r
+                               X_NET_QUEUE_LIST.splice( i, 1 );\r
+                               flag = true;\r
                        };\r
                        \r
                        if( flag ){ // flag が立つ場合、これは中断\r
@@ -259,22 +267,20 @@ function X_NET_proxyDispatch( e ){
                        if( e.status === 401 ){\r
                                if( auth = X_Pair_get( this )[ 'auth' ] ){\r
                                        X_Pair_get( auth ).onAuthError( auth, e );\r
+                                       // TODO 破棄しないで待機。\r
                                };\r
                        };\r
                        \r
                case X_EVENT_SUCCESS :\r
-               case X_EVENT_TIMEOUT :\r
-                       X_NET_completePhase = true;\r
-                       this\r
-                               [ 'listenOnce' ]( X_EVENT_COMPLETE, X_NET_proxyDispatch )\r
-                               [ 'unlisten' ]( [ X_EVENT_BEFORE_KILL_INSTANCE, X_EVENT_KILL_INSTANCE ], X_NET_proxyDispatch )\r
-                               [ 'asyncDispatch' ]( e );\r
-                       this[ 'asyncDispatch' ]( 32, { type : X_EVENT_COMPLETE, 'lastEventType' : e.type } );\r
+                       X_NET_completePhase = 1;\r
+                       this[ 'listenOnce' ]( X_EVENT_COMPLETE, X_NET_proxyDispatch )\r
+                               [ 'asyncDispatch' ]( 32, { type : X_EVENT_COMPLETE, 'lastEventType' : e.type } );\r
+\r
+                       this[ 'asyncDispatch' ]( e );\r
                        break;\r
+\r
                case X_EVENT_COMPLETE :\r
-                       X_Pair_release( this );\r
-                       X_NET_shiftQueue();\r
-                       X_NET_completePhase = false;\r
+                       X_NET_completePhase = 2;\r
                        this[ 'kill' ]();\r
                        break;\r
        };\r
@@ -285,14 +291,19 @@ function X_NET_shiftQueue(){
 \r
        if( X_NET_currentQueue ){\r
                if( X_NET_currentWrapper._busy ) return;\r
+               \r
                X_NET_currentWrapper\r
-                       [ 'unlisten' ]( [ X_EVENT_PROGRESS, X_EVENT_SUCCESS, X_EVENT_ERROR, X_EVENT_TIMEOUT ], X_NET_currentQueue, X_NET_proxyDispatch )\r
+                       [ 'unlisten' ]( [ X_EVENT_PROGRESS, X_EVENT_SUCCESS, X_EVENT_ERROR ], X_NET_currentQueue, X_NET_proxyDispatch )\r
                        .reset();\r
+\r
                X_NET_currentQueue = X_NET_currentWrapper = X_NET_currentData = null;\r
        };\r
        \r
+       console.log( '■■------------ X_NET_shiftQueue ' + X_NET_QUEUE_LIST.length );\r
+       \r
        if( !X_NET_QUEUE_LIST.length ) return;\r
 \r
+\r
        X_NET_currentQueue = X_NET_QUEUE_LIST.shift();\r
        X_NET_currentData  = X_Pair_get( X_NET_currentQueue );\r
        \r
@@ -320,8 +331,9 @@ function X_NET_shiftQueue(){
                                        case 0 :\r
                                        case 1 :\r
                                        case 2 :\r
-                                               if( !( auth[ 'dispatch' ]( X_EVENT_NEED_AUTH ) & X_Callback_PREVENT_DEFAULT ) ){\r
-                                                       authSettings.lazyReq = X_NET_currentQueue;\r
+                                               if( !( auth[ 'dispatch' ]( X_EVENT_NEED_AUTH ) & X_CALLBACK_PREVENT_DEFAULT ) ){\r
+                                                       authSettings.lazyRequests = authSettings.lazyRequests || [];\r
+                                                       authSettings.lazyRequests.indexOf( X_NET_currentQueue ) === -1 && authSettings.lazyRequests.push( X_NET_currentQueue );\r
                                                };\r
                                                X_NET_currentQueue = null;\r
                                                X_NET_shiftQueue();\r
@@ -346,7 +358,7 @@ function X_NET_shiftQueue(){
                        break;\r
        };\r
        \r
-       X_NET_currentWrapper[ 'listen' ]( [ X_EVENT_PROGRESS, X_EVENT_SUCCESS, X_EVENT_ERROR, X_EVENT_TIMEOUT ], X_NET_currentQueue, X_NET_proxyDispatch );\r
+       X_NET_currentWrapper[ 'listen' ]( [ X_EVENT_PROGRESS, X_EVENT_SUCCESS, X_EVENT_ERROR ], X_NET_currentQueue, X_NET_proxyDispatch );\r
        \r
        X_NET_currentWrapper.load( X_NET_currentData );\r
 };\r