Current File : /home/pacjaorg/www/kmm/components/com_sppagebuilder/layouts/row/css.php |
<?php
/**
* @package SP Page Builder
* @author JoomShaper http://www.joomshaper.com
* @copyright Copyright (c) 2010 - 2023 JoomShaper
* @license http://www.gnu.org/licenses/gpl-2.0.html GNU/GPLv2 or later
*/
//no direct access
defined('_JEXEC') or die('Restricted access');
use Joomla\CMS\Factory;
use Joomla\CMS\Uri\Uri;
use Joomla\CMS\Component\ComponentHelper;
$options = $displayData['options'];
$device = SpPgaeBuilderBase::$defaultDevice;
$doc = Factory::getDocument();
// Image lazy load
$config = ComponentHelper::getParams('com_sppagebuilder');
$lazyload = $config->get('lazyloadimg', '0');
$placeholder = $config->get('lazyplaceholder', '');
$lazy_bg_image = '';
$placeholder_bg_image = '';
$row_id = (isset($options->id) && $options->id) ? $options->id : 'section-id-' . $options->dynamicId;
$rowIdSelector = '.sp-page-builder .page-content #' . $row_id;
$cssHelper = new CSSHelper($rowIdSelector, true);
$row_styles = '';
$style = '';
$styleX = '';
$mediaStyle = '';
$propMaps = [
'padding' => 'padding',
'margin' => 'margin',
'section_overflow_x' => 'overflow-x',
'section_overflow_y' => 'overflow-y',
'color' => 'color',
'row_border_radius' => 'border-radius',
'row_border_style' => !empty($options->row_border) ? 'border-style' : null,
'row_border_color' => !empty($options->row_border) ? 'border-color' : null,
'row_border_width' => !empty($options->row_border) ? 'border-width' : null,
'row_width' => 'width',
'row_max_width' => 'max-width',
'row_min_width' => 'min-width',
];
$units = [
'row_border_color' => false,
'row_border_style' => false,
'row_border_width' => false,
'padding' => false,
'margin' => false,
'section_overflow_x' => false,
'section_overflow_y' => false,
'color' => false,
'row_width' => $options->row_width->unit ?? 'px',
'row_max_width' => $options->row_max_width->unit ?? 'px',
'row_min_width' => $options->row_min_width->unit ?? 'px',
];
$modifier = ['padding' => 'spacing', 'margin' => 'spacing'];
$default = [];
if (!empty($options->section_height_option) && $options->section_height_option === 'win-height') {
$propMaps['section_height'] = 'height';
$default['section_height'] = '100vh';
$units['section_height'] = false;
} elseif (!empty($options->section_height_option) && $options->section_height_option === 'height') {
$propMaps = array_merge($propMaps, [
'section_height' => 'height'
]);
}
$propMaps = array_merge($propMaps, [
'row_width' => 'width',
'section_min_height' => 'min-height',
'section_max_height' => 'max-height',
'row_max_width' => 'max-width',
'row_min_width' => 'min-width'
]);
$sectionStyle = $cssHelper->generateStyle(':self', $options, $propMaps, $units, $modifier, $default);
$cssHelper->setID($rowIdSelector . '.sppb-row-overlay', true);
$sectionOverlay = $cssHelper->generateStyle(':self', $options, ['row_border_radius' => 'border-radius']);
$cssHelper->setID($rowIdSelector, true);
$sectionStyle .= $sectionOverlay;
$deviceList = array_filter(AddonHelper::$deviceList, function ($size) {
return $size !== SpPgaeBuilderBase::$defaultDevice;
});
$background_image = (isset($options->background_image) && $options->background_image) ? $options->background_image : '';
$background_image_src = isset($background_image->src) ? $background_image->src : $background_image;
if (property_exists($options, 'background_type') && isset($options->background_type)) {
if (($options->background_type == 'image' || $options->background_type == 'color') && isset($options->background_color) && $options->background_color) $style .= 'background-color:' . $options->background_color . ';';
if (($options->background_type == 'image' && $background_image_src) || (isset($options->background_type) && $options->background_type == 'video')) {
if ($lazyload) {
if ($placeholder) {
$placeholder_bg_image .= 'background-image:url(' . $placeholder . ');';
}
if (strpos($background_image_src, "http://") !== false || strpos($background_image_src, "https://") !== false) {
$lazy_bg_image .= 'background-image:url(' . $background_image_src . ');';
} else {
$originalSrc = Uri::base(true) . '/' . $background_image_src;
$lazy_bg_image .= 'background-image:url(' . SppagebuilderHelperSite::cleanPath($originalSrc) . ');';
}
} else {
if (strpos($background_image_src, "http://") !== false || strpos($background_image_src, "https://") !== false) {
$style .= 'background-image:url(' . $background_image_src . ');';
} else {
$original_src = Uri::base(true) . '/' . $background_image_src;
$style .= 'background-image:url(' . SppagebuilderHelperSite::cleanPath($original_src) . ');';
}
}
if (isset($options->background_repeat) && $options->background_repeat) $style .= 'background-repeat:' . $options->background_repeat . ';';
if (isset($options->background_size) && $options->background_size && $options->background_size != 'custom') $style .= 'background-size:' . $options->background_size . ';';
if (isset($options->background_attachment) && $options->background_attachment) $style .= 'background-attachment:' . $options->background_attachment . ';';
if (isset($options->background_position) && $options->background_position && $options->background_position != 'custom') $style .= 'background-position:' . $options->background_position . ';';
if (isset($options->background_size) && $options->background_size == 'custom') {
if (isset($options->background_size_custom) && \is_object($options->background_size_custom)) {
$backgroundSize = AddonHelper::generateMultiDeviceObject($options, 'background_size_custom', 'background-size', $device, false, ($options->background_size_custom->unit ?? 'px'));
$styleX .= $backgroundSize->$device;
}
}
}
if (isset($options->background_position) && $options->background_position == 'custom') {
$backgroundPosition = AddonHelper::initDeviceObject();
foreach ($backgroundPosition as $key => $_) {
if (isset($options->background_position_custom_x->$key) && isset($options->background_position_custom_y->$key)) {
$backgroundPosition->$key = \is_object($options->background_position_custom_x) && \is_object($options->background_position_custom_y)
? 'background-position: ' . $options->background_position_custom_x->$key . $options->background_position_custom_x->unit . ' ' . $options->background_position_custom_y->$key . $options->background_position_custom_y->unit . ';'
: 'background-position: ' . $options->background_position_custom_x . $options->background_position_custom_x->unit . ' ' . $options->background_position_custom_y . $options->background_position_custom_y->unit . ';';
}
}
$styleX .= $backgroundPosition->$device;
}
if ($options->background_type == 'gradient' && isset($options->background_gradient) && is_object($options->background_gradient)) {
$radialPos = (isset($options->background_gradient->radialPos) && !empty($options->background_gradient->radialPos)) ? $options->background_gradient->radialPos : 'center center';
$gradientColor = (isset($options->background_gradient->color) && !empty($options->background_gradient->color)) ? $options->background_gradient->color : '';
$gradientColor2 = (isset($options->background_gradient->color2) && !empty($options->background_gradient->color2)) ? $options->background_gradient->color2 : '';
$gradientDeg = (isset($options->background_gradient->deg) && !empty($options->background_gradient->deg)) ? $options->background_gradient->deg : '0';
$gradientPos = (isset($options->background_gradient->pos) && !empty($options->background_gradient->pos)) ? $options->background_gradient->pos : '0';
$gradientPos2 = (isset($options->background_gradient->pos2) && !empty($options->background_gradient->pos2)) ? $options->background_gradient->pos2 : '100';
if (isset($options->background_gradient->type) && $options->background_gradient->type == 'radial') {
$style .= "\tbackground-image: radial-gradient(at " . $radialPos . ", " . $gradientColor . " " . $gradientPos . "%, " . $gradientColor2 . " " . $gradientPos2 . "%);\n";
} else {
$style .= "\tbackground-image: linear-gradient(" . $gradientDeg . "deg, " . $gradientColor . " " . $gradientPos . "%, " . $gradientColor2 . " " . $gradientPos2 . "%);\n";
}
}
} else {
if (isset($options->background_color) && $options->background_color) $style .= 'background-color:' . $options->background_color . ';';
if ($background_image_src || (isset($options->background_type) && $options->background_type == 'video')) {
if ($lazyload) {
if ($placeholder) {
$placeholder_bg_image .= 'background-image:url(' . $placeholder . ');';
}
if (strpos($background_image_src, "http://") !== false || strpos($background_image_src, "https://") !== false) {
$lazy_bg_image .= 'background-image:url(' . $background_image_src . ');';
} else {
$original_src = Uri::base(true) . '/' . $background_image_src;
$lazy_bg_image .= 'background-image:url(' . SppagebuilderHelperSite::cleanPath($original_src) . ');';
}
} else {
if (strpos($background_image_src, "http://") !== false || strpos($background_image_src, "https://") !== false) {
$style .= 'background-image:url(' . $background_image_src . ');';
} else {
$original_src = Uri::base(true) . '/' . $background_image_src;
$style .= 'background-image:url(' . SppagebuilderHelperSite::cleanPath($original_src) . ');';
}
}
if (isset($options->background_repeat) && $options->background_repeat) $style .= 'background-repeat:' . $options->background_repeat . ';';
if (isset($options->background_size) && $options->background_size && $options->background_size != 'custom') $style .= 'background-size:' . $options->background_size . ';';
if (isset($options->background_attachment) && $options->background_attachment) $style .= 'background-attachment:' . $options->background_attachment . ';';
if (isset($options->background_position) && $options->background_position && $options->background_position != 'custom') $style .= 'background-position:' . $options->background_position . ';';
if (isset($options->background_size) && $options->background_size == 'custom') {
if (isset($options->background_size_custom) && \is_object($options->background_size_custom)) {
$backgroundSize = AddonHelper::generateMultiDeviceObject($options, 'background_size_custom', 'background-size', $device, false, ($options->background_size_custom->unit ?? 'px'));
$styleX .= $backgroundSize->$device;
}
}
if (isset($options->background_position) && $options->background_position == 'custom') {
$backgroundPosition = AddonHelper::initDeviceObject();
foreach ($backgroundPosition as $key => $_) {
if (!empty($options->background_position_custom_x->$key) && !empty($options->background_position_custom_y->$key)) {
$backgroundPosition->$key = \is_object($options->background_position_custom_x) && \is_object($options->background_position_custom_y)
? 'background-position: ' . $options->background_position_custom_x->$key . $options->background_position_custom_x->unit . ' ' . $options->background_position_custom_y->$key . $options->background_position_custom_y->unit . ';'
: 'background-position: ' . $options->background_position_custom_x . $options->background_position_custom_x->unit . ' ' . $options->background_position_custom_y . $options->background_position_custom_y->unit . ';';
}
}
$styleX .= $backgroundPosition->$device;
}
}
if ($style) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . '{' . $style . '}';
}
}
// Box Shadow
if (isset($options->row_boxshadow) && $options->row_boxshadow) {
if (is_object($options->row_boxshadow)) {
$ho = (isset($options->row_boxshadow->ho) && $options->row_boxshadow->ho != '') ? $options->row_boxshadow->ho . 'px' : '0px';
$vo = (isset($options->row_boxshadow->vo) && $options->row_boxshadow->vo != '') ? $options->row_boxshadow->vo . 'px' : '0px';
$blur = (isset($options->row_boxshadow->blur) && $options->row_boxshadow->blur != '') ? $options->row_boxshadow->blur . 'px' : '0px';
$spread = (isset($options->row_boxshadow->spread) && $options->row_boxshadow->spread != '') ? $options->row_boxshadow->spread . 'px' : '0px';
$color = (isset($options->row_boxshadow->color) && $options->row_boxshadow->color != '') ? $options->row_boxshadow->color : '#fff';
$style .= "box-shadow: {$ho} {$vo} {$blur} {$spread} {$color};";
} else {
$style .= "box-shadow: " . $options->row_boxshadow . ";";
}
}
$rowIdSelector = '.sp-page-builder .page-content #' . $row_id;
$backgroundSize = $backgroundSize ?? false;
$backgroundPosition = $backgroundPosition ?? false;
$mediaStyle = array_map(function ($size) use (
$rowIdSelector,
$backgroundSize,
$backgroundPosition
) {
$str = '';
$str .= AddonHelper::mediaQuery($size);
$str .= $rowIdSelector . '{';
$str .= !empty($backgroundSize) ? $backgroundSize->$size : '';
$str .= !empty($backgroundPosition) ? $backgroundPosition->$size : '';
$str .= '}';
$str .= '}';
return $str;
}, $deviceList);
if ($styleX) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . '{' . $styleX . '}';
}
$mediaStyle = implode("\n", $mediaStyle);
if ($mediaStyle) {
$row_styles .= $mediaStyle;
}
if ($style) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . '{' . $style . '}';
$row_styles .= '.sp-page-builder .page-content #' . $row_id . '{' . $placeholder_bg_image . '}';
$row_styles .= '.sp-page-builder .page-content #' . $row_id . '.sppb-element-loaded {' . $lazy_bg_image . '}';
}
$row_styles .= $sectionStyle;
// Overlay
if (isset($options->background_type)) {
if ($options->background_type == 'image' || $options->background_type == 'video') {
if (!isset($options->overlay_type)) {
$options->overlay_type = 'overlay_color';
}
if (isset($options->overlay) && $options->overlay && $options->overlay_type == 'overlay_color') {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {background-color: ' . $options->overlay . '}';
}
if (isset($options->gradient_overlay) && $options->gradient_overlay && $options->overlay_type == 'overlay_gradient') {
$overlay_radialPos = (isset($options->gradient_overlay->radialPos) && !empty($options->gradient_overlay->radialPos)) ? $options->gradient_overlay->radialPos : 'center center';
$overlay_gradientColor = (isset($options->gradient_overlay->color) && !empty($options->gradient_overlay->color)) ? $options->gradient_overlay->color : '';
$overlay_gradientColor2 = (isset($options->gradient_overlay->color2) && !empty($options->gradient_overlay->color2)) ? $options->gradient_overlay->color2 : '';
$overlay_gradientDeg = (isset($options->gradient_overlay->deg) && !empty($options->gradient_overlay->deg)) ? $options->gradient_overlay->deg : '0';
$overlay_gradientPos = (isset($options->gradient_overlay->pos) && !empty($options->gradient_overlay->pos)) ? $options->gradient_overlay->pos : '0';
$overlay_gradientPos2 = (isset($options->gradient_overlay->pos2) && !empty($options->gradient_overlay->pos2)) ? $options->gradient_overlay->pos2 : '100';
if (isset($options->gradient_overlay->type) && $options->gradient_overlay->type == 'radial') {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background: radial-gradient(at ' . $overlay_radialPos . ', ' . $overlay_gradientColor . ' ' . $overlay_gradientPos . '%, ' . $overlay_gradientColor2 . ' ' . $overlay_gradientPos2 . '%) transparent;
}';
} else {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background: linear-gradient(' . $overlay_gradientDeg . 'deg, ' . $overlay_gradientColor . ' ' . $overlay_gradientPos . '%, ' . $overlay_gradientColor2 . ' ' . $overlay_gradientPos2 . '%) transparent;
}';
}
}
if (isset($options->pattern_overlay) && $options->pattern_overlay && $options->overlay_type == 'overlay_pattern') {
if (is_object($options->pattern_overlay)) {
if (strpos($options->pattern_overlay->src, "http://") !== false || strpos($options->pattern_overlay->src, "https://") !== false) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-image:url(' . $options->pattern_overlay->src . ');
background-attachment: scroll;
}';
if (isset($options->overlay_pattern_color)) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-color:' . $options->overlay_pattern_color . ';
}';
}
} else {
$original_src = Uri::base(true) . '/' . $options->pattern_overlay->src;
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-image:url(' . SppagebuilderHelperSite::cleanPath($original_src) . ');
background-attachment: scroll;
}';
if (isset($options->overlay_pattern_color)) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-color:' . $options->overlay_pattern_color . ';
}';
}
}
} else {
if (strpos($options->pattern_overlay, "http://") !== false || strpos($options->pattern_overlay, "https://") !== false) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-image:url(' . $options->pattern_overlay . ');
background-attachment: scroll;
}';
if (isset($options->overlay_pattern_color)) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-color:' . $options->overlay_pattern_color . ';
}';
}
} else {
$original_src = Uri::base(true) . '/' . $options->pattern_overlay;
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-image:url(' . SppagebuilderHelperSite::cleanPath($original_src) . ');
background-attachment: scroll;
}';
if (isset($options->overlay_pattern_color)) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-color:' . $options->overlay_pattern_color . ';
}';
}
}
}
}
}
} else {
if (!isset($options->overlay_type)) {
$options->overlay_type = 'overlay_color';
}
if (isset($options->overlay) && $options->overlay && $options->overlay_type == 'overlay_color') {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {background-color: ' . $options->overlay . '}';
}
if (isset($options->gradient_overlay) && $options->gradient_overlay && $options->overlay_type == 'overlay_gradient') {
$overlay_radialPos = (isset($options->gradient_overlay->radialPos) && !empty($options->gradient_overlay->radialPos)) ? $options->gradient_overlay->radialPos : 'center center';
$overlay_gradientColor = (isset($options->gradient_overlay->color) && !empty($options->gradient_overlay->color)) ? $options->gradient_overlay->color : '';
$overlay_gradientColor2 = (isset($options->gradient_overlay->color2) && !empty($options->gradient_overlay->color2)) ? $options->gradient_overlay->color2 : '';
$overlay_gradientDeg = (isset($options->gradient_overlay->deg) && !empty($options->gradient_overlay->deg)) ? $options->gradient_overlay->deg : '0';
$overlay_gradientPos = (isset($options->gradient_overlay->pos) && !empty($options->gradient_overlay->pos)) ? $options->gradient_overlay->pos : '0';
$overlay_gradientPos2 = (isset($options->gradient_overlay->pos2) && !empty($options->gradient_overlay->pos2)) ? $options->gradient_overlay->pos2 : '100';
if (isset($options->gradient_overlay->type) && $options->gradient_overlay->type == 'radial') {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background: radial-gradient(at ' . $overlay_radialPos . ', ' . $overlay_gradientColor . ' ' . $overlay_gradientPos . '%, ' . $overlay_gradientColor2 . ' ' . $overlay_gradientPos2 . '%) transparent;
}';
} else {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background: linear-gradient(' . $overlay_gradientDeg . 'deg, ' . $overlay_gradientColor . ' ' . $overlay_gradientPos . '%, ' . $overlay_gradientColor2 . ' ' . $overlay_gradientPos2 . '%) transparent;
}';
}
}
if (isset($options->pattern_overlay) && $options->pattern_overlay && $options->overlay_type == 'overlay_pattern') {
if (is_object($options->pattern_overlay)) {
if (strpos($options->pattern_overlay->src, "http://") !== false || strpos($options->pattern_overlay->src, "https://") !== false) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-image:url(' . $options->pattern_overlay->src . ');
background-attachment: scroll;
}';
if (isset($options->overlay_pattern_color)) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-color:' . $options->overlay_pattern_color . ';
}';
}
} else {
$original_src = Uri::base(true) . '/' . $options->pattern_overlay->src;
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-image:url(' . SppagebuilderHelperSite::cleanPath($original_src) . ');
background-attachment: scroll;
}';
if (isset($options->overlay_pattern_color)) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-color:' . $options->overlay_pattern_color . ';
}';
}
}
} else {
if (strpos($options->pattern_overlay, "http://") !== false || strpos($options->pattern_overlay, "https://") !== false) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-image:url(' . $options->pattern_overlay . ');
background-attachment: scroll;
}';
if (isset($options->overlay_pattern_color)) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-color:' . $options->overlay_pattern_color . ';
}';
}
} else {
$original_src = Uri::base(true) . '/' . $options->pattern_overlay;
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-image:url(' . SppagebuilderHelperSite::cleanPath($original_src) . ');
background-attachment: scroll;
}';
if (isset($options->overlay_pattern_color)) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
background-color:' . $options->overlay_pattern_color . ';
}';
}
}
}
}
}
//Blend Mode
if (isset($options->background_type) && $options->background_type) {
if ($options->background_type == 'image') {
if (isset($options->blend_mode) && $options->blend_mode) {
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' > .sppb-row-overlay {
mix-blend-mode:' . $options->blend_mode . ';
}';
}
}
}
// Row Title
if ((isset($options->title) && $options->title) || (isset($options->subtitle) && $options->subtitle)) {
if (!empty($options->title)) {
$titleStyle = '';
if (!empty($options->title_fontsize)) {
$titleFontSize = AddonHelper::generateMultiDeviceObject($options, 'title_fontsize', ['font-size', 'line-height'], $device);
$titleStyle .= $titleFontSize->$device;
}
if (!empty($options->title_position)) {
$titleAlignment = CSSHelper::parseAlignment($options, 'title_position');
$titleStyle .= 'text-align: ' . $titleAlignment . ';';
}
if (!empty($options->title_fontweight)) {
$titleStyle .= 'font-weight: ' . $options->title_fontweight . ';';
}
if (!empty($options->title_text_color)) {
$titleStyle .= 'color:' . $options->title_text_color . ';';
}
$titleMarginTop = AddonHelper::generateMultiDeviceObject($options, 'title_margin_top', 'margin-top', $device);
$titleMarginBottom = AddonHelper::generateMultiDeviceObject($options, 'title_margin_bottom', 'margin-bottom', $device);
$titleStyle .= $titleMarginTop->$device;
$titleStyle .= $titleMarginBottom->$device;
$titleSelector = '.sp-page-builder .page-content #' . $row_id . ' .sppb-section-title .sppb-title-heading';
$titleFontSize = $titleFontSize ?? new stdClass;
$titleStyleMedia = array_map(
function ($size) use (
$titleSelector,
$titleFontSize,
$titleMarginTop,
$titleMarginBottom
) {
$str = AddonHelper::mediaQuery($size);
$str .= $titleSelector . '{';
$str .= $titleFontSize->$size ?? '';
$str .= $titleMarginTop->$size ?? '';
$str .= $titleMarginBottom->$size ?? '';
$str .= '}';
$str .= '}';
return $str;
},
$deviceList
);
$titleStyleMedia = implode("\r\n", $titleStyleMedia);
$row_styles .= !empty($titleStyle) ? '.sp-page-builder .page-content #' . $row_id . ' .sppb-section-title .sppb-title-heading {' . $titleStyle . '}' : '';
$row_styles .= !empty($titleStyleMedia) ? $titleStyleMedia : '';
}
// Subtitle font size
if (!empty($options->subtitle)) {
$subTitleStyle = '';
$subtitleFontSize = AddonHelper::generateMultiDeviceObject($options, 'subtitle_fontsize', 'font-size', $device);
$subtitleSelector = '.sp-page-builder .page-content #' . $row_id . ' .sppb-section-title .sppb-title-subheading';
if (!empty($options->title_position)) {
$titleAlignment = CSSHelper::parseAlignment($options, 'title_position');
$subTitleStyle .= 'text-align: ' . $titleAlignment . ';';
}
$subtitleStyleMedia = array_map(
function ($size) use (
$subtitleSelector,
$subtitleFontSize
) {
$str = AddonHelper::mediaQuery($size);
$str .= $subtitleSelector . '{';
$str .= $subtitleFontSize->$size;
$str .= '}';
$str .= '}';
return $str;
},
$deviceList
);
$subtitleStyleMedia = implode("\r\n", $subtitleStyleMedia);
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' .sppb-section-title .sppb-title-subheading {' . $subtitleFontSize->$device . '}';
$row_styles .= '.sp-page-builder .page-content #' . $row_id . ' .sppb-section-title .sppb-title-subheading {' . $subTitleStyle . '}';
$row_styles .= !empty($subtitleStyleMedia) ? $subtitleStyleMedia : '';
}
}
//container width
if (isset($options->fullscreen) && !$options->fullscreen && isset($options->container_width) && is_object($options->container_width) && isset($options->container_width->md) && $options->container_width->md != '') {
$row_styles .= '@media (min-width: 1400px) {#' . $row_id . ' > .sppb-row-container { max-width:' . $options->container_width->md . 'px;}}';
} else if (isset($options->fullscreen) && !$options->fullscreen && isset($options->container_width) && !is_object($options->container_width)) {
$row_styles .= '@media (min-width: 1400px) {#' . $row_id . ' > .sppb-row-container { max-width:' . $options->container_width . 'px;}}';
}
if (property_exists($options, 'no_gutter') && !$options->no_gutter) {
if (!$options->no_gutter && isset($options->columns_gap) && is_object($options->columns_gap)) {
$columnsGapMargin = AddonHelper::initDeviceObject();
$columnsGapPadding = AddonHelper::initDeviceObject();
$gapUnit = $options->columns_gap->unit;
foreach ($columnsGapMargin as $key => $gaps) {
if (!empty($options->columns_gap->$key)) {
$gap = (int) $options->columns_gap->$key / 2;
$columnsGapMargin->$key .= 'margin-left: -' . $gap . $gapUnit . ';';
$columnsGapMargin->$key .= 'margin-right: -' . $gap . $gapUnit . ';';
$columnsGapPadding->$key .= 'padding-left: ' . $gap . $gapUnit . ';';
$columnsGapPadding->$key .= 'padding-right: ' . $gap . $gapUnit . ';';
}
}
$rowContainerClass = (isset($options->fullscreen) && boolval($options->fullscreen)) ? ".sppb-container-inner" : ".sppb-row-container";
$marginSelector = '#' . $row_id . ' > ' . $rowContainerClass . ' > .sppb-row ';
$paddingSelector = '#' . $row_id . ' > ' . $rowContainerClass . ' > .sppb-row > div';
$columnsGapMarginStyle = $marginSelector . '{' . $columnsGapMargin->$device . '}';
$columnsGapPaddingStyle = $paddingSelector . '{' . $columnsGapPadding->$device . '}';
$columnsGapMedia = array_map(
function ($size) use (
$marginSelector,
$paddingSelector,
$columnsGapMargin,
$columnsGapPadding
) {
$str = AddonHelper::mediaQuery($size);
$str .= $marginSelector . '{';
$str .= $columnsGapMargin->$size;
$str .= '}';
$str .= $paddingSelector . '{';
$str .= $columnsGapPadding->$size;
$str .= '}';
$str .= '}';
return $str;
},
$deviceList
);
$columnsGapMedia = implode("\r\n", $columnsGapMedia);
$row_styles .= $columnsGapMarginStyle;
$row_styles .= $columnsGapPaddingStyle;
$row_styles .= $columnsGapMedia;
// nested row
$marginSelectorNested = '#' . $row_id . ' > .sppb-container-inner > .sppb-nested-row';
$paddingSelectorNested = '#' . $row_id . ' > .sppb-container-inner > .sppb-nested-row > div';
$columnsGapMarginStyleNested = $marginSelectorNested . '{' . $columnsGapMargin->$device . '}';
$columnsGapPaddingStyleNested = $paddingSelectorNested . '{' . $columnsGapPadding->$device . '}';
$columnsGapMediaNested = array_map(
function ($size) use (
$marginSelectorNested,
$paddingSelectorNested,
$columnsGapMargin,
$columnsGapPadding
) {
$str = AddonHelper::mediaQuery($size);
$str .= $marginSelectorNested . '{';
$str .= $columnsGapMargin->$size;
$str .= '}';
$str .= $paddingSelectorNested . '{';
$str .= $columnsGapPadding->$size;
$str .= '}';
$str .= '}';
return $str;
},
$deviceList
);
$columnsGapMediaNested = implode("\r\n", $columnsGapMediaNested);
$row_styles .= $columnsGapMarginStyleNested;
$row_styles .= $columnsGapPaddingStyleNested;
$row_styles .= $columnsGapMediaNested;
}
}
echo $row_styles;