class AdminComments in Ubercart 8.4
View the admin comments, used for administrative notes and instructions.
Plugin annotation
@UbercartOrderPane(
id = "admin_comments",
title = @Translation("Admin comments"),
weight = 9,
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\uc_order\OrderPanePluginBase implements OrderPanePluginInterface
- class \Drupal\uc_order\EditableOrderPanePluginBase implements EditableOrderPanePluginInterface
- class \Drupal\uc_order\Plugin\Ubercart\OrderPane\AdminComments
- class \Drupal\uc_order\EditableOrderPanePluginBase implements EditableOrderPanePluginInterface
- class \Drupal\uc_order\OrderPanePluginBase implements OrderPanePluginInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of AdminComments
File
- uc_order/
src/ Plugin/ Ubercart/ OrderPane/ AdminComments.php, line 19
Namespace
Drupal\uc_order\Plugin\Ubercart\OrderPaneView source
class AdminComments extends EditableOrderPanePluginBase {
/**
* {@inheritdoc}
*/
public function view(OrderInterface $order, $view_mode) {
if ($view_mode != 'customer') {
$build = [
'#theme' => 'table',
'#header' => [
[
'data' => $this
->t('Date'),
'class' => [
'date',
],
],
[
'data' => $this
->t('User'),
'class' => [
'user',
],
],
[
'data' => $this
->t('Comment'),
'class' => [
'message',
],
],
],
'#rows' => [],
'#attributes' => [
'class' => [
'order-pane-table uc-order-comments',
],
],
'#empty' => $this
->t('This order has no admin comments associated with it.'),
];
$comments = uc_order_comments_load($order
->id(), TRUE);
foreach ($comments as $comment) {
$build['#rows'][] = [
[
'data' => \Drupal::service('date.formatter')
->format($comment->created, 'short'),
'class' => [
'date',
],
],
[
'data' => [
'#theme' => 'username',
'#account' => User::load($comment->uid),
],
'class' => [
'user',
],
],
[
'data' => [
'#markup' => $comment->message,
],
'class' => [
'message',
],
],
];
}
return $build;
}
}
/**
* {@inheritdoc}
*/
public function buildForm(OrderInterface $order, array $form, FormStateInterface $form_state) {
$items = [];
$comments = uc_order_comments_load($order
->id(), TRUE);
foreach ($comments as $comment) {
$items[] = [
'username' => [
'#theme' => 'username',
'#account' => User::load($comment->uid),
'#prefix' => '[',
'#suffix' => '] ',
],
'message' => [
'#markup' => $comment->message,
],
];
}
$form['comments'] = [
'#theme' => 'item_list',
'#items' => $items,
'#empty' => $this
->t('No admin comments have been entered for this order.'),
];
$form['admin_comment_field'] = [
'#type' => 'details',
'#title' => $this
->t('Add an admin comment'),
];
$form['admin_comment_field']['admin_comment'] = [
'#type' => 'textarea',
'#description' => $this
->t('Admin comments are only seen by store administrators.'),
];
return $form;
}
/**
* {@inheritdoc}
*/
public function submitForm(OrderInterface $order, array &$form, FormStateInterface $form_state) {
if (!$form_state
->isValueEmpty('admin_comment')) {
$uid = \Drupal::currentUser()
->id();
uc_order_comment_save($order
->id(), $uid, $form_state
->getValue('admin_comment'));
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
AdminComments:: |
public | function |
Form constructor. Overrides EditableOrderPanePluginInterface:: |
|
AdminComments:: |
public | function |
Form submission handler. Overrides EditableOrderPanePluginInterface:: |
|
AdminComments:: |
public | function |
Returns the contents of an order pane as a store administrator. Overrides OrderPanePluginInterface:: |
|
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 | |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
OrderPanePluginBase:: |
public | function | ||
OrderPanePluginBase:: |
public | function |
Returns the classes used to wrap an order pane. Overrides OrderPanePluginInterface:: |
6 |
OrderPanePluginBase:: |
public | function |
Returns the title of an order pane. Overrides OrderPanePluginInterface:: |
2 |
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. | |
PluginBase:: |
public | function | Constructs a \Drupal\Component\Plugin\PluginBase object. | 92 |
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. |