Social Media Link Widget with Icons
<?php
/**
* Social Widget
* Based on Bill Erickson's example from his Core Functionality plugin example.
* An older version of Bill's code had a similar style widget example.
*
* @package Core Functionality
* @since 1.0.0
* @link https://github.com/billerickson/Core-Functionality
* @author Bill Erickson <bill@billerickson.net>
* @author Patrick Boehner <patrick@patrickboehner.com>
* @copyright Copyright (c) 2011, Bill Erickson
* @license http://opensource.org/licenses/gpl-2.0.php GNU Public License
*/
//* Block Acess
//**********************************************
if( !defined( 'ABSPATH' ) ) exit;
// Setup Simple Social Widget
//**********************************************
class PB_Social_Widget extends WP_Widget {
/**
* Constructor
* @return void
**/
function __construct() {
$widget_ops = array(
'classname' => 'widget_social_links',
'description' => 'A simple social media icon widget'
);
parent::__construct( 'social-widget', 'Social Media Links Widget', $widget_ops );
}
/**
* Social Options
*
*/
function social_options() {
return array(
'facebook' => 'Facebook',
'youtube' => 'Youtube',
'vimeo' => 'Vimeo',
'linkedin' => 'LinkedIn',
'instagram' => 'Instagram',
'twitter' => 'Twitter',
'pinterest' => 'Pinterest',
'yelp' => 'Yelp',
);
}
/**
* Outputs the HTML for this widget.
* Includes schema for soical media porfiles as outlined by google
*
* @param array An array of standard parameters for widgets in this theme
* @param array An array of settings for this widget instance
* @return void Echoes it's output
**/
function widget( $args, $instance ) {
extract( $args, EXTR_SKIP );
echo $before_widget;
if( $instance['title'] )
echo $before_title . esc_html( $instance['title'] ) . $after_title;
echo '<div class="social-links" itemscope itemtype="http://schema.org/Organization">';
echo '<span class="screen-reader-text">Social media links</span>';
echo '<link itemprop="url" href="' .get_bloginfo( 'url' ). '">';
echo '<ul class=social-links-list>';
$socials = $this->social_options();
foreach( $socials as $key => $label ) {
if( !empty( $instance[$key] ) )
echo '<li class="social-item"><a class="social-icon icon-' . $key . '" itemprop="sameAs" href="' . esc_url( $instance[$key] ) . '" target="_blank" rel="noopener noreferrer" aria-label="' .$key. ' - Opens in new window"></a></li>';
}
echo '</ul></div>';
echo $after_widget;
}
/**
* Deals with the settings when they are saved by the admin. Here is
* where any validation should be dealt with.
*
* @param array An array of new settings as submitted by the admin
* @param array An array of the previous settings
* @return array The validated and (if necessary) amended settings
**/
function update( $new_instance, $old_instance ) {
$instance = $old_instance;
$instance['title'] = esc_attr( $new_instance['title'] );
$socials = $this->social_options();
foreach( $socials as $key => $label )
$instance[$key] = esc_url( $new_instance[$key] );
return $instance;
}
/**
* Displays the form for this widget on the Widgets page of the WP Admin area.
*
* @param array An array of the current settings for this widget
* @return void Echoes it's output
**/
function form( $instance ) {
$socials = $this->social_options();
$defaults = array( 'title' => '' );
foreach( $socials as $key => $label )
$defaults[$key] = '';
$instance = wp_parse_args( (array) $instance, $defaults );
echo '<p><label for="' . $this->get_field_id( 'title' ) . '">Title: <input class="widefat" id="' . $this->get_field_id( 'title' ) .'" name="' . $this->get_field_name( 'title' ) . '" value="' . esc_attr( $instance['title'] ) . '" /></label></p>';
foreach( $socials as $key => $label )
echo '<p><label for="' . $this->get_field_id( $key ) . '">' . $label . ' URL: <input class="widefat" id="' . $this->get_field_id( $key ) .'" name="' . $this->get_field_name( $key ) . '" value="' . esc_url( $instance[$key] ) . '" /></label></p>';
}
}
//* Register the widget
add_action( 'widgets_init', 'pb_register_social_widget' );
function pb_register_social_widget() {
register_widget('PB_Social_Widget');
}