Файл: vendor/laravel/framework/src/Illuminate/Console/View/Components/Task.php
Строк: 65
<?php
namespace IlluminateConsoleViewComponents;
use SymfonyComponentConsoleOutputOutputInterface;
use function Termwindterminal;
use Throwable;
class Task extends Component
{
/**
* Renders the component using the given arguments.
*
* @param string $description
* @param (callable(): bool)|null $task
* @param int $verbosity
* @return void
*/
public function render($description, $task = null, $verbosity = OutputInterface::VERBOSITY_NORMAL)
{
$description = $this->mutate($description, [
MutatorsEnsureDynamicContentIsHighlighted::class,
MutatorsEnsureNoPunctuation::class,
MutatorsEnsureRelativePaths::class,
]);
$descriptionWidth = mb_strlen(preg_replace("/<[w=#/;,:.&,%?]+>|\e[d+m/", '$1', $description) ?? '');
$this->output->write(" $description ", false, $verbosity);
$startTime = microtime(true);
$result = false;
try {
$result = ($task ?: fn () => true)();
} catch (Throwable $e) {
throw $e;
} finally {
$runTime = $task
? (' '.number_format((microtime(true) - $startTime) * 1000).'ms')
: '';
$runTimeWidth = mb_strlen($runTime);
$width = min(terminal()->width(), 150);
$dots = max($width - $descriptionWidth - $runTimeWidth - 10, 0);
$this->output->write(str_repeat('<fg=gray>.</>', $dots), false, $verbosity);
$this->output->write("<fg=gray>$runTime</>", false, $verbosity);
$this->output->writeln(
$result !== false ? ' <fg=green;options=bold>DONE</>' : ' <fg=red;options=bold>FAIL</>',
$verbosity,
);
}
}
}