You are here

public function ScheduledPublishWidget::massageFormValues in Scheduled Publish 8.3

Same name and namespace in other branches
  1. 8 src/Plugin/Field/FieldWidget/ScheduledPublishWidget.php \Drupal\scheduled_publish\Plugin\Field\FieldWidget\ScheduledPublishWidget::massageFormValues()
  2. 8.2 src/Plugin/Field/FieldWidget/ScheduledPublishWidget.php \Drupal\scheduled_publish\Plugin\Field\FieldWidget\ScheduledPublishWidget::massageFormValues()

Massages the form values into the format expected for field values.

Parameters

array $values: The submitted form values produced by the widget.

  • If the widget does not manage multiple values itself, the array holds the values generated by the multiple copies of the $element generated by the formElement() method, keyed by delta.
  • If the widget manages multiple values, the array holds the values of the form element generated by the formElement() method.

array $form: The form structure where field elements are attached to. This might be a full form structure, or a sub-element of a larger form.

\Drupal\Core\Form\FormStateInterface $form_state: The form state.

Return value

array An array of field values, keyed by delta.

Overrides WidgetBase::massageFormValues

File

src/Plugin/Field/FieldWidget/ScheduledPublishWidget.php, line 129

Class

ScheduledPublishWidget
Plugin implementation of the 'scheduled_publish_widget' widget.

Namespace

Drupal\scheduled_publish\Plugin\Field\FieldWidget

Code

public function massageFormValues(array $values, array $form, FormStateInterface $form_state) : array {

  // Make sure values stored in form_state get saved into database.
  $field_name = $this->fieldDefinition
    ->getName();
  $entries = $form_state
    ->get([
    'scheduled_publish',
    $field_name,
  ]);
  $values = [];
  foreach ($entries as $key => $entry) {
    $values[$key] = [
      'moderation_state' => $entry['state'],
      'value' => $entry['date'],
    ];
  }
  return $values;
}