Skip to content

Commit

Permalink
NEW: Improved task runner UI. (#9540)
Browse files Browse the repository at this point in the history
Co-authored-by: Sacha Judd <[email protected]>
  • Loading branch information
mfendeksilverstripe and sachajudd authored Aug 25, 2020
1 parent c143941 commit 7c84171
Show file tree
Hide file tree
Showing 3 changed files with 155 additions and 23 deletions.
58 changes: 58 additions & 0 deletions client/styles/task-runner.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
/* This file is manually maintained, it is not generated from SCSS sources */

.task {
padding-top: 20px;
}

.task__panel {
padding: 0 15px 15px 15px;
}

@media (min-width:992px) {
.task__list {
columns: 2;
column-gap: 100px;
}
}

.task__item {
padding-bottom: 30px;
}

@media (min-width:992px) {
.task__item {
display: inline-block;
width: 100%;
}
}

.task__title {
color: #303b4d;
margin: 0 0 8px;
}

.task__description {
color: #43536d;
margin-bottom: 12px;
}

.task__button {
border: 1px solid #ced5e1;
border-radius: 5px;
background-color: #f6f7f8;
color: #43536d;
display: inline-block;
margin-right: 10px;
padding: 6px 10px;
text-decoration: none;
transition: background-color 0.2s;
}

.task__button:last-child {
margin-right: 0;
}

.task__button:focus,
.task__button:hover {
background-color: #ced5e1;
}
96 changes: 73 additions & 23 deletions src/Dev/TaskRunner.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,19 +2,26 @@

namespace SilverStripe\Dev;

use ReflectionClass;
use SilverStripe\Control\Controller;
use SilverStripe\Control\Director;
use SilverStripe\Control\HTTPRequest;
use SilverStripe\Core\ClassInfo;
use SilverStripe\Core\Config\Configurable;
use SilverStripe\Core\Convert;
use SilverStripe\Core\Injector\Injector;
use SilverStripe\Core\Manifest\ModuleResourceLoader;
use SilverStripe\ORM\ArrayList;
use SilverStripe\Security\Permission;
use SilverStripe\Security\Security;
use ReflectionClass;
use SilverStripe\View\ArrayData;
use SilverStripe\View\ViewableData;

class TaskRunner extends Controller
{

use Configurable;

private static $url_handlers = [
'' => 'index',
'$TaskName' => 'runTask'
Expand All @@ -25,6 +32,13 @@ class TaskRunner extends Controller
'runTask',
];

/**
* @var array
*/
private static $css = [
'silverstripe/framework:client/styles/task-runner.css',
];

protected function init()
{
parent::init();
Expand All @@ -44,33 +58,42 @@ protected function init()

public function index()
{
$baseUrl = Director::absoluteBaseURL();
$tasks = $this->getTasks();

// Web mode
if (!Director::is_cli()) {
$renderer = new DebugView();
echo $renderer->renderHeader();
echo $renderer->renderInfo("SilverStripe Development Tools: Tasks", Director::absoluteBaseURL());
$base = Director::absoluteBaseURL();
if (Director::is_cli()) {
// CLI mode
$output = 'SILVERSTRIPE DEVELOPMENT TOOLS: Tasks' . PHP_EOL . '--------------------------' . PHP_EOL . PHP_EOL;

echo "<div class=\"options\">";
echo "<ul>";
foreach ($tasks as $task) {
echo "<li><p>";
echo "<a href=\"{$base}dev/tasks/" . $task['segment'] . "\">" . $task['title'] . "</a><br />";
echo "<span class=\"description\">" . $task['description'] . "</span>";
echo "</p></li>\n";
$output .= sprintf(' * %s: sake dev/tasks/%s%s', $task['title'], $task['segment'], PHP_EOL);
}
echo "</ul></div>";

echo $renderer->renderFooter();
// CLI mode
} else {
echo "SILVERSTRIPE DEVELOPMENT TOOLS: Tasks\n--------------------------\n\n";
foreach ($tasks as $task) {
echo " * $task[title]: sake dev/tasks/" . $task['segment'] . "\n";
}
return $output;
}

$list = ArrayList::create();

foreach ($tasks as $task) {
$list->push(ArrayData::create([
'TaskLink' => $baseUrl . 'dev/tasks/' . $task['segment'],
'Title' => $task['title'],
'Description' => $task['description'],
]));
}

$renderer = DebugView::create();
$header = $renderer->renderHeader();
$header = $this->addCssToHeader($header);

$data = [
'Tasks' => $list,
'Header' => $header,
'Footer' => $renderer->renderFooter(),
'Info' => $renderer->renderInfo('SilverStripe Development Tools: Tasks', $baseUrl),
];

return ViewableData::create()->renderWith(static::class, $data);
}

/**
Expand Down Expand Up @@ -126,10 +149,12 @@ protected function getTasks()
}

$singleton = BuildTask::singleton($class);
$description = $singleton->getDescription();
$description = trim($description);

$desc = (Director::is_cli())
? Convert::html2raw($singleton->getDescription())
: $singleton->getDescription();
? Convert::html2raw($description)
: $description;

$availableTasks[] = [
'class' => $class,
Expand Down Expand Up @@ -157,4 +182,29 @@ protected function taskEnabled($class)

return true;
}

/**
* Inject task runner CSS into the heaader
* @param string $header
* @return string
*/
protected function addCssToHeader($header)
{
$css = (array) $this->config()->get('css');

if (!$css) {
return $header;
}

foreach ($css as $include) {
$path = ModuleResourceLoader::singleton()->resolveURL($include);

// inject CSS into the heaader
$element = sprintf('<link rel="stylesheet" type="text/css" href="%s" />', $path);
$header = str_replace('</head>', $element . '</head>', $header);
}

return $header;
}
}
24 changes: 24 additions & 0 deletions templates/SilverStripe/Dev/TaskRunner.ss
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
$Header.RAW
$Info.RAW

<div class="task">
<div class="task__panel">
<% if $Tasks.Count > 0 %>
<div class="task__list">
<% loop $Tasks %>
<div class="task__item">
<div>
<h3 class="task__title">$Title</h3>
<div class="task__description">$Description</div>
</div>
<div>
<a href="{$TaskLink.ATT}" class="task__button">Run task</a>
</div>
</div>
<% end_loop %>
</div>
<% end_if %>
</div>
</div>

$Footer.RAW

0 comments on commit 7c84171

Please sign in to comment.