Blame view

vendor/yiisoft/yii2-debug/views/default/panels/log/detail.php 2.51 KB
e4e4ce76   Administrator   update rep
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
  <?php
  /* @var $panel yii\debug\panels\LogPanel */
  /* @var $searchModel yii\debug\models\search\Log */
  /* @var $dataProvider yii\data\ArrayDataProvider */
  
  use yii\helpers\Html;
  use yii\grid\GridView;
  use yii\helpers\VarDumper;
  use yii\log\Logger;
  
  ?>
  <h1>Log Messages</h1>
  <?php
  
  echo GridView::widget([
      'dataProvider' => $dataProvider,
      'id' => 'log-panel-detailed-grid',
      'options' => ['class' => 'detail-grid-view table-responsive'],
      'filterModel' => $searchModel,
      'filterUrl' => $panel->getUrl(),
      'rowOptions' => function ($model, $key, $index, $grid) {
          switch ($model['level']) {
              case Logger::LEVEL_ERROR : return ['class' => 'danger'];
              case Logger::LEVEL_WARNING : return ['class' => 'warning'];
              case Logger::LEVEL_INFO : return ['class' => 'success'];
              default: return [];
          }
      },
      'columns' => [
          ['class' => 'yii\grid\SerialColumn'],
          [
              'attribute' => 'time',
              'value' => function ($data) {
                  $timeInSeconds = $data['time'] / 1000;
                  $millisecondsDiff = (int) (($timeInSeconds - (int) $timeInSeconds) * 1000);
  
                  return date('H:i:s.', $timeInSeconds) . sprintf('%03d', $millisecondsDiff);
              },
              'headerOptions' => [
                  'class' => 'sort-numerical'
              ]
          ],
          [
              'attribute' => 'level',
              'value' => function ($data) {
                  return Logger::getLevelName($data['level']);
              },
              'filter' => [
                  Logger::LEVEL_TRACE => ' Trace ',
                  Logger::LEVEL_INFO => ' Info ',
                  Logger::LEVEL_WARNING => ' Warning ',
                  Logger::LEVEL_ERROR => ' Error ',
              ],
          ],
          'category',
          [
              'attribute' => 'message',
              'value' => function ($data) {
                  $message = Html::encode(is_string($data['message']) ? $data['message'] : VarDumper::export($data['message']));
                  if (!empty($data['trace'])) {
                      $message .= Html::ul($data['trace'], [
                          'class' => 'trace',
                          'item' => function ($trace) {
                              return "<li>{$trace['file']} ({$trace['line']})</li>";
                          }
                      ]);
                  };
                  return $message;
              },
              'format' => 'html',
              'options' => [
                  'width' => '50%',
              ],
          ],
      ],
  ]);