HOME


Mini Shell 1.0
DIR: /home/dhnidqcz/africaprag.org/wp-content/themes/yuki/inc/traits/
Upload File :
Current File : /home/dhnidqcz/africaprag.org/wp-content/themes/yuki/inc/traits/trait-particles-effect.php
<?php
/**
 * Particles effect trait
 *
 * @package Yuki
 */

use LottaFramework\Customizer\Controls\ColorPicker;
use LottaFramework\Customizer\Controls\Condition;
use LottaFramework\Customizer\Controls\Number;
use LottaFramework\Customizer\Controls\Radio;
use LottaFramework\Customizer\Controls\Select;
use LottaFramework\Customizer\Controls\Toggle;
use LottaFramework\Facades\CZ;
use LottaFramework\Utils;

if ( ! defined( 'ABSPATH' ) ) {
	exit; // Exit if accessed directly.
}

if ( ! trait_exists( 'Yuki_Particles_Effect' ) ) {

	trait Yuki_Particles_Effect {

		/**
		 * Particles effect presets
		 *
		 * @var array
		 */
		protected $particles_presets = [];

		/**
		 * Register particles.js script
		 */
		public function registerParticlesScript() {
			wp_register_script(
				'particles.js',
				get_template_directory_uri() . '/dist/vendor/particles/tsparticles.bundle.min.js',
//				get_template_directory_uri() . '/dist/vendor/particles/particles.min.js',
				[],
				YUKI_VERSION
			);
		}

		protected function getParticlesCss( $prefix, $selector = '' ) {
			if ( ! Utils::str_ends_with( $prefix, '_' ) ) {
				$prefix .= '_';
			}

			if ( ! CZ::checked( $prefix . 'enable_particles' ) ) {
				return [];
			}

			$selector = $selector === '' ? ".{$prefix}particles_canvas" : $selector;

			return [
				$selector => apply_filters( 'yuki_particles_effect_css', [
					'--yuki-particles-canvas-z-index' => CZ::get( $prefix . 'particle_canvas_z_index' ),
				], $prefix )
			];
		}

		/**
		 * Render particles canvas element
		 *
		 * @param $prefix
		 * @param string $id
		 */
		protected function renderParticlesCanvas( $prefix, $id = '' ) {
			if ( ! Utils::str_ends_with( $prefix, '_' ) ) {
				$prefix .= '_';
			}
			if ( ! CZ::checked( $prefix . 'enable_particles' ) ) {
				return;
			}

			$options = apply_filters(
				'yuki_particles_effect_options',
				$this->particles_presets[ CZ::get( $prefix . 'particle_preset' ) ] ?? '',
				$prefix
			);

			if ( empty( $options ) ) {
				return;
			}

			wp_enqueue_script( 'particles.js' );

			$attrs = apply_filters( 'yuki_particles_canvas_attrs', [
				'class'                         => Utils::clsx( [
					'yuki-particles-canvas'      => true,
					$prefix . 'particles_canvas' => true,
					$id                          => $id !== '',
				] ),
				'id'                            => $id === '' ? $prefix . 'particles' : $id,
				'data-yuki-particles'           => $options,
				// override global options
				'data-yuki-particle-detect-on'  => CZ::get( $prefix . 'particle_detect_on' ),
				'data-yuki-particle-color'      => CZ::get( $prefix . 'particle_color' )['particle'],
				'data-yuki-particle-line-color' => CZ::get( $prefix . 'particle_color' )['line'] ?? '',
			], $prefix );

			echo '<div ' . Utils::render_attribute_string( $attrs ) . '></div>';
		}

		/**
		 * Particles effect related controls
		 *
		 * @param $prefix
		 * @param array $exclude
		 *
		 * @return array
		 */
		protected function getParticleEffectControls( $prefix, $exclude = [] ) {

			if ( ! Utils::str_ends_with( $prefix, '_' ) ) {
				$prefix .= '_';
			}

			$controls = [];
			if ( ! in_array( 'enable', $exclude ) ) {
				$controls[] = ( new Toggle( $prefix . 'enable_particles' ) )
					->setLabel( __( 'Enable Particles Effect', 'yuki' ) )
					->closeByDefault();
			}

			// z-index & source
			$controls[] = ( new Condition() )
				->setCondition( [ $prefix . 'enable_particles' => 'yes' ] )
				->setControls( [
					( new Number( $prefix . 'particle_canvas_z_index' ) )
						->setLabel( __( 'Z Index', 'yuki' ) )
						->asyncCss( ".{$prefix}particles_canvas", [ '--yuki-particles-canvas-z-index' => 'value' ] )
						->setMin( - 99999 )
						->setMax( 99999 )
						->setDefaultUnit( false )
						->setDefaultValue( 1 )
					,
					( new Radio( $prefix . 'particle_source' ) )
						->setLabel( __( 'Particle Source', 'yuki' ) )
						->setDefaultValue( 'preset' )
						->buttonsGroupView()
						->setChoices( [
							'preset' => __( 'Preset', 'yuki' ),
							'custom' => __( 'Custom', 'yuki' ),
						] )
					,
				] );

			// Particles preset
			$controls[] = ( new Condition() )
				->setCondition( [
					$prefix . 'enable_particles' => 'yes',
					$prefix . 'particle_source'  => 'preset',
				] )
				->setControls( [
					( new Select( $prefix . 'particle_preset' ) )
						->setLabel( __( 'Choose Particle Preset', 'yuki' ) )
						->setDefaultValue( 'default' )
						->setChoices( apply_filters( 'yuki_particles_effect_presets_options', [
							'default'        => __( 'Default', 'yuki' ),
							'gather'         => __( 'Gather', 'yuki' ),
							'parallax'       => __( 'Parallax', 'yuki' ),
							'nasa'           => __( 'NASA', 'yuki' ),
							'polygon-bubble' => __( 'Polygon Bubble', 'yuki' ),
							'circle-bubble'  => __( 'Circle Bubble', 'yuki' ),
							'snow'           => __( 'Snow', 'yuki' ),
							'fire-spark'     => __( 'Fire Spark', 'yuki' ),
							'nyancat'        => __( 'Nyan Cat', 'yuki' ),
						] ) )
					,
				] );

			// Custom particles
			$controls[] = ( new Condition() )
				->setCondition( [
					$prefix . 'enable_particles' => 'yes',
					$prefix . 'particle_source'  => 'custom',
				] )
				->setControls( apply_filters( 'yuki_particles_custom_json_controls', [
					yuki_upsell_info_control(
						__( "You can customize your particles effect using the online editor in %sPro Version%s", 'yuki' ),
						$prefix . 'particles_custom_json_upsell'
					),
				], $prefix ) );

			// Particles override
			$controls[] = ( new Condition() )
				->setCondition( [ $prefix . 'enable_particles' => 'yes' ] )
				->setControls( apply_filters( 'yuki_particles_override_controls', [
					( new Radio( $prefix . 'particle_detect_on' ) )
						->setLabel( __( 'Interactivity Detect On', 'yuki' ) )
						->setDefaultValue( 'default' )
						->buttonsGroupView()
						->setChoices( [
							'default' => __( 'Default', 'yuki' ),
							'window'  => __( 'Window', 'yuki' ),
							'canvas'  => __( 'Canvas', 'yuki' ),
						] )
					,
					( new ColorPicker( $prefix . 'particle_color' ) )
						->setLabel( __( 'Particle Color', 'yuki' ) )
						->addColor( 'particle', __( 'Particle Color', 'yuki' ), 'var(--yuki-primary-color)' )
						->addColor( 'line', __( 'Line Color', 'yuki' ), 'var(--yuki-primary-color)' )
					,
					yuki_upsell_info_control(
						__( "More particle options available in %sPro Version%s", 'yuki' ),
						$prefix . 'particles_override_options_upsell'
					),
				], $prefix ) );

			return apply_filters( 'yuki_particles_effect_controls', $controls, $prefix, $exclude );
		}

	}

}