laipower/wp-content/plugins/easy-digital-downloads/includes/admin/reporting/class-edd-pie-graph.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 );
}
}