200 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			200 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Graphs
 | |
|  *
 | |
|  * This class handles building pretty report graphs
 | |
|  *
 | |
|  * @package     EDD
 | |
|  * @subpackage  Admin/Reports
 | |
|  * @copyright   Copyright (c) 2018, Easy Digital Downloads, LLC
 | |
|  * @license     http://opensource.org/licenses/gpl-2.0.php GNU Public License
 | |
|  * @since 2.4
 | |
|  */
 | |
| 
 | |
| // Exit if accessed directly
 | |
| defined( 'ABSPATH' ) || exit;
 | |
| 
 | |
| /**
 | |
|  * EDD_Graph Class
 | |
|  *
 | |
|  * @since 2.4
 | |
|  */
 | |
| class EDD_Pie_Graph extends EDD_Graph {
 | |
| 
 | |
| 	/*
 | |
| 
 | |
| 	Simple example:
 | |
| 
 | |
| 	data format for each point: array( location on x, location on y )
 | |
| 
 | |
| 	$data = array(
 | |
| 		array( 'Label'   => 'value' ),
 | |
| 		array( 'Label 2' => 'value 2' ),
 | |
| 	);
 | |
| 
 | |
| 	$graph = new EDD_Pie_Graph( $data );
 | |
| 	$graph->display();
 | |
| 
 | |
| 	*/
 | |
| 
 | |
| 	/**
 | |
| 	 * Data to graph
 | |
| 	 *
 | |
| 	 * @var array
 | |
| 	 * @since 2.4
 | |
| 	 */
 | |
| 	private $data;
 | |
| 
 | |
| 	/**
 | |
| 	 * Unique ID for the graph
 | |
| 	 *
 | |
| 	 * @var string
 | |
| 	 * @since 2.4
 | |
| 	 */
 | |
| 	private $id = '';
 | |
| 
 | |
| 	/**
 | |
| 	 * Graph options
 | |
| 	 *
 | |
| 	 * @var array
 | |
| 	 * @since 2.4
 | |
| 	 */
 | |
| 	private $options = array();
 | |
| 
 | |
| 	/**
 | |
| 	 * Get things started
 | |
| 	 *
 | |
| 	 * @since 2.4
 | |
| 	 */
 | |
| 	public function __construct( $_data, $options = array() ) {
 | |
| 
 | |
| 		$this->data = $_data;
 | |
| 
 | |
| 		// Set this so filters recieving $this can quickly know if it's a graph they want to modify
 | |
| 		$this->type = 'pie';
 | |
| 
 | |
| 		// Generate unique ID, add 'a' since md5 can leave a numerical first character
 | |
| 		$this->id = 'a' . md5( rand() );
 | |
| 
 | |
| 		// Setup default options;
 | |
| 		$this->options = wp_parse_args( $options,  array(
 | |
| 			'radius'            => 1,
 | |
| 			'legend'            => true,
 | |
| 			'legend_formatter'  => false,
 | |
| 			'legend_columns'    => 3,
 | |
| 			'legend_position'   => 's',
 | |
| 			'show_labels'       => false,
 | |
| 			'label_threshold'   => 0.01,
 | |
| 			'label_formatter'   => 'eddLabelFormatter',
 | |
| 			'label_bg_opacity'  => 0.75,
 | |
| 			'label_radius'      => 1,
 | |
| 			'height'            => '300',
 | |
| 			'hoverable'         => true,
 | |
| 			'clickable'         => false,
 | |
| 			'threshold'         => false,
 | |
| 		) );
 | |
| 
 | |
| 		add_action( 'edd_graph_load_scripts', array( $this, 'load_additional_scripts' ) );
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Load the graphing library script
 | |
| 	 *
 | |
| 	 * @since 2.4
 | |
| 	 */
 | |
| 	public function load_additional_scripts() {
 | |
| 		wp_enqueue_script( 'edd-jquery-flot-pie', EDD_PLUGIN_URL . 'assets/js/vendor/jquery.flot.pie.min.js' );
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Build the graph and return it as a string
 | |
| 	 *
 | |
| 	 * @var array
 | |
| 	 * @since 2.4
 | |
| 	 * @return string
 | |
| 	 */
 | |
| 	public function build_graph() {
 | |
| 
 | |
| 		if ( count( $this->data ) ) {
 | |
| 			$this->load_scripts();
 | |
| 
 | |
| 			ob_start();
 | |
| 			?>
 | |
| 			<script type="text/javascript">
 | |
| 				var <?php echo $this->id; ?>_data = [
 | |
| 				<?php foreach ( $this->data as $label => $value ) : ?>
 | |
| 					<?php echo '{ label: "' . esc_attr( $label ) . '", data: "' . $value . '" },' . "\n"; ?>
 | |
| 				<?php endforeach; ?>
 | |
| 				];
 | |
| 
 | |
| 				var <?php echo $this->id; ?>_options = {
 | |
| 					series: {
 | |
| 						pie: {
 | |
| 							show: true,
 | |
| 							radius: <?php echo $this->options['radius']; ?>,
 | |
| 							label: [],
 | |
| 						},
 | |
| 						edd_vars: {
 | |
| 							id: '<?php echo $this->id; ?>',
 | |
| 						}
 | |
| 					},
 | |
| 					legend: {
 | |
| 						show: <?php echo $this->options['legend']; ?>,
 | |
| 					},
 | |
| 					grid: {},
 | |
| 				};
 | |
| 
 | |
| 				<?php if ( true === $this->options['show_labels'] ) : ?>
 | |
| 					<?php echo $this->id; ?>_options.series.pie.label.show = true;
 | |
| 					<?php echo $this->id; ?>_options.series.pie.label.formatter = <?php echo $this->options['label_formatter']; ?>;
 | |
| 					<?php echo $this->id; ?>_options.series.pie.label.threshold = <?php echo $this->options['label_threshold']; ?>;
 | |
| 					<?php echo $this->id; ?>_options.series.pie.label.radius = <?php echo $this->options['label_radius']; ?>;
 | |
| 					<?php echo $this->id; ?>_options.series.pie.label.background = { opacity: <?php echo $this->options['label_bg_opacity']; ?> };
 | |
| 				<?php endif; ?>
 | |
| 
 | |
| 				<?php if ( true === $this->options['legend'] && ! empty( $this->options['legend_formatter'] ) ) : ?>
 | |
| 					<?php echo $this->id; ?>_options.legend.labelFormatter = <?php echo $this->options['legend_formatter']; ?>;
 | |
| 					<?php echo $this->id; ?>_options.legend.noColumns = <?php echo $this->options['legend_columns']; ?>;
 | |
| 					<?php echo $this->id; ?>_options.legend.position = "<?php echo $this->options['legend_position']; ?>";
 | |
| 				<?php endif; ?>
 | |
| 
 | |
| 				<?php if ( true === $this->options['hoverable'] ) : ?>
 | |
| 					<?php echo $this->id; ?>_options.grid.hoverable = true;
 | |
| 				<?php endif; ?>
 | |
| 
 | |
| 				<?php if ( true === $this->options['clickable'] ) : ?>
 | |
| 					<?php echo $this->id; ?>_options.grid.clickable = true;
 | |
| 				<?php endif; ?>
 | |
| 
 | |
| 				jQuery( document ).ready( function($) {
 | |
| 					var <?php echo $this->id; ?>Chart = $('#edd-pie-graph-<?php echo $this->id; ?>');
 | |
| 					$.plot( <?php echo $this->id; ?>Chart, <?php echo $this->id; ?>_data, <?php echo $this->id; ?>_options );
 | |
| 					<?php if ( ! wp_is_mobile() ) : ?>
 | |
| 					$(<?php echo $this->id; ?>Chart).on('plothover', function (event, pos, item) {
 | |
| 						$('.edd-legend-item-wrapper').css('background-color', 'inherit');
 | |
| 						if ( item ) {
 | |
| 							var label = item.series.label;
 | |
| 							var id    = item.series.edd_vars.id;
 | |
| 
 | |
| 							var slug = label.toLowerCase().replace(/\s/g, '-');
 | |
| 							var legendTarget = '#' + id + slug;
 | |
| 
 | |
| 							$('.edd-legend-item-wrapper' + legendTarget).css('background-color', '#f0f0f0');
 | |
| 						}
 | |
| 					});
 | |
| 					<?php endif; ?>
 | |
| 				});
 | |
| 
 | |
| 			</script>
 | |
| 			<div class="edd-pie-graph-wrap">
 | |
| 				<div id="edd-pie-graph-<?php echo $this->id; ?>" class="edd-pie-graph" style="height: <?php echo $this->options['height']; ?>px;"></div>
 | |
| 				<div id="edd-pie-legend-<?php echo $this->id; ?>" class="edd-pie-legend"></div>
 | |
| 			</div>
 | |
| 			<?php
 | |
| 		}
 | |
| 		return apply_filters( 'edd_pie_graph_output', ob_get_clean(), $this->id, $this->data, $this->options );
 | |
| 
 | |
| 	}
 | |
| 
 | |
| }
 |