You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
69 lines
1.7 KiB
69 lines
1.7 KiB
<?php |
|
use yii\helpers\Html; |
|
use yii\grid\GridView; |
|
use yii\data\ArrayDataProvider; |
|
use yii\log\Logger; |
|
?> |
|
<h1>Log Messages</h1> |
|
<?php |
|
|
|
echo GridView::widget([ |
|
'dataProvider' => $dataProvider, |
|
'id' => 'log-panel-detailed-grid', |
|
'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); |
|
}, |
|
], |
|
[ |
|
'attribute' => 'level', |
|
'value' => function ($data) { |
|
return Logger::getLevelName($data['level']); |
|
}, |
|
'filter' => [ |
|
Logger::LEVEL_TRACE => ' Trace ', |
|
Logger::LEVEL_PROFILE => ' Profile ', |
|
Logger::LEVEL_INFO => ' Info ', |
|
Logger::LEVEL_ERROR => ' Error ', |
|
], |
|
], |
|
'category', |
|
[ |
|
'attribute' => 'message', |
|
'value' => function ($data) { |
|
$message = nl2br(Html::encode($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%', |
|
], |
|
], |
|
], |
|
]); |
|
?>
|