class MaestroProcessStatusBlock in Maestro 8.2
Same name and namespace in other branches
- 3.x src/Plugin/Block/MaestroProcessStatusBlock.php \Drupal\maestro\Plugin\Block\MaestroProcessStatusBlock
Provides a Maestro block that shows the linear status output for processes this user belongs to or in general.
Plugin annotation
@Block(
id = "maestro_process_status_block",
admin_label = @Translation("Maestro Process Status Block"),
category = @Translation("Maestro"),
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Component\Plugin\ContextAwarePluginBase implements ContextAwarePluginInterface
- class \Drupal\Core\Plugin\ContextAwarePluginBase implements CacheableDependencyInterface, ContextAwarePluginInterface uses DependencySerializationTrait, StringTranslationTrait, TypedDataTrait
- class \Drupal\Core\Block\BlockBase implements BlockPluginInterface, PluginWithFormsInterface, PreviewFallbackInterface uses BlockPluginTrait, ContextAwarePluginAssignmentTrait
- class \Drupal\maestro\Plugin\Block\MaestroProcessStatusBlock
- class \Drupal\Core\Block\BlockBase implements BlockPluginInterface, PluginWithFormsInterface, PreviewFallbackInterface uses BlockPluginTrait, ContextAwarePluginAssignmentTrait
- class \Drupal\Core\Plugin\ContextAwarePluginBase implements CacheableDependencyInterface, ContextAwarePluginInterface uses DependencySerializationTrait, StringTranslationTrait, TypedDataTrait
- class \Drupal\Component\Plugin\ContextAwarePluginBase implements ContextAwarePluginInterface
Expanded class hierarchy of MaestroProcessStatusBlock
File
- src/
Plugin/ Block/ MaestroProcessStatusBlock.php, line 19
Namespace
Drupal\maestro\Plugin\BlockView source
class MaestroProcessStatusBlock extends BlockBase {
/**
* {@inheritdoc}
*/
public function blockForm($form, FormStateInterface $form_state) {
$config = $this
->getConfiguration();
$form['maestro_skip_execute_check'] = [
'#type' => 'checkbox',
'#title' => $this
->t('Skip checking if the user is part of the process status bars shown.'),
'#description' => $this
->t('When checked, any open process can show its status. Unchecked means only those processes the user is a part of will be shown.'),
'#default_value' => isset($this->configuration['maestro_skip_execute_check']) ? $this->configuration['maestro_skip_execute_check'] : 0,
'#required' => FALSE,
];
$form['maestro_filter_process_names'] = [
'#type' => 'textfield',
'#title' => $this
->t('Simple filter to filter on process name.'),
'#description' => $this
->t('Specify the filter you wish to limit on. Filter uses %{your-filter}% database filtering. Available current user tokens are [uid] and [username].'),
'#default_value' => isset($this->configuration['maestro_filter_process_names']) ? $this->configuration['maestro_filter_process_names'] : '',
'#required' => FALSE,
];
$form['maestro_provide_link'] = [
'#type' => 'textfield',
'#title' => $this
->t('Make the Process Name a link to the following URL.'),
'#description' => $this
->t('No link when left blank. Available current user tokens are [uid] and [username].'),
'#default_value' => isset($this->configuration['maestro_provide_link']) ? $this->configuration['maestro_provide_link'] : '',
'#required' => FALSE,
];
$form['maestro_link_tooltip'] = [
'#type' => 'textfield',
'#title' => $this
->t('The hover-over tooltip for the link.'),
'#description' => $this
->t('If you enter a link above, the tooltip entered here will be shown. Defaults to nothing.'),
'#default_value' => isset($this->configuration['maestro_link_tooltip']) ? $this->configuration['maestro_link_tooltip'] : '',
'#required' => FALSE,
];
return $form;
}
/**
* {@inheritdoc}
*/
public function blockSubmit($form, FormStateInterface $form_state) {
$this->configuration['maestro_skip_execute_check'] = $form_state
->getValue('maestro_skip_execute_check');
$this->configuration['maestro_filter_process_names'] = $form_state
->getValue('maestro_filter_process_names');
$this->configuration['maestro_provide_link'] = $form_state
->getValue('maestro_provide_link');
$this->configuration['maestro_link_tooltip'] = $form_state
->getValue('maestro_link_tooltip');
}
/**
* {@inheritdoc}
*/
public function build() {
$conf = $this
->getConfiguration();
$processID = intval(\Drupal::request()->query
->get('process_id', 0));
$usr = \Drupal::currentUser();
if ($usr
->id()) {
if ($conf['maestro_skip_execute_check'] == 0) {
$query = \Drupal::database()
->select('maestro_production_assignments', 'a');
$query
->join('maestro_queue', 'b', 'a.queue_id = b.id');
$query
->join('maestro_process', 'c', 'b.process_id = c.process_id');
$query
->leftJoin('maestro_process_variables', 'd', 'c.process_id = d.process_id');
$andConditionGroup1 = $query
->andConditionGroup();
$andConditionGroup1
->condition('a.assign_id', $usr
->getAccountName());
$andConditionGroup1
->condition('b.status', '0');
if (isset($conf['maestro_filter_process_names']) && $conf['maestro_filter_process_names'] != '') {
$filter = str_replace('[uid]', $usr
->id(), $conf['maestro_filter_process_names']);
$filter = str_replace('[username]', $usr
->getAccountName(), $filter);
$andConditionGroup1
->condition('c.process_name', '%' . $query
->escapeLike($filter) . '%', 'LIKE');
}
if ($processID > 0) {
$andConditionGroup1
->condition('c.process_id', intval($processID));
}
$andConditionGroup2 = $query
->andConditionGroup();
$andConditionGroup2
->condition('d.variable_name', 'initiator');
$andConditionGroup2
->condition('d.variable_value', $usr
->getAccountName());
$orConditionGroup = $query
->orConditionGroup();
$orConditionGroup
->condition($andConditionGroup1);
$orConditionGroup
->condition($andConditionGroup2);
$query
->condition($orConditionGroup);
$query
->addField('b', 'process_id');
$query
->addField('c', 'process_name');
$query
->groupBy('b.process_id');
$query
->groupBy('c.process_name');
}
else {
$query = \Drupal::database()
->select('maestro_queue', 'b');
$query
->join('maestro_process', 'c', 'b.process_id = c.process_id');
$query
->leftJoin('maestro_process_variables', 'd', 'c.process_id = d.process_id');
$andConditionGroup1 = $query
->andConditionGroup();
$andConditionGroup1
->condition('b.status', '0');
if (isset($conf['maestro_filter_process_names']) && $conf['maestro_filter_process_names'] != '') {
$filter = str_replace('[uid]', $usr
->id(), $conf['maestro_filter_process_names']);
$filter = str_replace('[username]', $usr
->getAccountName(), $filter);
$andConditionGroup1
->condition('c.process_name', '%' . $query
->escapeLike($filter) . '%', 'LIKE');
}
if ($processID > 0) {
$andConditionGroup1
->condition('c.process_id', intval($processID));
}
$andConditionGroup2 = $query
->andConditionGroup();
$andConditionGroup2
->condition('d.variable_name', 'initiator');
$andConditionGroup2
->condition('d.variable_value', $usr
->getAccountName());
$orConditionGroup = $query
->orConditionGroup();
$orConditionGroup
->condition($andConditionGroup1);
$orConditionGroup
->condition($andConditionGroup2);
$query
->condition($orConditionGroup);
$query
->addField('b', 'process_id');
$query
->addField('c', 'process_name');
$query
->groupBy('b.process_id');
$query
->groupBy('c.process_name');
}
$result = $query
->execute();
$output = [];
foreach ($result as $row) {
$status_bar = MaestroStatus::getMaestroStatusBar($row->process_id, 0, TRUE);
$templateName = MaestroEngine::getTemplateIdFromProcessId($row->process_id);
$process_name = $row->process_name;
$link_start = '';
$link_end = '';
if (isset($conf['maestro_provide_link']) && $conf['maestro_provide_link'] != '') {
$interim_link = str_replace('[uid]', $usr
->id(), $conf['maestro_provide_link']);
$interim_link = str_replace('[username]', $usr
->getAccountName(), $interim_link);
$link_start = '<a href="' . $interim_link . '" title="' . $this
->t($this->configuration['maestro_link_tooltip']) . '">';
$link_end = '</a>';
}
$output['status'][] = [
'#prefix' => $link_start . '<div id="processid-' . $row->process_id . '" class="maestro-block-process ' . $templateName . '">
<div class="maestro-block-process-title">' . $process_name . '</div>',
'#suffix' => '</div>' . $link_end,
'#markup' => $status_bar['status_bar']['#children'],
];
}
$output['#attached']['library'][] = 'maestro/maestro-engine-css';
// Keeping the cache lines commented for now to ensure caching for this block is indeed disabled
// $output['#cache'] = ['contexts' => ['url.query_args:process_id']]; //don't cache the process_id url parameter
// $output['#cache']['max-age'] = 0; //just disable the cache completely for this module.
return $output;
}
}
/**
* {@inheritDoc}
*
* @see \Drupal\Core\Plugin\ContextAwarePluginBase::getCacheMaxAge()
*/
public function getCacheMaxAge() {
// Caching turned off for this block.
return 0;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
BlockPluginInterface:: |
constant | Indicates the block label (title) should be displayed to end users. | ||
BlockPluginTrait:: |
protected | property | The transliteration service. | |
BlockPluginTrait:: |
public | function | ||
BlockPluginTrait:: |
protected | function | Returns generic default configuration for block plugins. | |
BlockPluginTrait:: |
protected | function | Indicates whether the block should be shown. | 16 |
BlockPluginTrait:: |
public | function | 3 | |
BlockPluginTrait:: |
public | function | Creates a generic configuration form for all block types. Individual block plugins can add elements to this form by overriding BlockBase::blockForm(). Most block plugins should not override this method unless they need to alter the generic form elements. | 2 |
BlockPluginTrait:: |
public | function | ||
BlockPluginTrait:: |
public | function | 19 | |
BlockPluginTrait:: |
public | function | 1 | |
BlockPluginTrait:: |
public | function | 1 | |
BlockPluginTrait:: |
public | function | 3 | |
BlockPluginTrait:: |
public | function | ||
BlockPluginTrait:: |
public | function | ||
BlockPluginTrait:: |
public | function | ||
BlockPluginTrait:: |
public | function | Sets the transliteration service. | |
BlockPluginTrait:: |
public | function | Most block plugins should not override this method. To add submission handling for a specific block type, override BlockBase::blockSubmit(). | |
BlockPluginTrait:: |
protected | function | Wraps the transliteration service. | |
BlockPluginTrait:: |
public | function | Most block plugins should not override this method. To add validation for a specific block type, override BlockBase::blockValidate(). | 1 |
BlockPluginTrait:: |
public | function | 22 | |
ContextAwarePluginAssignmentTrait:: |
protected | function | Builds a form element for assigning a context to a given slot. | |
ContextAwarePluginAssignmentTrait:: |
protected | function | Wraps the context handler. | |
ContextAwarePluginBase:: |
protected | property | The data objects representing the context of this plugin. | |
ContextAwarePluginBase:: |
private | property | Data objects representing the contexts passed in the plugin configuration. | |
ContextAwarePluginBase:: |
protected | function |
Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
The cache contexts associated with this object. Overrides CacheableDependencyInterface:: |
9 |
ContextAwarePluginBase:: |
public | function |
The cache tags associated with this object. Overrides CacheableDependencyInterface:: |
4 |
ContextAwarePluginBase:: |
public | function |
This code is identical to the Component in order to pick up a different
Context class. Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Gets a mapping of the expected assignment names to their context names. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Gets the defined contexts. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Gets the value for a defined context. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Gets the values for all defined contexts. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Set a context on this plugin. Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Sets a mapping of the expected assignment names to their context names. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Sets the value for a defined context. Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Validates the set values for the defined contexts. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function | Implements magic __get() method. | |
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
MaestroProcessStatusBlock:: |
public | function |
Overrides BlockPluginTrait:: |
|
MaestroProcessStatusBlock:: |
public | function |
Overrides BlockPluginTrait:: |
|
MaestroProcessStatusBlock:: |
public | function |
Builds and returns the renderable array for this block plugin. Overrides BlockPluginInterface:: |
|
MaestroProcessStatusBlock:: |
public | function |
Overrides ContextAwarePluginBase:: |
|
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
PluginBase:: |
protected | property | Configuration information passed into the plugin. | 1 |
PluginBase:: |
protected | property | The plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
PluginBase:: |
constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
PluginBase:: |
public | function |
Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
3 |
PluginBase:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
PluginBase:: |
public | function | Determines if the plugin is configurable. | |
PluginWithFormsTrait:: |
public | function | ||
PluginWithFormsTrait:: |
public | function | ||
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. | |
TypedDataTrait:: |
protected | property | The typed data manager used for creating the data types. | |
TypedDataTrait:: |
public | function | Gets the typed data manager. | 2 |
TypedDataTrait:: |
public | function | Sets the typed data manager. | 2 |