You are here

public function MediaElementAudioPlayer::renderPlayer in AudioField 8

Renders the player.

Parameters

\Drupal\Core\Field\FieldItemListInterface $items: The uploaded item list.

string $langcode: The language code.

array $settings: An array of additional render settings.

Return value

array Returns the rendered array.

Overrides AudioFieldPluginBase::renderPlayer

File

src/Plugin/AudioPlayer/MediaElementAudioPlayer.php, line 28

Class

MediaElementAudioPlayer
Implements the MediaElement Audio Player plugin.

Namespace

Drupal\audiofield\Plugin\AudioPlayer

Code

public function renderPlayer(FieldItemListInterface $items, $langcode, array $settings) {

  // Check to make sure we're installed.
  if (!$this
    ->checkInstalled()) {

    // Show the error.
    $this
      ->showInstallError();

    // Simply return the default rendering so the files are still displayed.
    return $this
      ->renderDefaultPlayer($items, $settings);
  }

  // Start building settings to pass to the javascript MediaElement builder.
  $player_settings = [
    // MediaElement expects this as a 0 - 1 range.
    'volume' => $settings['audio_player_initial_volume'] / 10,
    'elements' => [],
  ];

  // Format files for output.
  $template_files = $this
    ->getItemRenderList($items);
  foreach ($template_files as $renderInfo) {

    // Pass the element name for the player so we know what to render.
    $player_settings['elements'][] = '#mediaelement_player_' . $renderInfo->id;
  }
  return [
    'audioplayer' => [
      '#theme' => 'audioplayer',
      '#plugin_id' => 'mediaelement',
      '#settings' => $settings,
      '#files' => $template_files,
    ],
    'downloads' => $this
      ->createDownloadList($items, $settings),
    '#attached' => [
      'library' => [
        // Attach the MediaElement library.
        'audiofield/audiofield.' . $this
          ->getPluginLibraryName(),
      ],
      'drupalSettings' => [
        'audiofieldmediaelement' => [
          $this
            ->getUniqueRenderId() => $player_settings,
        ],
      ],
    ],
  ];
}