[ 
https://issues.apache.org/jira/browse/CB-8383?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15315334#comment-15315334
 ] 

ASF GitHub Bot commented on CB-8383:
------------------------------------

Github user codecov-io commented on the issue:

    https://github.com/apache/cordova-android/pull/288
  
    ## [Current coverage][cc-pull] is **33.29%**
    > Merging [#288][cc-pull] into [master][cc-base-branch] will decrease 
coverage by **2.99%**
    
    ```diff
    @@           master    #288   diff @@
    =====================================
      Files          11      11          
      Lines         926     916    -10   
      Methods         0       0          
      Branches      167     167          
    =====================================
    - Hits          336     305    -31   
    - Misses        590     610    +20   
    - Partials        0       1     +1   
    ```
    
    > Powered by [Codecov](https://codecov.io?src=pr). Last updated by 
[9af7f50...98d1460][cc-compare]
    [cc-base-branch]: 
https://codecov.io/gh/apache/cordova-android/branch/master?src=pr
    [cc-compare]: 
https://codecov.io/gh/apache/cordova-android/compare/9af7f506f03b468734406341ae98599dbd2af676...98d1460f808073dc94ad2cd1fa989156a7d8f91d
    [cc-pull]: https://codecov.io/gh/apache/cordova-android/pull/288?src=pr


> pause event don't fire when 'KeepRunning' is false
> --------------------------------------------------
>
>                 Key: CB-8383
>                 URL: https://issues.apache.org/jira/browse/CB-8383
>             Project: Apache Cordova
>          Issue Type: Bug
>          Components: Android
>    Affects Versions: Master, 3.5.0, 4.0.0, 4.1.3
>         Environment: Mac osx 10.9
>            Reporter: hugefactory
>   Original Estimate: 1h
>  Remaining Estimate: 1h
>
> Under Android, when a project use 'KeepRunning=false' in the config.xml file, 
> the 'pause' event in javascript don't fire when application go to background. 
> Next, 'pause' event fire when 'resume' is call and when the application 
> resume.
> The problem is in 'CordovaWebView.java' in the 'handlePause' method :
> public void handlePause(boolean keepRunning) {
>         LOG.d(TAG, "Handle the pause");
>         // Send pause event to JavaScript
>         
> this.loadUrl("javascript:try{cordova.fireDocumentEvent('pause');}catch(e){console.log('exception
>  firing pause event from native');};");
>         // Forward to plugins
>         if (this.pluginManager != null) {
>             this.pluginManager.onPause(keepRunning);
>         }
>         // If app doesn't want to run in background
>         if (!keepRunning) {
>             // Pause JavaScript timers (including setInterval)
>             this.pauseTimers();
>         }
>         paused = true;
>    
>     }
> As you can see, 'pauseTimers()' is call immediatly when we choose 
> 'KeepRunning' false.
> According to the Android documentation, 'pauseTimer()' stop all javascript 
> activity....then the 'pause' javascript callback is not execute (it's execute 
> after, when the 'resumeTimers()' is call and the application resume.
> I suggest to delay the 'pauseTimers()' for 1 or 2 sec. Then the javascript 
> 'pause' can execute before the application is really stop :
> //OLD       
>      //this.pauseTimers();
> //NEW
>             final Handler handler = new Handler();
>             handler.postDelayed(new Runnable() {
>               @Override
>               public void run() {
>                 LOG.d(TAG, "Handle the pauseTimers");
>                 pauseTimers();
>               }
>             }, 1000);
>         }
> Thanks.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to