diff --git a/PicoUICard.php b/PicoUICard.php index 4cab1d7..d702902 100644 --- a/PicoUICard.php +++ b/PicoUICard.php @@ -49,6 +49,7 @@ final class PicoUICard extends AbstractPicoPlugin public function onConfigLoaded(array &$config) { $this->config['loadBootstrap'] = false; + $this->config['cardRatio'] = '16:9'; $this->config['cardPosition'] = 'col-md-4 col-sm-6 col-xs-6'; $this->config['cardTitle'] = ''; $this->config['cardText'] = ''; @@ -56,6 +57,9 @@ final class PicoUICard extends AbstractPicoPlugin if (isset($config['PicoUICard.loadBootstrap'])) { $this->config['loadBootstrap'] = $config['PicoUICard.loadBootstrap']; } + if (isset($config['PicoUICard.cardRatio'])) { + $this->config['cardRatio'] = $config['PicoUICard.cardRatio']; + } if (isset($config['PicoUICard.cssClass.cardPosition'])) { $this->config['cardPosition'] = $config['PicoUICard.cssClass.cardPosition']; } @@ -65,6 +69,9 @@ final class PicoUICard extends AbstractPicoPlugin if (isset($config['PicoUICard.cssClass.cardText'])) { $this->config['cardText'] = $config['PicoUICard.cssClass.cardText']; } + // some postprocessing of config + list($cardWidth, $cardHeight) = explode(':', $this->config['cardRatio']); + $this->config['cardHeightMultiplier'] = max(0.01, min(floatval($cardHeight) / floatval($cardWidth), 10)) * 100; } /** @@ -90,7 +97,7 @@ final class PicoUICard extends AbstractPicoPlugin preg_match_all('/\s*([a-z]+)\=[\'\"]([^\'\"]*)[\'\"]/', $matches[1], $attributes); preg_match_all('/\[([a-z]+)\]([^\[]*)\[\/([a-z]+)\]\s*/', $matches[3], $subtags); // look for what we want from attributes and subtags - $uicard = array('href' => '', 'img' => '', 'title' => '', 'text' => ''); + $uicard = array('href' => '', 'img' => '', 'ratio' => '', 'title' => '', 'text' => ''); for ($i = 0; $i < count($attributes[0]); $i++) { $uicard[ $attributes[1][$i] ] = $attributes[2][$i]; } @@ -100,9 +107,15 @@ final class PicoUICard extends AbstractPicoPlugin } $uicard[ $subtags[1][$i] ] = $subtags[2][$i]; } + if (!empty($uicard['ratio'])) { + list($cardWidth, $cardHeight) = explode(':', $uicard['ratio']); + $cardRatio = ' padding-bottom: '.(max(0.01, min(floatval($cardHeight) / floatval($cardWidth), 10)) * 100).'%;'; + } else { + $cardRatio = ''; // default + } $result = '