OSDN Git Service

Version 0.6.172, bugfix...
[pettanr/clientJs.git] / 0.6.x / js / 06_net / 00_XNet.js
index fdc66aa..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
@@ -43,7 +42,7 @@
  * <dt>mimeType<dd>'text/xml', 'audio/mpeg' 等。xhr.overrideMimeType する値\r
  * <dt>auth<dd>X.OAuth2 インスタンス(OAuth2 サービスの定義)\r
  * <dt>getFullHeaders<dd>getAllResponseHeaders() をパースしたハッシュを返す。値は配列になっている。XDR は Content-Type しか取得でいない。\r
- * <dt>canUse<dd>未実装。gadget proxy, YQL, YPipes 等のマッシュアップの許可。現在は test : 'gadget' としている\r
+ * <dt>canUse<dd>未実装。gadget proxy, YQL, <del>YPipes</del> 等のマッシュアップの許可。現在は test : 'gadget' としている\r
  * </dl>\r
  * \r
  * <h4>JSONP 用プロパティ</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,31 +90,36 @@ 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
                                \r
                                if( X_Type_isObject( opt = urlOrObject ) ){\r
+                                       //{+xhr\r
                                        if( X_Type_isString( url = opt[ 'xhr' ] ) ){\r
                                                type = X_NET_TYPE_XHR;\r
                                        } else\r
+                                       //}+xhr\r
+                                       //{+jsonp\r
                                        if( X_Type_isString( url = opt[ 'jsonp' ] ) ){\r
                                                type = X_NET_TYPE_JSONP;\r
                                        } else\r
+                                       //}+jsonp\r
+                                       //{+netimage\r
                                        if( X_Type_isString( url = opt[ 'img' ] || opt[ 'image' ] ) ){\r
                                                type = X_NET_TYPE_IMAGE;\r
                                        } else\r
+                                       //}+netimage\r
+                                       //{+netform\r
                                        if( X_Type_isString( url = opt[ 'form' ] ) ){\r
                                                type = X_NET_TYPE_FORM;\r
-                                       //{+dev\r
                                        } else\r
+                                       //}+netform\r
                                        if( !( type = X_NET_NAME_TO_ID[ opt[ 'type' ] ] ) ){\r
+                                               //{+dev\r
                                                alert( 'X.Net args error' );\r
+                                               //}+dev\r
                                                return;\r
-                                       //}+dev\r
                                        } else {\r
                                                url = opt[ 'url' ];\r
                                        };\r
@@ -166,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
@@ -220,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
@@ -251,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
@@ -277,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
@@ -312,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
@@ -338,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