View source
<?php
namespace Drupal\uc_payment;
use Drupal\Core\Config\Entity\DraggableListBuilder;
use Drupal\Core\Entity\EntityInterface;
use Drupal\Core\Entity\EntityStorageInterface;
use Drupal\Core\Entity\EntityTypeInterface;
use Drupal\Core\Form\FormStateInterface;
use Drupal\Core\Url;
use Drupal\uc_payment\Plugin\PaymentMethodManager;
use Symfony\Component\DependencyInjection\ContainerInterface;
class PaymentMethodListBuilder extends DraggableListBuilder {
protected $paymentMethodManager;
public function __construct(EntityTypeInterface $entity_type, EntityStorageInterface $storage, PaymentMethodManager $payment_method_manager) {
parent::__construct($entity_type, $storage);
$this->paymentMethodManager = $payment_method_manager;
}
public static function createInstance(ContainerInterface $container, EntityTypeInterface $entity_type) {
return new static($entity_type, $container
->get('entity_type.manager')
->getStorage($entity_type
->id()), $container
->get('plugin.manager.uc_payment.method'));
}
public function getFormId() {
return 'uc_payment_methods_form';
}
public function buildHeader() {
$header['label'] = [
'data' => $this
->t('Payment method'),
];
$header['plugin'] = [
'data' => $this
->t('Type'),
'class' => [
RESPONSIVE_PRIORITY_LOW,
],
];
$header['status'] = [
'data' => $this
->t('Status'),
];
return $header + parent::buildHeader();
}
public function buildRow(EntityInterface $entity) {
$row['label'] = $entity
->label();
$definition = $entity
->getPlugin()
->getPluginDefinition();
$row['plugin']['#markup'] = $definition['name'];
$row['status']['#markup'] = $entity
->status() ? $this
->t('Enabled') : $this
->t('Disabled');
return $row + parent::buildRow($entity);
}
public function getDefaultOperations(EntityInterface $entity) {
$operations = parent::getDefaultOperations($entity);
if (isset($operations['delete']) && $entity
->isLocked()) {
unset($operations['delete']);
}
return $operations;
}
public function buildForm(array $form, FormStateInterface $form_state) {
$options = array_map(function ($definition) {
return $definition['name'];
}, array_filter($this->paymentMethodManager
->getDefinitions(), function ($definition) {
return !$definition['no_ui'];
}));
if ($options) {
uasort($options, 'strnatcasecmp');
$form['add'] = [
'#type' => 'details',
'#title' => $this
->t('Add payment method'),
'#open' => TRUE,
'#attributes' => [
'class' => [
'container-inline',
],
],
];
$form['add']['payment_method_type'] = [
'#type' => 'select',
'#title' => $this
->t('Type'),
'#empty_option' => $this
->t('- Choose -'),
'#options' => $options,
];
$form['add']['submit'] = [
'#type' => 'submit',
'#value' => $this
->t('Add payment method'),
'#validate' => [
'::validateAddPaymentMethod',
],
'#submit' => [
'::submitAddPaymentMethod',
],
'#limit_validation_errors' => [
[
'payment_method_type',
],
],
];
}
$form = parent::buildForm($form, $form_state);
$form[$this->entitiesKey]['#empty'] = $this
->t('No payment methods have been configured.');
$form['actions']['#type'] = 'actions';
$form['actions']['submit'] = [
'#type' => 'submit',
'#value' => $this
->t('Save configuration'),
'#button_type' => 'primary',
];
return $form;
}
public function submitForm(array &$form, FormStateInterface $form_state) {
parent::submitForm($form, $form_state);
$this
->messenger()
->addMessage($this
->t('The configuration options have been saved.'));
}
public function validateAddPaymentMethod(array &$form, FormStateInterface $form_state) {
if ($form_state
->isValueEmpty('payment_method_type')) {
$form_state
->setErrorByName('payment_method_type', $this
->t('You must select the new payment method type.'));
}
}
public function submitAddPaymentMethod(array &$form, FormStateInterface $form_state) {
$form_state
->setRedirect('entity.uc_payment_method.add_form', [
'plugin_id' => $form_state
->getValue('payment_method_type'),
]);
}
public function render() {
$build['description'] = [
'#markup' => '<p>' . $this
->t('By default, only the "No payment required" payment method is listed here. To see additional payment methods you must <a href=":install">install additional modules</a>. The "Payment Method Pack" module that comes with Ubercart provides "Check" and "COD" payment methods. The "Credit Card" module that comes with Ubercart provides a credit card payment method, although you will need an additional module to provide a payment gateway for your credit card. For more information about payment methods and settings please read the <a href=":doc">Ubercart Documentation</a>.', [
':install' => Url::fromRoute('system.modules_list', [], [
'fragment' => 'edit-modules-ubercart-payment',
])
->toString(),
':doc' => Url::fromUri('https://www.drupal.org/docs/8/modules/ubercart')
->toString(),
]) . '</p><p>' . $this
->t('The order of methods shown below is the order those methods will appear on the checkout page. To re-order, drag the method to its desired location using the drag icon then save the configuration using the button at the bottom of the page.') . '</p>',
];
$build += parent::render();
return $build;
}
}