File "countdown.php"

Full Path: /www/wwwroot/shphe-en.com/wp-content/plugins/bb-plugin/modules/countdown/countdown.php
File size: 14.47 KB
MIME-type: --
Charset: utf-8

<?php

/**
 * @class FLCountdownModule
 */
class FLCountdownModule extends FLBuilderModule {

	/**
	 * @method __construct
	 */
	public function __construct()
	{
		parent::__construct(array(
			'name'          	=> __('倒计时', 'fl-builder'),
			'description'   	=> __('Render a Countdown module.', 'fl-builder'),
			'category'      	=> __('高级模块', 'fl-builder'),
			'partial_refresh'	=> true
		));
	}

	/**
	 * Builds an string with the respective ISO formatted time.
	 *
	 * @since 1.6.4
	 * @return string The current timestamp in an ISO format.
	 */
	public function get_time(){

		$year  = isset( $this->settings->year ) ? str_pad( $this->settings->year, 4, '0', STR_PAD_LEFT ) : '00';
		$month = isset( $this->settings->month ) ? str_pad( $this->settings->month, 2, '0', STR_PAD_LEFT ) : '00';
		$day   = isset( $this->settings->day ) ? str_pad( $this->settings->day, 2, '0', STR_PAD_LEFT ) : '00';

		$date = $year .'-'. $month .'-'. $day;

		$hours      = isset( $this->settings->time['hours'] ) ? str_pad( $this->settings->time['hours'], 2, '0', STR_PAD_LEFT ) : '00';
		$minutes    = isset( $this->settings->time['minutes'] ) ? str_pad( $this->settings->time['minutes'], 2, '0', STR_PAD_LEFT ) : '00';
		$day_period = isset( $this->settings->time['day_period'] ) ? $this->settings->time['day_period'] : 'AM';
		$zone       = isset( $this->settings->time_zone ) ? $this->settings->time_zone : date( 'e', current_time( 'timestamp', 1 ) );
		$time       = date( 'H:i:s', strtotime( $hours .':'. $minutes . ':00 ' . strtoupper( $day_period ) ) );

		$timestamp = $date .' '. $time;

		$timezone = new DateTimeZone( $this->settings->time_zone );
		$date = new DateTime( $timestamp, $timezone );

		return $date->format('c');

	}

	/**
	 * Renders a svg circle for the current number.
	 *
	 * @since 1.6.4
	 * @return void
	 */
	public function render_circle(){

		$width = !empty( $this->settings->circle_width ) ? $this->settings->circle_width : 100;
		$pos = ( $width / 2 );
		$radius = $pos - 10;
		$dash = number_format( ( ( M_PI * 2 ) * $radius ), 2, '.', '');

		$html = '<div class="svg-container">';
		$html .= '<svg class="svg" viewBox="0 0 '. $width .' '. $width .'" version="1.1" preserveAspectRatio="xMinYMin meet">
			<circle class="fl-number-bg" r="'. $radius .'" cx="'. $pos .'" cy="'. $pos .'" fill="transparent" stroke-dasharray="'. $dash .'" stroke-dashoffset="0"></circle>
			<circle class="fl-number" r="'. $radius .'" cx="'. $pos .'" cy="'. $pos .'" fill="transparent" stroke-dasharray="'. $dash .'" stroke-dashoffset="'. $dash .'" transform="rotate(-90 '. $pos .' '. $pos .')"></circle>
		</svg>';
		$html .= '</div>'; 

		echo $html;
	}


}

/**
 * Register the module and its form settings.
 */
FLBuilder::register_module('FLCountdownModule', array(
	'general'       => array(
		'title'         => __('General', 'fl-builder'),
		'sections'      => array(
			'date'       => array(
				'title'         => __( 'Date', 'fl-builder' ),
				'fields'        => array(
					'day'          => array(
						'type'          => 'text',
						'label'         => __('Day', 'fl-builder'),
						'default'       => date( 'j' ),
						'maxlength'     => '2',
						'size'          => '5',
					    'preview'      => array(
					    	'type'         => 'none'
					    )
					),
					'month'         => array(
						'type'          => 'text',
						'label'         => __('Month', 'fl-builder'),
						'default'       => date( 'n' ),
						'maxlength'     => '2',
						'size'          => '5',
					    'preview'      => array(
					    	'type'         => 'none'
					    )
					),
					'year'          => array(
						'type'          => 'text',
						'label'         => __('Year', 'fl-builder'),
						'default'       => date( 'Y' ),
						'maxlength'     => '4',
						'size'          => '5',
					    'preview'      => array(
					    	'type'         => 'none'
					    )
					),
				)
			),
			'time'       => array(
				'title'         => __( 'Time', 'fl-builder' ),
				'fields'        => array(
					'time'          => array(
						'type'          => 'time',
						'label'         => __('Time', 'fl-builder'),
						'default'		=>array(
							'hours'			=> '01',
							'minutes'		=> '00',
							'day_period'	=> 'am'
						)			
					),
					'time_zone'          => array(
						'type'          => 'timezone',
						'label'         => __('Time Zone', 'fl-builder'),
						'default'		=> 'UTC',
					),
				)
			)

		)
	),
	'style'         => array( // Tab
		'title'         => __('Style', 'fl-builder'), // Tab title
		'sections'      => array( // Tab Sections
			'general'       => array(
				'title'         => '',
				'fields'        => array(
					'layout' => array(
					    'type'          => 'select',
					    'label'         => __( 'Layout', 'fl-builder' ),
					    'default'       => 'default',
					    'options'       => array(
					    	'default'		=> __( 'Numbers', 'fl-builder' ),
					    	'circle'		=> __( 'Numbers + Circles', 'fl-builder' ),
					    ),
					    'toggle'		=> array(
					    	'circle'		=> array(
					    		'sections'		=> array( 'circle_bar_style' ),
					    		'fields'		=> array( 'after_number_text' ),
					    	),
					    	'default'		=> array(
					    		'sections'		=> array( 'numbers_style', 'separator_style' ),
					    		'fields'		=> array( 'horizontal_padding', 'vertical_padding' ),
					    	),
					    ),
					),
				)
			),
			'text_style'    => array(
				'title'         => __('Numbers and Text', 'fl-builder'),
				'fields'        => array(
					'number_color'    => array(
						'type'          => 'color',
						'label'         => __('Number Color', 'fl-builder'),
						'show_reset'    => true,
					    'preview'      => array(
					        'type'         => 'css',
					        'selector'     => '.fl-countdown .fl-countdown-unit-number',
					        'property'     => 'color'
					    )
					),
					'label_color' => array(
						'type'          => 'color',
						'label'         => __('Text Color', 'fl-builder'),
						'show_reset'    => true,
					    'preview'      => array(
					        'type'         => 'css',
					        'selector'     => '.fl-countdown .fl-countdown-unit-label',
					        'property'     => 'color'
					    )
					),
					'number_size' => array(
						'type'          => 'text',
						'label'         => __('Number Size', 'fl-builder'),
						'default'       => '24',
						'maxlength'     => '3',
						'size'          => '4',
						'description'   => 'px',
					    'preview'      => array(
					        'type'         => 'css',
					        'selector'     => '.fl-countdown .fl-countdown-unit-number',
					        'property'     => 'font-size',
					        'unit'		   => 'px'
					    )
					),
					'label_size' => array(
						'type'          => 'text',
						'label'         => __('Text Size', 'fl-builder'),
						'default'       => '13',
						'maxlength'     => '3',
						'size'          => '4',
						'description'   => 'px',
					    'preview'      => array(
					        'type'         => 'css',
					        'selector'     => '.fl-countdown .fl-countdown-unit-label',
					        'property'     => 'font-size',
					        'unit'		   => 'px'
					    )
					),
					'horizontal_padding' => array(
						'type'          => 'text',
						'label'         => __('Horizontal Padding', 'fl-builder'),
						'default'       => '10',
						'maxlength'     => '3',
						'size'          => '4',
						'description'   => 'px',
					    'preview'      => array(
					        'type'         => 'css',
					        'rules'		   => array(
					        	array(
							        'selector'     => '.fl-countdown .fl-countdown-unit',
							        'property'     => 'padding-left',
							        'unit'		   => 'px',
					        	),
					        	array(
							        'selector'     => '.fl-countdown .fl-countdown-unit',
							        'property'     => 'padding-right',
							        'unit'		   => 'px',
					        	),
					        )
					    )
					),
					'vertical_padding' => array(
						'type'          => 'text',
						'label'         => __('Vertical Padding', 'fl-builder'),
						'default'       => '10',
						'maxlength'     => '3',
						'size'          => '4',
						'description'   => 'px',					    
					    'preview'      => array(
					        'type'         => 'css',
					        'rules'		   => array(
					        	array(
							        'selector'     => '.fl-countdown .fl-countdown-unit',
							        'property'     => 'padding-top',
							        'unit'		   => 'px',
					        	),
					        	array(
							        'selector'     => '.fl-countdown .fl-countdown-unit',
							        'property'     => 'padding-bottom',
							        'unit'		   => 'px',
					        	),
					        )
					    )
					),
					'number_spacing' => array(
						'type'          => 'text',
						'label'         => __('Number Spacing', 'fl-builder'),
						'default'       => '10',
						'maxlength'     => '3',
						'size'          => '4',
						'description'   => 'px',
					    'preview'      => array(
					        'type'         => 'css',
					        'rules'		   => array(
					        	array(
							        'selector'     => '.fl-countdown .fl-countdown-number',
							        'property'     => 'margin-left',
							        'unit'		   => 'px',
					        	),
					        	array(
							        'selector'     => '.fl-countdown .fl-countdown-number',
							        'property'     => 'margin-right',
							        'unit'		   => 'px',
					        	),
					        )
					    )
					),
				)
			),
			'numbers_style'    => array(
				'title'         => __('Backgrounds', 'fl-builder'),
				'fields'        => array(
					'number_bg_color'   => array(
						'type'          => 'color',
						'label'         => __( 'Number Background Color', 'fl-builder' ),
						'show_reset'    => true,
					    'preview'      => array(
					        'type'         => 'css',
					        'selector'     => '.fl-countdown .fl-countdown-unit',
					        'property'     => 'background-color'
					    )
					),
					'number_bg_opacity' => array(
						'type'          => 'text',
						'label'         => __('Number Background Opacity', 'fl-builder'),
						'default'       => '100',
						'maxlength'     => '3',
						'size'          => '4',
						'description'   => '%'
					),
					'border_radius' => array(
						'type'          => 'text',
						'label'         => __('Number Border Radius', 'fl-builder'),
						'default'       => '0',
						'maxlength'     => '3',
						'size'          => '4',
						'description'   => 'px',
					    'preview'      => array(
					        'type'         => 'css',
					        'selector'     => '.fl-countdown .fl-countdown-unit',
					        'property'     => 'border-radius',
					        'unit'		   => 'px'
					    )
					),
				),
			),
			'separator_style'    => array(
				'title'         => __('Separator', 'fl-builder'),
				'fields'        => array(
					'show_separator' => array(
					    'type'          => 'select',
					    'label'         => __( 'Show Time Separators', 'fl-builder' ),
					    'default'       => 'no',
					    'options'       => array(
					    	'no'			=> __( 'No', 'fl-builder' ),
					    	'yes'			=> __( 'Yes', 'fl-builder' ),
					    ),
					    'toggle'		=> array(
					    	'yes'			=> array(
					    		'fields'		=> array( 'separator_type', 'separator_color' ),
					    	)
					    ),
					),
					'separator_type' => array(
					    'type'          => 'select',
					    'label'         => __( 'Separator Type', 'fl-builder' ),
					    'default'       => 'line',
					    'options'       => array(
					    	'colon'			=> __( 'Colon', 'fl-builder' ),
					    	'line'			=> __( 'Line', 'fl-builder' ),
					    ),
					    'toggle'		=> array(
					    	'colon'			=> array(
					    		'fields'		=> array( 'separator_size' ),
					    	)
					    ),
					),
					'separator_color'   => array(
						'type'          => 'color',
						'label'         => __('Separator Color', 'fl-builder'),
						'show_reset'    => true
					),
					'separator_size' => array(
						'type'          => 'text',
						'label'         => __('Separator Size', 'fl-builder'),
						'default'       => '15',
						'maxlength'     => '3',
						'size'          => '4',
						'description'   => 'px'
					),
				)
			),
			'circle_bar_style'    => array(
				'title'         => __('Circle Styles', 'fl-builder'),
				'fields'        => array(
					'circle_width' => array(
						'type'          => 'text',
						'label'         => __('Circle Size', 'fl-builder'),
						'default'       => '200',
						'maxlength'     => '4',
						'size'          => '4',
						'description'   => 'px',
					    'preview'      => array(
					        'type'         => 'css',
					        'rules'		   => array(
					        	array(
							        'selector'     => '.fl-countdown-number',
							        'property'     => 'max-width',
					        		'unit'		   => 'px'
					        	),
					        	array(
							        'selector'     => '.fl-countdown-number',
							        'property'     => 'max-height',
					        		'unit'		   => 'px'
					        	),
					        	array(
							        'selector'     => '.fl-countdown-circle-container',
							        'property'     => 'max-width',
					        		'unit'		   => 'px'
					        	),
					        	array(
							        'selector'     => '.fl-countdown-circle-container',
							        'property'     => 'max-height',
					        		'unit'		   => 'px'
					        	),
					        )
					    )

					),
					'circle_dash_width' => array(
						'type'          => 'text',
						'label'         => __('Circle Stroke Size', 'fl-builder'),
						'default'       => '10',
						'maxlength'     => '2',
						'size'          => '4',
						'description'   => 'px',
					    'preview'      => array(
					        'type'         => 'css',
					        'selector'     => '.svg circle',
					        'property'     => 'stroke-width',
					        'unit'		   => 'px'
					    )
					),
					'circle_color' => array(
						'type'          => 'color',
						'label'         => __('Circle Foreground Color', 'fl-builder'),
						'default'		=> 'f7951e',
						'show_reset'    => true,
					    'preview'      => array(
					        'type'         => 'css',
					        'selector'     => '.fl-countdown .svg .fl-number',
					        'property'     => 'stroke'
					    )
					),
					'circle_bg_color' => array(
						'type'          => 'color',
						'label'         => __('Circle Background Color', 'fl-builder'),
						'default'		=> 'eaeaea',
						'show_reset'    => true,
					    'preview'      => array(
					        'type'         => 'css',
					        'selector'     => '.fl-countdown .svg .fl-number-bg',
					        'property'     => 'stroke'
					    )
					),
				)
			),
		)
	),

));