HOME


Mini Shell 1.0
DIR: /home/dhnidqcz/africaprag.org/wp-content/themes/yuki/inc/customizer/
Upload File :
Current File : /home/dhnidqcz/africaprag.org/wp-content/themes/yuki/inc/customizer/class-content-section.php
<?php

/**
 * Content customizer section
 *
 * @package Yuki
 */
use LottaFramework\Customizer\Controls\Border;
use LottaFramework\Customizer\Controls\ColorPicker;
use LottaFramework\Customizer\Controls\Placeholder;
use LottaFramework\Customizer\Controls\Radio;
use LottaFramework\Customizer\Controls\Section;
use LottaFramework\Customizer\Controls\Select;
use LottaFramework\Customizer\Controls\Separator;
use LottaFramework\Customizer\Controls\Spacing;
use LottaFramework\Customizer\Controls\Typography;
use LottaFramework\Customizer\Section as CustomizerSection;
use LottaFramework\Facades\AsyncCss;
if ( !defined( 'ABSPATH' ) ) {
    exit;
    // Exit if accessed directly.
}
if ( !class_exists( 'Yuki_Content_Section' ) ) {
    class Yuki_Content_Section extends CustomizerSection {
        use Yuki_Button_Controls;
        /**
         * {@inheritDoc}
         */
        public function getControls() {
            return [
                ( new Section('yuki_content_colors') )->setLabel( __( 'Colors', 'yuki' ) )->setControls( $this->getColorsControls() ),
                ( new Section('yuki_content_typography') )->setLabel( __( 'Typography', 'yuki' ) )->setControls( array_merge( [( new Typography('yuki_site_global_typography') )->setLabel( __( 'Global Typography', 'yuki' ) )->setDescription( __( 'This option will affects the entire site', 'yuki' ) )->asyncCss( [':root', '.yuki-body'], AsyncCss::typography() )->setDefaultValue( [
                    'family'     => 'sans',
                    'fontSize'   => '16px',
                    'variant'    => '400',
                    'lineHeight' => '1.5',
                ] ), new Separator()], $this->getTypographyControls() ) ),
                ( new Section('yuki_content_links') )->setLabel( __( 'Links', 'yuki' ) )->setControls( $this->getLinksControls() ),
                ( new Section('yuki_content_buttons') )->setLabel( __( 'Buttons', 'yuki' ) )->setControls( $this->getButtonStyleControls( 'yuki_content_buttons_', [
                    'selective-refresh' => true,
                    'button-selector'   => [
                        '.yuki-article-content .wp-block-button',
                        '.yuki-article-content button',
                        '.yuki-article-content [type="submit"]',
                        '.yuki-comments-area [type="submit"]'
                    ],
                ] ) ),
                ( new Section('yuki_content_comments') )->setLabel( __( 'Comments Area', 'yuki' ) )->setControls( $this->getCommentsControls() ),
                ( new Section('yuki_content_forms') )->setLabel( __( 'Forms', 'yuki' ) )->setControls( $this->getFormControls() )
            ];
        }

        /**
         * @return array
         */
        protected function getTypographyControls() {
            $fonts = [
                'base_typography'     => [
                    'label'   => __( 'Content Typography', 'yuki' ),
                    'default' => [
                        'family'     => 'inherit',
                        'fontSize'   => '1rem',
                        'variant'    => '400',
                        'lineHeight' => '1.75',
                    ],
                ],
                'drop_cap_typography' => [
                    'label'   => __( 'Drop Cap', 'yuki' ),
                    'default' => [
                        'family'        => 'serif',
                        'fontSize'      => '5rem',
                        'variant'       => '700',
                        'lineHeight'    => '1',
                        'textTransform' => 'uppercase',
                    ],
                ],
            ];
            $controls = [];
            foreach ( $fonts as $item => $font ) {
                $controls[] = ( new Typography('yuki_content_' . $item) )->setLabel( $font['label'] )->bindSelectiveRefresh( 'yuki-global-selective-css' )->setDefaultValue( $font['default'] );
            }
            if ( yuki_fs()->is_not_paying() ) {
                $controls[] = yuki_upsell_info_control( __( 'More typography options in %sPro Version%s', 'yuki' ) )->showBackground();
            }
            return $controls;
        }

        /**
         * @return array
         */
        protected function getLinksControls() {
            return [( new ColorPicker('yuki_content_link_color') )->setLabel( __( 'Colors', 'yuki' ) )->bindSelectiveRefresh( 'yuki-global-selective-css' )->addColor( 'initial', __( 'Initial', 'yuki' ), 'var(--yuki-primary-color)' )->addColor( 'hover', __( 'Hover', 'yuki' ), 'var(--yuki-primary-active)' ), ( new Select('yuki_content_link_style') )->setLabel( __( 'Link Style', 'yuki' ) )->bindSelectiveRefresh( 'yuki-global-selective-css' )->displayInline()->setDefaultValue( 'underline' )->setChoices( [
                'underline'       => __( 'Underline', 'yuki' ),
                'plain'           => __( 'Plain', 'yuki' ),
                'hover-underline' => __( 'Hover Underline', 'yuki' ),
            ] )];
        }

        /**
         * @return array
         */
        protected function getColorsControls() {
            $colors = [
                'base_color'     => [
                    'label'  => __( 'Base Color', 'yuki' ),
                    'colors' => [
                        'initial' => 'var(--yuki-accent-color)',
                    ],
                ],
                'headings_color' => [
                    'label'  => __( 'All Headings Color (H1 - H6)', 'yuki' ),
                    'colors' => [
                        'initial' => 'var(--yuki-accent-active)',
                    ],
                ],
                'link_color'     => [
                    'label'  => __( 'Links Color', 'yuki' ),
                    'colors' => [
                        'initial' => 'var(--yuki-primary-color)',
                        'hover'   => 'var(--yuki-primary-active)',
                    ],
                ],
            ];
            $controls = [];
            foreach ( $colors as $item => $color ) {
                $picker = new ColorPicker('yuki_content_' . $item);
                $picker->bindSelectiveRefresh( 'yuki-global-selective-css' );
                $picker->setLabel( $color['label'] );
                foreach ( $color['colors'] as $id => $value ) {
                    $picker->addColor( $id, ucfirst( $id ), $value );
                }
                $controls[] = $picker;
            }
            if ( yuki_fs()->is_not_paying() ) {
                $controls[] = yuki_upsell_info_control( __( 'More color options in %sPro Version%s', 'yuki' ) )->showBackground();
            }
            return $controls;
        }

        /**
         * @return array
         */
        protected function getCommentsControls() {
            $controls = [];
            $controls = [( new Placeholder('yuki_content_comments_typography') )->setDefaultValue( [
                'family'     => 'inherit',
                'fontSize'   => '0.85rem',
                'variant'    => '400',
                'lineHeight' => '1.5em',
            ] ), ( new Placeholder('yuki_content_comments_text_color') )->addColor( 'initial', 'var(--yuki-accent-active)' )->addColor( 'hover', 'var(--yuki-primary-color)' ), ( new Placeholder('yuki_content_comments_form_color') )->addColor( 'background', 'var(--yuki-base-color)' )->addColor( 'border', 'var(--yuki-base-200)' )->addColor( 'active', 'var(--yuki-primary-color)' )];
            $controls = array_merge( $controls, [
                ( new Border('yuki_content_comments_border_top') )->setLabel( __( 'Top Border', 'yuki' ) )->enableResponsive()->bindSelectiveRefresh( 'yuki-global-selective-css' )->displayBlock()->setDefaultBorder( 1, 'none', 'var(--yuki-base-200)' ),
                new Separator(),
                ( new Border('yuki_content_comments_border_bottom') )->setLabel( __( 'Bottom Border', 'yuki' ) )->enableResponsive()->bindSelectiveRefresh( 'yuki-global-selective-css' )->displayBlock()->setDefaultBorder( 1, 'none', 'var(--yuki-base-200)' ),
                new Separator(),
                ( new Spacing('yuki_content_comments_padding') )->setLabel( __( 'Padding', 'yuki' ) )->enableResponsive()->bindSelectiveRefresh( 'yuki-global-selective-css' )->setDisabled( ['left', 'right'] )->setSpacing( [
                    'linked' => true,
                ] ),
                ( new Spacing('yuki_content_comments_margin') )->setLabel( __( 'Margin', 'yuki' ) )->enableResponsive()->bindSelectiveRefresh( 'yuki-global-selective-css' )->setDisabled( ['left', 'right'] )->setSpacing( [
                    'linked' => true,
                ] )
            ] );
            if ( yuki_fs()->is_not_paying() ) {
                $controls[] = yuki_upsell_info_control( __( 'More options in %sPro Version%s', 'yuki' ) )->showBackground();
            }
            return $controls;
        }

        /**
         * @return array
         */
        protected function getFormControls() {
            $selectors = '.woocommerce form, .yuki-form, .yuki-raw-html, .yuki-article-content, .yuki-widget';
            return [( new Radio('yuki_content_form_style') )->setLabel( __( 'Style', 'yuki' ) )->setDefaultValue( 'classic' )->buttonsGroupView()->setChoices( [
                'classic' => __( 'Classic', 'yuki' ),
                'modern'  => __( 'Modern', 'yuki' ),
            ] ), ( new Typography('yuki_content_form_typography') )->setLabel( __( 'Typography', 'yuki' ) )->asyncCss( $selectors, AsyncCss::typography() )->setDefaultValue( [
                'family'     => 'inherit',
                'fontSize'   => '0.85rem',
                'variant'    => '400',
                'lineHeight' => '1.5em',
            ] ), ( new ColorPicker('yuki_content_form_color') )->setLabel( __( 'Controls Color', 'yuki' ) )->enableAlpha()->asyncColors( $selectors, [
                'background' => '--yuki-form-background-color',
                'border'     => '--yuki-form-border-color',
                'active'     => '--yuki-form-active-color',
            ] )->addColor( 'background', __( 'Background', 'yuki' ), 'var(--yuki-base-color)' )->addColor( 'border', __( 'Border', 'yuki' ), 'var(--yuki-base-300)' )->addColor( 'active', __( 'Active', 'yuki' ), 'var(--yuki-primary-color)' )];
        }

    }

}