2021-12-14 18:32:47 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
2012-09-23 14:18:12 -07:00
|
|
|
|
2023-01-10 22:44:09 +00:00
|
|
|
namespace Shimmie2;
|
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
class VideoFileHandlerTheme extends Themelet
|
|
|
|
{
|
|
|
|
public function display_image(Page $page, Image $image)
|
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
$ilink = $image->get_image_link();
|
|
|
|
$thumb_url = make_http($image->get_thumb_link()); //used as fallback image
|
2020-06-14 11:05:55 -05:00
|
|
|
$mime = strtolower($image->get_mime());
|
2020-06-02 18:03:28 -05:00
|
|
|
$autoplay = $config->get_bool(VideoFileHandlerConfig::PLAYBACK_AUTOPLAY);
|
|
|
|
$loop = $config->get_bool(VideoFileHandlerConfig::PLAYBACK_LOOP);
|
2020-06-24 08:14:24 -05:00
|
|
|
$mute = $config->get_bool(VideoFileHandlerConfig::PLAYBACK_MUTE);
|
2016-05-14 23:14:29 +01:00
|
|
|
|
2023-11-11 21:49:12 +00:00
|
|
|
$width = "auto";
|
|
|
|
if ($image->width > 1) {
|
2020-06-02 17:49:35 -05:00
|
|
|
$width = $image->width."px";
|
|
|
|
}
|
2023-11-11 21:49:12 +00:00
|
|
|
$height = "auto";
|
|
|
|
if ($image->height > 1) {
|
2020-06-02 17:49:35 -05:00
|
|
|
$height = $image->height."px";
|
|
|
|
}
|
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
$html = "Video not playing? <a href='$ilink'>Click here</a> to download the file.<br/>";
|
2016-05-14 23:14:29 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
//Browser media format support: https://developer.mozilla.org/en-US/docs/Web/HTML/Supported_media_formats
|
2020-05-28 10:05:20 -05:00
|
|
|
|
2020-06-14 11:05:55 -05:00
|
|
|
if (MimeType::matches_array($mime, VideoFileHandler::SUPPORTED_MIME)) {
|
|
|
|
if ($mime == MimeType::WEBM) {
|
2020-03-25 11:47:00 +00:00
|
|
|
//Several browsers still lack WebM support sadly: https://caniuse.com/#feat=webm
|
2019-05-28 17:59:38 +01:00
|
|
|
$html .= "<!--[if IE]><p>To view webm files with IE, please <a href='https://tools.google.com/dlpage/webmmf/' target='_blank'>download this plugin</a>.</p><![endif]-->";
|
|
|
|
}
|
2016-05-14 23:14:29 +01:00
|
|
|
|
2021-03-14 15:47:29 +00:00
|
|
|
$autoplay = ($autoplay ? ' autoplay' : '');
|
|
|
|
$loop = ($loop ? ' loop' : '');
|
|
|
|
$mute = ($mute ? ' muted' : '');
|
2021-03-14 15:43:35 +00:00
|
|
|
|
2021-03-14 15:47:29 +00:00
|
|
|
$html .= "
|
2021-03-14 15:43:35 +00:00
|
|
|
<video controls class='shm-main-image' id='main_image' alt='main image' poster='$thumb_url' {$autoplay} {$loop} {$mute}
|
|
|
|
style='height: $height; width: $width; max-width: 100%; object-fit: contain; background-color: black;'>
|
|
|
|
<source src='{$ilink}' type='{$mime}'>
|
|
|
|
</video>
|
|
|
|
<script>$('#main_image').prop('volume', 0.25);</script>
|
|
|
|
";
|
2019-05-28 17:59:38 +01:00
|
|
|
} else {
|
|
|
|
//This should never happen, but just in case let's have a fallback..
|
2020-05-28 10:05:20 -05:00
|
|
|
$html = "Video type '$mime' not recognised";
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
$page->add_block(new Block("Video", $html, "main", 10));
|
|
|
|
}
|
2012-09-23 14:18:12 -07:00
|
|
|
}
|