File "Hero.php"
Full Path: /home/pumpbmko/public_html/themes/momota/lib/kubio-themebase/src/Hero.php
File size: 5.34 KB
MIME-type: text/x-php
Charset: utf-8
<?php
namespace Kubio\Theme\Components\FrontHeader;
use ColibriWP\Theme\Components\CSSOutput;
use ColibriWP\Theme\Defaults;
use ColibriWP\Theme\Translations;
use Kubio\Theme\Components\Common\HeroStyle;
class Hero extends \ColibriWP\Theme\Components\FrontHeader\Hero {
static $settings_prefix = 'front-header.hero.';
protected static function getGeneralContentSettings( $prefix ) {
$selector = static::selectiveRefreshSelector();
return array(
"{$prefix}props.heroSection.layout" => array(
'default' => Defaults::get( "{$prefix}props.heroSection.layout" ),
'control' => array(
'label' => Translations::get( 'hero_layout' ),
'focus_alias' => 'hero_layout',
'type' => 'select-icon',
'section' => 'hero',
'colibri_tab' => 'content',
'choices' => array(
'textOnly' =>
array(
'tooltip' => Translations::get( 'text_only' ),
'label' => Translations::get( 'text_only' ),
'value' => 'textOnly',
'icon' => Defaults::get( 'icons.textOnly.content' ),
),
'textWithMediaOnRight' =>
array(
'tooltip' => Translations::get( 'text_with_media_on_right' ),
'label' => Translations::get( 'text_with_media_on_right' ),
'value' => 'textWithMediaOnRight',
'icon' => Defaults::get( 'icons.textWithMediaOnRight.content' ),
),
'textWithMediaOnLeft' =>
array(
'tooltip' => Translations::get( 'text_with_media_on_left' ),
'label' => Translations::get( 'text_with_media_on_left' ),
'value' => 'textWithMediaOnLeft',
'icon' => Defaults::get( 'icons.textWithMediaOnLeft.content' ),
),
),
),
'css_output' => array(
array(
'selector' => "{$selector} .wp-block-kubio-column__container",
'media' => CSSOutput::desktopMedia(),
'property' => 'width',
'value' => array(
'textOnly' => '80%',
'textWithMediaOnRight' => '50%',
'textWithMediaOnLeft' => '50%',
),
),
array(
'selector' => "{$selector} .wp-block-kubio-column__container:nth-child(1)",
'media' => CSSOutput::desktopMedia(),
'property' => 'order',
'value' => array(
'textOnly' => '0',
'textWithMediaOnRight' => '0',
'textWithMediaOnLeft' => '1',
),
),
array(
'selector' => "{$selector} .wp-block-kubio-column__container:nth-child(2)",
'property' => 'display',
'value' => array(
'textOnly' => 'none',
'textWithMediaOnRight' => 'flex',
'textWithMediaOnLeft' => 'flex',
),
),
),
),
"{$prefix}separator1" => array(
'default' => '',
'control' => array(
'label' => '',
'type' => 'separator',
'section' => 'hero',
'colibri_tab' => 'content',
),
),
"{$prefix}hero_column_width" => array(
'default' => Defaults::get( "{$prefix}hero_column_width" ),
'control' => array(
'label' => Translations::get( 'hero_column_width' ),
'type' => 'slider',
'section' => 'hero',
'colibri_tab' => 'content',
'min' => 0,
'max' => 100,
),
'css_output' => array(
array(
'selector' => "{$selector} .wp-block-kubio-row__inner .wp-block-kubio-column__container:first-child",
'property' => 'width',
'media' => CSSOutput::desktopMedia(),
'value_pattern' => '%s%% !important',
),
array(
'selector' => "{$selector} .wp-block-kubio-row__inner .wp-block-kubio-column__container:nth-child(2)",
'property' => 'width',
'media' => CSSOutput::desktopMedia(),
'value_pattern' => 'calc(100%% - %s%%) !important',
),
),
),
"{$prefix}separator2" => array(
'default' => '',
'control' => array(
'label' => '',
'type' => 'separator',
'section' => 'hero',
'colibri_tab' => 'content',
),
),
);
}
public static function getStyleComponent() {
return HeroStyle::getInstance(
static::$settings_prefix,
static::selectiveRefreshSelector()
);
}
public function printSeparator() {
$prefix = static::$settings_prefix;
$style_prefix = ( static::getStyleComponent() )::STYLE_PREFIX;
$divider_prefix = "{$prefix}{$style_prefix}.separators.separatorBottom.";
$enabled = $this->mod( "{$divider_prefix}enabled", false );
$negative = $this->mod( "{$divider_prefix}negative", false );
if ( $enabled ) {
$style = $this->mod( "{$divider_prefix}type", 'mountains' );
$divider_style = Defaults::get( 'divider_style' );
if ( $negative && ! isset( $divider_style[ $style . '-negative' ] ) ) {
$negative = false;
}
if ( $negative ) {
$style .= '-negative';
}
$svg = '';
if ( isset( $divider_style[ $style ] ) ) {
$svg = $divider_style[ $style ];
}
// set color
$svg = str_replace( '<path', '<path class="svg-white-bg"', $svg );
if ( $negative ) {
$transform = '';
} else {
$transform = 'transform:rotateX(180deg);';
}
// flip for bottom
$svg = str_replace( '<svg ', '<svg style="' . $transform . '" ', $svg );
$separator = "<div class='h-separator' style='bottom: -1px;'>$svg</div>";
echo $separator;
}
}
}