Zend_ProgressBar_Adapter_JsPush.xml 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. <!-- EN-Revision: 13910 -->
  2. <sect3 id="zend.progressbar.adapter.jspush">
  3. <title>Zend_ProgressBar_Adapter_JsPush</title>
  4. <para><classname>Zend_ProgressBar_Adapter_JsPush</classname> est un adaptateur qui vous permet de mettre à jour une barre de
  5. progression dans un navigateur au travers de Javascript. Ceci veut dire qu'une seconde connexion n'est pas
  6. nécessaire pour recueillir le statut du processus courant, mais que le processus lui-même envoie son statut
  7. directement au navigateur.</para>
  8. <para>Vous pouvez paramétrer les options de l'adaptateur soit avec les méthodes <code>set*</code> soit en
  9. fournissant un tableau ("array") ou une instance de <classname>Zend_Config</classname> contenant les options en tant que
  10. premier paramètre du constructeur. Les options disponibles sont :</para>
  11. <itemizedlist>
  12. <listitem>
  13. <para><code>updateMethodName</code> : la méthode Javascript qui sera appelée à chaque mise à jour. La valeur
  14. par défaut est <classname>Zend_ProgressBar_Update</classname>.</para>
  15. </listitem>
  16. <listitem>
  17. <para><code>finishMethodName</code> : la méthode Javascript qui sera appelée lorsque le statut terminé sera
  18. atteint. La valeur par défaut est <code>NULL</code>, qui veut dire que rien n'est fait.</para>
  19. </listitem>
  20. </itemizedlist>
  21. <para>L'utilisation de cet adaptateur est assez simple. Premièrement vous créez une barre de progression pour le
  22. navigateur, soit avec Javascript ou auparavant en pur HTML. Ensuite vous définissez une méthode de mise à jour et
  23. optionnellement une méthode de finalisation en Javascript, les deux acceptant un objet JSON en tant qu'unique
  24. argument. Ensuite vous appelez une page Web avec un processus chronophage dans une balise <code>iframe</code> ou
  25. <code>object</code> masqué. Pendant que le processus tourne, l'adaptateur appelle la méthode de mise à jour à chaque
  26. mise à jour avec un objet JSON, contenant le paramètres suivants :</para>
  27. <itemizedlist>
  28. <listitem>
  29. <para><code>current</code> : la valeur courante</para>
  30. </listitem>
  31. <listitem>
  32. <para><code>max</code> : la valeur maximum</para>
  33. </listitem>
  34. <listitem>
  35. <para><code>percent</code> : le pourcentage calculé</para>
  36. </listitem>
  37. <listitem>
  38. <para><code>timeTaken</code> : le temps depuis quand le processus courant est en marche</para>
  39. </listitem>
  40. <listitem>
  41. <para><code>timeRemaining</code> : le temps estimé pour que le processus se termine</para>
  42. </listitem>
  43. <listitem>
  44. <para><code>text</code> : le message de statut optionnel, si fourni</para>
  45. </listitem>
  46. </itemizedlist>
  47. <example id="zend.progressbar-adapter.jspush.example">
  48. <title>Exemple basique du fonctionnement côté-client</title>
  49. <para>Cet exemple illustre un paramétrage basique du HTML, CSS et JavaScript pour l'adaptateur JsPush :</para>
  50. <programlisting role="html"><![CDATA[
  51. <div id="zend-progressbar-container">
  52. <div id="zend-progressbar-done"></div>
  53. </div>
  54. <iframe src="long-running-process.php" id="long-running-process"></iframe>
  55. ]]></programlisting>
  56. <programlisting role="css"><![CDATA[
  57. #long-running-process {
  58. position: absolute;
  59. left: -100px;
  60. top: -100px;
  61. width: 1px;
  62. height: 1px;
  63. }
  64. #zend-progressbar-container {
  65. width: 100px;
  66. height: 30px;
  67. border: 1px solid #000000;
  68. background-color: #ffffff;
  69. }
  70. #zend-progressbar-done {
  71. width: 0;
  72. height: 30px;
  73. background-color: #000000;
  74. }
  75. ]]></programlisting>
  76. <programlisting role="javascript"><![CDATA[
  77. function Zend_ProgressBar_Update(data)
  78. {
  79. document.getElementById('zend-progressbar-done').style.width = data.percent + '%';
  80. }
  81. ]]></programlisting>
  82. <para>Ceci créera un simple conteneur avec une bordure noire et un bloc qui indique le niveau du processus
  83. courant. Vous ne devez pas masquer l'<code>iframe</code> ou l'<code>object</code> par <code>display:
  84. none;</code>, car dans ce cas les navigateurs comme Safari 2 ne chargeront pas le contenu réel.</para>
  85. <para>Plutôt que de créer votre barre de progression personnalisée, vous pouvez utiliser une de celles
  86. disponibles dans les librairies JavaScript comme Dojo, jQuery etc. Par exemple, il existe :</para>
  87. <itemizedlist>
  88. <listitem>
  89. <para>Dojo : <ulink
  90. url="http://dojotoolkit.org/book/dojo-book-0-9/part-2-dijit/user-assistance-and-feedback/progress-bar"></ulink></para>
  91. </listitem>
  92. <listitem>
  93. <para>jQuery : <ulink url="http://t.wits.sg/2008/06/20/jquery-progress-bar-11/"></ulink></para>
  94. </listitem>
  95. <listitem>
  96. <para>MooTools : <ulink url="http://davidwalsh.name/dw-content/progress-bar.php"></ulink></para>
  97. </listitem>
  98. <listitem>
  99. <para>Prototype : <ulink url="http://livepipe.net/control/progressbar"></ulink></para>
  100. </listitem>
  101. </itemizedlist>
  102. </example>
  103. <note>
  104. <title>Intervalle de mise à jour</title>
  105. <para>Vous devez faire attention à ne pas envoyer trop de mises à jour, puisque chaque mise à jour a une taille
  106. minimum de 1ko. Ceci est requis par le navigateur Safari pour rendre et exécuter l'appel de fonction. Internet
  107. Explorer possède une limitation similaire mais à 256 octets.</para>
  108. </note>
  109. </sect3>