55namespace Skautis \Nette \Tracy ;
66
77use Nette ;
8- use Skautis \SkautisQuery ;
9- use Skautis \Wsdl \WebService ;
10- use Skautis \Wsdl \WsdlManager ;
8+ use Skaut \Skautis \Wsdl \WsdlManager ;
119use Tracy ;
1210use Tracy \Debugger ;
1311
1917 */
2018class Panel implements Tracy \IBarPanel
2119{
22-
2320 use Nette \SmartObject;
2421
25- /** @var SkautisQuery[] */
26- private $ queries = [] ;
22+ /** @var EventDispatcher */
23+ private $ eventDispatcher ;
2724
25+ public function __construct ()
26+ {
27+ $ this ->eventDispatcher = new EventDispatcher ();
28+ }
2829
29- /**
30+ /**
3031 * Registers event listener on WebService objects via WsdlManager
3132 */
3233 public function register (WsdlManager $ wsdlManager ): void
3334 {
34- $ wsdlManager ->addWebServiceListener (WebService::EVENT_SUCCESS , [$ this , 'logEvent ' ]);
35- $ wsdlManager ->addWebServiceListener (WebService::EVENT_FAILURE , [$ this , 'logEvent ' ]);
35+ $ wsdlManager ->setEventDispatcher ($ this ->eventDispatcher );
3636 Debugger::getBar ()->addPanel ($ this );
3737 }
3838
39-
40- public function logEvent (SkautisQuery $ query ): void
41- {
42- $ this ->queries [] = $ query ;
43- }
44-
45-
4639 /**
4740 * @inheritdoc
4841 */
4942 public function getTab (): string
5043 {
5144 $ totalTime = 0 ;
52- foreach ($ this ->queries as $ query ) {
45+ foreach ($ this ->eventDispatcher -> getQueries () as $ query ) {
5346 $ totalTime += $ query ->time ;
5447 }
5548 return '<span title="skautis"><img src=""> '
56- . count ($ this ->queries ) . ' queries '
49+ . count ($ this ->eventDispatcher -> getQueries () ) . ' queries '
5750 . ($ totalTime ? sprintf (' / %0.1f ms ' , $ totalTime * 1000 ) : '' )
5851 . '</span> ' ;
5952 }
@@ -66,7 +59,7 @@ public function getPanel(): string
6659 {
6760 $ cnt = 0 ;
6861 $ s = "" ;
69- foreach ($ this ->queries as $ query ) {
62+ foreach ($ this ->eventDispatcher -> getQueries () as $ query ) {
7063 $ rowId = "tracy-debug-Skautis-args-row- $ cnt " ;
7164 $ s .= "<tr> "
7265 . "<td> " . sprintf ('%0.2f ' , $ query ->time * 1000 ) . "</td> "
@@ -77,7 +70,7 @@ public function getPanel(): string
7770 $ cnt ++;
7871 }
7972
80- return empty ($ this ->queries ) ? '' :
73+ return empty ($ this ->eventDispatcher -> getQueries () ) ? '' :
8174 '<h1>Skautis</h1> '
8275 . '<div class="tracy-inner"> '
8376 . '<table> '
0 commit comments