diff options
author | Theo Chatzimichos <tampakrap@gentoo.org> | 2012-06-13 16:18:13 +0200 |
---|---|---|
committer | Theo Chatzimichos <tampakrap@gentoo.org> | 2012-06-13 16:18:13 +0200 |
commit | ab05ecf6ac2bdd10e542eff7764de0f02a17f0a8 (patch) | |
tree | 5134afa67836f0657151a40cfba49c9adf969a50 /plugins/jetpack/modules/sharedaddy/sharing-service.php | |
parent | Update limit-login-attempts, smart-youtube and wp-stats (diff) | |
download | blogs-gentoo-ab05ecf6ac2bdd10e542eff7764de0f02a17f0a8.tar.gz blogs-gentoo-ab05ecf6ac2bdd10e542eff7764de0f02a17f0a8.tar.bz2 blogs-gentoo-ab05ecf6ac2bdd10e542eff7764de0f02a17f0a8.zip |
New module jetpack, replacement of wp-stats
Update akismet, limit-login-attempts, smart-youtube, wp-importer
Diffstat (limited to 'plugins/jetpack/modules/sharedaddy/sharing-service.php')
-rw-r--r-- | plugins/jetpack/modules/sharedaddy/sharing-service.php | 529 |
1 files changed, 529 insertions, 0 deletions
diff --git a/plugins/jetpack/modules/sharedaddy/sharing-service.php b/plugins/jetpack/modules/sharedaddy/sharing-service.php new file mode 100644 index 00000000..073044d4 --- /dev/null +++ b/plugins/jetpack/modules/sharedaddy/sharing-service.php @@ -0,0 +1,529 @@ +<?php + +include_once dirname( __FILE__ ).'/sharing-sources.php'; + +define( 'WP_SHARING_PLUGIN_VERSION', '0.3' ); + +class Sharing_Service { + private $global = false; + + /** + * Gets a generic list of all services, without any config + */ + public function get_all_services_blog() { + $options = get_option( 'sharing-options' ); + + $all = $this->get_all_services(); + $services = array(); + + foreach ( $all AS $id => $name ) { + if ( isset( $all[$id] ) ) { + $config = array(); + + // Pre-load custom modules otherwise they won't know who they are + if ( substr( $id, 0, 7 ) == 'custom-' && is_array( $options[$id] ) ) + $config = $options[$id]; + + $services[$id] = new $all[$id]( $id, $config ); + } + } + + return $services; + } + + /** + * Gets a list of all available service names and classes + */ + private function get_all_services() { + // Default services + $services = array( + 'email' => 'Share_Email', + 'print' => 'Share_Print', + 'digg' => 'Share_Digg', + 'facebook' => 'Share_Facebook', + 'linkedin' => 'Share_LinkedIn', + 'reddit' => 'Share_Reddit', + 'stumbleupon' => 'Share_Stumbleupon', + 'twitter' => 'Share_Twitter', + 'press-this' => 'Share_PressThis', + 'google-plus-1' => 'Share_GooglePlus1' + ); + + // Add any custom services in + $options = $this->get_global_options(); + foreach ( (array)$options['custom'] AS $custom_id ) { + $services[$custom_id] = 'Share_Custom'; + } + + return apply_filters( 'sharing_services', $services ); + } + + public function new_service( $label, $url, $icon ) { + // Validate + $label = trim( wp_html_excerpt( wp_kses( $label, array() ), 30 ) ); + $url = trim( esc_url_raw( $url ) ); + $icon = trim( esc_url_raw( $icon ) ); + + if ( $label && $url && $icon ) { + $options = get_option( 'sharing-options' ); + if ( !is_array( $options ) ) + $options = array(); + + $service_id = 'custom-'.time(); + + // Add a new custom service + $options['global']['custom'][] = $service_id; + + update_option( 'sharing-options', $options ); + + // Create a custom service and set the options for it + $service = new Share_Custom( $service_id, array( 'name' => $label, 'url' => $url, 'icon' => $icon ) ); + $this->set_service( $service_id, $service ); + + // Return the service + return $service; + } + + return false; + } + + public function delete_service( $service_id ) { + $service = $this->get_service( $service_id ); + + if ( $service ) { + $options = get_option( 'sharing-options' ); + if ( isset( $options[$service_id] ) ) + unset( $options[$service_id] ); + + $key = array_search( $service_id, $options['global']['custom'] ); + if ( $key !== false ) + unset( $options['global']['custom'][$key] ); + + update_option( 'sharing-options', $options ); + return true; + } + + return false; + } + + public function set_blog_services( array $visible, array $hidden ) { + $services = $this->get_all_services(); + // Validate the services + $available = array_keys( $services ); + + // Only allow services that we have defined + $hidden = array_intersect( $hidden, $available ); + $visible = array_intersect( $visible, $available ); + + // Ensure we don't have the same ones in hidden and visible + $hidden = array_diff( $hidden, $visible ); + + do_action( 'sharing_get_services_state', array( + 'services' => $services, + 'available' => $available, + 'hidden' => $hidden, + 'visible' => $visible, + 'currently_enabled' => $this->get_blog_services() + ) ); + + update_option( 'sharing-services', array( 'visible' => $visible, 'hidden' => $hidden ) ); + } + + public function get_blog_services() { + $options = get_option( 'sharing-options' ); + $enabled = get_option( 'sharing-services' ); + $services = $this->get_all_services(); + + if ( !is_array( $options ) ) + $options = array( 'global' => $this->get_global_options() ); + + $global = $options['global']; + + // Default services + if ( !is_array( $enabled ) ) { + $enabled = array( + 'visible' => array(), + 'hidden' => array() + ); + + $enabled = apply_filters( 'sharing_default_services', $enabled ); + } + + // Cleanup after any filters that may have produced duplicate services + $enabled['visible'] = array_unique( $enabled['visible'] ); + $enabled['hidden'] = array_unique( $enabled['hidden'] ); + + // Form the enabled services + $blog = array( 'visible' => array(), 'hidden' => array() ); + + foreach ( $blog AS $area => $stuff ) { + foreach ( (array)$enabled[$area] AS $service ) { + if ( isset( $services[$service] ) ) { + $blog[$area][$service] = new $services[$service]( $service, array_merge( $global, isset( $options[$service] ) ? $options[$service] : array() ) ); + } + } + } + + $blog = apply_filters( 'sharing_services_enabled', $blog ); + + // Convenience for checking if a service is present + $blog['all'] = array_flip( array_merge( array_keys( $blog['visible'] ), array_keys( $blog['hidden'] ) ) ); + return $blog; + } + + public function get_service( $service_name ) { + $services = $this->get_blog_services(); + + if ( isset( $services['visible'][$service_name] ) ) + return $services['visible'][$service_name]; + + if ( isset( $services['hidden'][$service_name] ) ) + return $services['hidden'][$service_name]; + + return false; + } + + public function set_global_options( $data ) { + $options = get_option( 'sharing-options' ); + + // No options yet + if ( ! is_array( $options ) ) + $options = array(); + + // Defaults + $options['global'] = array( + 'button_style' => 'icon-text', + 'sharing_label' => __( 'Share this:', 'jetpack' ), + 'open_links' => 'same', + 'show' => array( 'post', 'page' ), + 'custom' => isset( $options['global']['custom'] ) ? $options['global']['custom'] : array() + ); + + $options['global'] = apply_filters( 'sharing_default_global', $options['global'] ); + + // Validate options and set from our data + if ( isset( $data['button_style'] ) && in_array( $data['button_style'], array( 'icon-text', 'icon', 'text' ) ) ) + $options['global']['button_style'] = $data['button_style']; + + if ( isset( $data['sharing_label'] ) ) + $options['global']['sharing_label'] = trim( wp_kses( stripslashes( $data['sharing_label'] ), array() ) ); + + if ( isset( $data['open_links'] ) && in_array( $data['open_links'], array( 'new', 'same' ) ) ) + $options['global']['open_links'] = $data['open_links']; + + $shows = array_values( get_post_types( array( 'public' => true ) ) ); + $shows[] = 'index'; + + if ( isset( $data['show'] ) ) { + if ( is_scalar( $data['show'] ) ) { + switch ( $data['show'] ) { + case 'posts' : + $data['show'] = array( 'post', 'page' ); + break; + case 'index' : + $data['show'] = array( 'index' ); + break; + case 'posts-index' : + $data['show'] = array( 'post', 'page', 'index' ); + break; + } + } + + if ( $data['show'] = array_intersect( $data['show'], $shows ) ) { + $options['global']['show'] = $data['show']; + } + } else { + $options['global']['show'] = array(); + } + + update_option( 'sharing-options', $options ); + return $options['global']; + } + + public function get_global_options() { + if ( $this->global === false ) { + $options = get_option( 'sharing-options' ); + + if ( is_array( $options ) && isset( $options['global'] ) ) + $this->global = $options['global']; + else + $this->global = $this->set_global_options( $options['global'] ); + } + + if ( ! isset( $this->global['show'] ) ) { + $this->global['show'] = array( 'post', 'page' ); + } elseif ( is_scalar( $this->global['show'] ) ) { + switch ( $this->global['show'] ) { + case 'posts' : + $this->global['show'] = array( 'post', 'page' ); + break; + case 'index' : + $this->global['show'] = array( 'index' ); + break; + case 'posts-index' : + $this->global['show'] = array( 'post', 'page', 'index' ); + break; + } + } + return $this->global; + } + + public function set_service( $id, Sharing_Source $service ) { + // Update the options for this service + $options = get_option( 'sharing-options' ); + + // No options yet + if ( !is_array( $options ) ) + $options = array(); + + do_action( 'sharing_get_button_state', array( 'id' => $id, 'options' => $options, 'service' => $service ) ); + + $options[$id] = $service->get_options(); + + update_option( 'sharing-options', array_filter( $options ) ); + } + + // Soon to come to a .org plugin near you! + public function get_total( $service_name = false, $post_id = false ) { + global $wpdb, $blog_id; + if ( $service_name == false ) { + if ( $post_id > 0 ) { + // total number of shares for this post + return (int) $wpdb->get_var( $wpdb->prepare( "SELECT SUM( count ) FROM sharing_stats WHERE blog_id = %d AND post_id = %d", $blog_id, $post_id ) ); + } else { + // total number of shares for this blog + return (int) $wpdb->get_var( $wpdb->prepare( "SELECT SUM( count ) FROM sharing_stats WHERE blog_id = %d", $blog_id ) ); + } + } + + if ( $post_id > 0 ) + return (int) $wpdb->get_var( $wpdb->prepare( "SELECT SUM( count ) FROM sharing_stats WHERE blog_id = %d AND post_id = %d AND share_service = %s", $blog_id, $post_id, $service_name ) ); + else + return (int) $wpdb->get_var( $wpdb->prepare( "SELECT SUM( count ) FROM sharing_stats WHERE blog_id = %d AND share_service = %s", $blog_id, $service_name ) ); + } + + public function get_services_total( $post_id = false ) { + $totals = array(); + $services = $this->get_blog_services(); + + if ( !empty( $services ) && isset( $services[ 'all' ] ) ) + foreach( $services[ 'all' ] as $key => $value ) { + $totals[$key] = new Sharing_Service_Total( $key, $this->get_total( $key, $post_id ) ); + } + usort( $totals, array( 'Sharing_Service_Total', 'cmp' ) ); + + return $totals; + } + + public function get_posts_total() { + $totals = array(); + global $wpdb, $blog_id; + + $my_data = $wpdb->get_results( $wpdb->prepare( "SELECT post_id as id, SUM( count ) as total FROM sharing_stats WHERE blog_id = %d GROUP BY post_id ORDER BY count DESC ", $blog_id ) ); + + if ( !empty( $my_data ) ) + foreach( $my_data as $row ) + $totals[] = new Sharing_Post_Total( $row->id, $row->total ); + + usort( $totals, array( 'Sharing_Post_Total', 'cmp' ) ); + + return $totals; + } +} + +class Sharing_Service_Total { + var $id = ''; + var $name = ''; + var $service = ''; + var $total = 0; + + public function Sharing_Service_Total( $id, $total ) { + $services = new Sharing_Service(); + $this->id = esc_html( $id ); + $this->service = $services->get_service( $id ); + $this->total = (int) $total; + + $this->name = $this->service->get_name(); + } + + static function cmp( $a, $b ) { + if ( $a->total == $b->total ) + return $a->name < $b->name; + return $a->total < $b->total; + } +} + +class Sharing_Post_Total { + var $id = 0; + var $total = 0; + var $title = ''; + var $url = ''; + + public function Sharing_Post_Total( $id, $total ) { + $this->id = (int) $id; + $this->total = (int) $total; + $this->title = get_the_title( $this->id ); + $this->url = get_permalink( $this->id ); + } + + static function cmp( $a, $b ) { + if ( $a->total == $b->total ) + return $a->id < $b->id; + return $a->total < $b->total; + } +} + +function sharing_add_footer() { + if ( apply_filters( 'sharing_js', true ) ) + wp_print_scripts( 'sharing-js' ); + + $sharer = new Sharing_Service(); + $enabled = $sharer->get_blog_services(); + foreach ( array_merge( $enabled['visible'], $enabled['hidden'] ) AS $service ) { + $service->display_footer(); + } +} + +function sharing_add_header() { + $sharer = new Sharing_Service(); + $enabled = $sharer->get_blog_services(); + + foreach ( array_merge( $enabled['visible'], $enabled['hidden'] ) AS $service ) { + $service->display_header(); + } + + if ( count( $enabled['all'] ) > 0 ) + wp_enqueue_style( 'sharedaddy', plugin_dir_url( __FILE__ ) .'sharing.css' ); +} + +function sharing_process_requests() { + global $post; + + // Only process if: single post and share=X defined + if ( ( is_page() || is_single() ) && isset( $_GET['share'] ) ) { + $sharer = new Sharing_Service(); + + $service = $sharer->get_service( $_GET['share'] ); + if ( $service ) { + $service->process_request( $post, $_POST ); + } + } +} + +function sharing_display( $text = '' ) { + global $post, $wp_current_filter; + + if ( is_preview() ) { + return $text; + } + + if ( in_array( 'get_the_excerpt', (array) $wp_current_filter ) ) { + return $text; + } + + $sharer = new Sharing_Service(); + $global = $sharer->get_global_options(); + + $show = false; + if ( !is_feed() ) { + if ( is_singular() && in_array( get_post_type(), $global['show'] ) ) { + $show = true; + } elseif ( in_array( 'index', $global['show'] ) && ( is_home() || is_archive() || is_search() ) ) { + $show = true; + } + } + + // Pass through a filter for final say so + $show = apply_filters( 'sharing_show', $show, $post ); + + // Disabled for this post? + $switched_status = get_post_meta( $post->ID, 'sharing_disabled', false ); + + if ( !empty( $switched_status ) ) + $show = false; + + $sharing_content = ''; + + if ( $show ) { + $enabled = $sharer->get_blog_services(); + + if ( count( $enabled['all'] ) > 0 ) { + global $post; + + $dir = get_option( 'text_direction' ); + + // Wrapper + $sharing_content .= '<div class="snap_nopreview sharing robots-nocontent">'; + $sharing_content .= '<ul>'; + + // Visible items + $visible = ''; + foreach ( $enabled['visible'] AS $id => $service ) { + // Individual HTML for sharing service + $visible .= '<li class="share-'.$service->get_class().' share-regular">'; + $visible .= $service->get_display( $post ); + $visible .= '</li>'; + } + + $parts = array(); + if ( $global['sharing_label'] != '' ) + $parts[] = '<li class="sharing_label">'.$global['sharing_label'].'</li>'; + + $parts[] = $visible; + if ( count( $enabled['hidden'] ) > 0 ) + $parts[] = '<li class="share-custom"><a href="#" class="sharing-anchor">'._x( 'Share', 'dropdown button', 'jetpack' ).'</a></li>'; + + if ( $dir == 'rtl' ) + $parts = array_reverse( $parts ); + + $sharing_content .= implode( '', $parts ); + $sharing_content .= '<li class="share-end"></li></ul>'; + + if ( count( $enabled['hidden'] ) > 0 ) { + $sharing_content .= '<div class="sharing-hidden"><div class="inner" style="display: none;'; + + if ( count( $enabled['hidden'] ) == 1 ) + $sharing_content .= 'width:150px;'; + + $sharing_content .= '">'; + + if ( count( $enabled['hidden'] ) == 1 ) + $sharing_content .= '<ul style="background-image:none;">'; + else + $sharing_content .= '<ul>'; + + $count = 1; + foreach ( $enabled['hidden'] AS $id => $service ) { + // Individual HTML for sharing service + $sharing_content .= '<li class="share-'.$service->get_class().'">'; + $sharing_content .= $service->get_display( $post ); + $sharing_content .= '</li>'; + + if ( ( $count % 2 ) == 0 ) + $sharing_content .= '<li class="share-end"></li>'; + + $count ++; + } + + // End of wrapper + $sharing_content .= '<li class="share-end"></li></ul></div></div>'; + } + + $sharing_content .= '<div class="sharing-clear"></div></div>'; + + // Register our JS + wp_register_script( 'sharing-js', plugin_dir_url( __FILE__ ).'sharing.js', array( 'jquery' ), '0.1' ); + add_action( 'wp_footer', 'sharing_add_footer' ); + } + } + + return $text.$sharing_content; +} + +add_filter( 'the_content', 'sharing_display', 19 ); +add_filter( 'the_excerpt', 'sharing_display', 19 ); + +// Register our CSS +add_action( 'wp_head', 'sharing_add_header', 1 ); + +add_action( 'template_redirect', 'sharing_process_requests' ); |