You are here

class FractionTarget in Fraction 2.x

Same name and namespace in other branches
  1. 8 src/Feeds/Target/FractionTarget.php \Drupal\fraction\Feeds\Target\FractionTarget

Defines a fraction field mapper.

Plugin annotation


@FeedsTarget(
  id = "fraction",
  field_types = {
    "fraction",
  }
)

Hierarchy

  • class \Drupal\fraction\Feeds\Target\FractionTarget extends \Drupal\feeds\Plugin\Type\Target\FieldTargetBase implements \Drupal\feeds\Plugin\Type\Target\ConfigurableTargetInterface

Expanded class hierarchy of FractionTarget

1 file declares its use of FractionTarget
FractionTargetTest.php in tests/src/Unit/Feeds/Target/FractionTargetTest.php

File

src/Feeds/Target/FractionTarget.php, line 20

Namespace

Drupal\fraction\Feeds\Target
View source
class FractionTarget extends FieldTargetBase implements ConfigurableTargetInterface {

  /**
   * Helper function to define the ways to import the fraction data.
   *
   * @return array
   *   Array with all the possible types.
   */
  protected function importTypes() {
    return [
      'fraction' => $this
        ->t('Fraction'),
      'decimal' => $this
        ->t('Decimal'),
    ];
  }

  /**
   * {@inheritdoc}
   */
  public function defaultConfiguration() {
    return [
      'type' => 'fraction',
    ];
  }

  /**
   * {@inheritdoc}
   */
  public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
    $form['type'] = [
      '#type' => 'select',
      '#title' => $this
        ->t('Filter format'),
      '#options' => $this
        ->importTypes(),
      '#default_value' => $this->configuration['type'],
    ];
    return $form;
  }

  /**
   * {@inheritdoc}
   */
  public function getSummary() {
    $types = $this
      ->importTypes();
    return $this
      ->t('Import type: %type', [
      '%type' => $types[$this->configuration['type']],
    ]);
  }

  /**
   * {@inheritdoc}
   */
  protected function prepareValue($delta, array &$values) {
    $item = trim($values['value']);
    unset($values['value']);
    switch ($this->configuration['type']) {
      case 'fraction':

        // Pull out the numerator and denominator.
        $parts = explode('/', $item);
        if (!empty($parts[0]) && is_numeric($parts[0]) && !empty($parts[1]) && is_numeric($parts[1]) && $parts[1] >= 0) {
          $values['numerator'] = $parts[0];
          $values['denominator'] = $parts[1];
        }
        else {
          $values['numerator'] = '';
          $values['denominator'] = '';
        }
        break;
      case 'decimal':

        // If item is non-numeric or an empty string, create an empty fraction.
        // Otherwise, pass the value to createFromDecimal().
        if (!is_numeric($item) || $item === '') {
          $values['numerator'] = '';
          $values['denominator'] = '';
        }
        else {
          $fraction = Fraction::createFromDecimal($item);
          $values['numerator'] = $fraction
            ->getNumerator();
          $values['denominator'] = $fraction
            ->getDenominator();
        }
        break;
    }
  }

}

Members

Namesort descending Modifiers Type Description Overrides
FractionTarget::buildConfigurationForm public function
FractionTarget::defaultConfiguration public function
FractionTarget::getSummary public function
FractionTarget::importTypes protected function Helper function to define the ways to import the fraction data.
FractionTarget::prepareValue protected function