index of
/
home
/
thefkyzp
/
www
/
wp-content
/
plugins
/
ocean-extra
/
includes
/
widgets
/
File: /home/thefkyzp/www/wp-content/plugins/ocean-extra/includes/widgets/about-me.php
<?php /** * About Me Widget. * * @package OceanWP WordPress theme * @since 1.0.0 */ // Exit if accessed directly. if ( ! defined( 'ABSPATH' ) ) { exit; } // Start class. if ( ! class_exists( 'Ocean_Extra_About_Me_Widget' ) ) { /** * Register class for the About Me widget */ class Ocean_Extra_About_Me_Widget extends WP_Widget { /** * Register widget with WordPress. * * @since 1.0.0 */ public function __construct() { // Declare social services array. $this->social_services_array = apply_filters( 'ocean_about_me_widget_profiles', array( 'facebook' => array( 'name' => 'Facebook', 'url' => '', ), 'instagram' => array( 'name' => 'Instagram', 'url' => '', ), 'linkedin' => array( 'name' => 'LinkedIn', 'url' => '', ), 'pinterest' => array( 'name' => 'Pinterest', 'url' => '', ), 'twitter' => array( 'name' => 'X', 'url' => '', ), 'telegram' => array( 'name' => 'Telegram', 'url' => '', ), 'twitch' => array( 'name' => 'Twitch', 'url' => '', ), 'line' => array( 'name' => 'Line', 'url' => '', ), 'xing' => array( 'name' => 'Xing', 'url' => '', ), 'vine' => array( 'name' => 'Vine', 'url' => '', ), 'vimeo' => array( 'name' => 'Vimeo', 'url' => '', ), 'github' => array( 'name' => 'Github', 'url' => '', ), 'flickr' => array( 'name' => 'Flickr', 'url' => '', ), 'yelp' => array( 'name' => 'Yelp', 'url' => '', ), 'rss' => array( 'name' => 'RSS', 'url' => '', ), 'medium' => array( 'name' => 'Medium', 'url' => '', ), 'tiktok' => array( 'name' => 'tiktok', 'url' => '', ), 'vk' => array( 'name' => 'VK', 'url' => '', ), 'dribbble' => array( 'name' => 'Dribbble', 'url' => '', ), 'tumblr' => array( 'name' => 'Tumblr', 'url' => '', ), ) ); // Start up widget. parent::__construct( 'ocean_about_me', esc_html__( '» About Me', 'ocean-extra' ), array( 'classname' => 'widget-oceanwp-about-me about-me-widget', 'description' => esc_html__( 'Adds an About Me widget.', 'ocean-extra' ), 'customize_selective_refresh' => true, ) ); add_action( 'load-widgets.php', array( $this, 'scripts' ), 100 ); /** * Load widgets styling and scripts. * * @since 1.3.8 */ add_action( 'admin_head-widgets.php', array( $this, 'social_widget_style' ) ); add_action( 'admin_footer-widgets.php', array( $this, 'print_scripts' ) ); } /** * Enqueue media scripts * * @since 1.0.0 */ public function scripts() { // If is not customizer to avoid conflict. if ( is_customize_preview() ) { return; } wp_enqueue_media(); } /** * Custom widget style * * @since 1.3.8 */ public function social_widget_style() { ?> <style> .oceanwp-about-me-widget-services-list { padding-top: 10px; } .oceanwp-about-me-widget-services-list li { cursor: move; background: #fafafa; padding: 10px; border: 1px solid #e5e5e5; margin-bottom: 10px; } .oceanwp-about-me-widget-services-list li p { margin: 0 } .oceanwp-about-me-widget-services-list li label { margin-bottom: 3px; display: block; color: #222; } .oceanwp-about-me-widget-services-list li label span.fab { margin-right: 10px } .oceanwp-about-me-widget-services-list .placeholder { border: 1px dashed #e3e3e3 } .oceanwp-widget-select { width: 100% } </style> <?php } /** * Print scripts. * * @since 1.3.8 */ public function print_scripts() { // If it's not customizer to avoid conflict. if ( is_customize_preview() ) { return; } ?> <script> ( function( $ ){ $(document).ajaxSuccess(function(e, xhr, settings) { var widget_id_base = 'ocean_about_me'; if (typeof(settings.data) !== 'undefined' && typeof(settings.data.search) !== 'undefined') { if ( settings.data.search( 'action=save-widget' ) !== 'undefined' && typeof(settings.data.search( 'id_base=' + widget_id_base)) !== 'undefined' ) { oceanwpSortServices(); } } } ); function oceanwpSortServices() { $( '.oceanwp-about-me-widget-services-list' ).each( function() { var id = $(this).attr( 'id' ); $( '#'+ id ).sortable( { placeholder : "placeholder", opacity : 0.6 } ); } ); } oceanwpSortServices(); }( jQuery ) ); </script> <?php } /** * Front-end display of widget. * * @see WP_Widget::widget() * @since 1.0.0 * * @param array $args Widget arguments. * @param array $instance Saved values from database. */ public function widget( $args, $instance ) { // Get social services. $social_services = isset( $instance['social_services'] ) ? $instance['social_services'] : ''; // Return if no services defined. if ( ! $social_services ) { return; } // Define vars. $title = isset( $instance['title'] ) ? apply_filters( 'widget_title', $instance['title'] ) : ''; $avatar = isset( $instance['avatar'] ) ? $instance['avatar'] : ''; $name = isset( $instance['name'] ) ? $instance['name'] : ''; $text = isset( $instance['text'] ) ? $instance['text'] : ''; $social_style = isset( $instance['social_style'] ) ? $instance['social_style'] : ''; $target = isset( $instance['target'] ) ? $instance['target'] : ''; $nofollow = isset( $instance['nofollow'] ) ? $instance['nofollow'] : ''; // Before widget WP hook. echo $args['before_widget']; // Show widget title. if ( $title ) { echo $args['before_title'] . esc_html( $title ) . $args['after_title']; } ?> <div class="oceanwp-about-me"> <div class="oceanwp-about-me-avatar clr"> <?php // Display the avatar. if ( $avatar ) : ?> <img src="<?php echo esc_url( $avatar ); ?>" alt="<?php echo esc_attr( $title ); ?>" /> <?php endif; // Display the name. if ( $name ) : ?> <h3 class="oceanwp-about-me-name"><?php echo esc_html( $name ); ?></h3> <?php endif; ?> </div><!-- .oceanwp-about-me-avatar --> <?php // Display the text. if ( $text ) : ?> <div class="oceanwp-about-me-text clr"><?php echo do_shortcode( $text ); ?></div> <?php endif; // Determine link rel and screen reader text. $ocean_srt = '<span class="screen-reader-text">' . esc_html__( 'Opens in a new tab', 'ocean-extra' ) . '</span>'; $results = ocean_link_rel( $ocean_srt, $nofollow, $target ); $ocean_sr = $results[0]; $link_rel = $results[1]; // Display the social. if ( $social_services ) : ?> <ul class="oceanwp-about-me-social style-<?php echo esc_attr( $social_style ); ?>"> <?php // Original Array. $social_services_array = $this->social_services_array; // Loop through each item in the array. foreach ( $social_services as $key => $val ) { $link = ! empty( $social_services[ $key ]['url'] ) ? $social_services[ $key ]['url'] : null; if ( ! isset( $social_services_array[ $key ] ) ) { continue; } $name = $social_services_array[ $key ]['name']; $name = esc_html( $name ); // Display social links. if ( $link ) { $icon = 'youtube' === $key ? 'youtube' : $key; $icon = 'pinterest' === $key ? 'pinterest' : $icon; echo '<li class="' . esc_attr( $key ) . '"><a href="' . esc_url( $link ) . ' " aria-label="' . esc_attr( $name ) . '" target="_' . esc_attr( $target ) . '" ' . $link_rel . '>' . Ocean_Extra::oe_svg_icon( $icon, false ) . '</a>'; echo $ocean_sr; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Escaped above. echo '</li>'; } } ?> </ul> <?php endif; ?> </div> <?php // After widget WP hook. echo $args['after_widget']; } /** * Sanitize widget form values as they are saved. * * @see WP_Widget::update() * @since 1.0.0 * * @param array $new_instance Values just sent to be saved. * @param array $old_instance Previously saved values from database. * * @return array Updated safe values to be saved. */ public function update( $new_instance, $old_instance ) { $instance = $old_instance; $instance['title'] = strip_tags( $new_instance['title'] ); $instance['avatar'] = strip_tags( $new_instance['avatar'] ); $instance['name'] = strip_tags( $new_instance['name'] ); $instance['text'] = $new_instance['text']; $instance['social_style'] = strip_tags( $new_instance['social_style'] ); $instance['target'] = strip_tags( $new_instance['target'] ); $instance['nofollow'] = strip_tags( $new_instance['nofollow'] ); $instance['social_services'] = $new_instance['social_services']; return $instance; } /** * Back-end widget form. * * @see WP_Widget::form() * @since 1.0.0 * * @param array $instance Previously saved values from database. */ public function form( $instance ) { $instance = wp_parse_args( (array) $instance, array( 'title' => esc_html__( 'About Me', 'ocean-extra' ), 'avatar' => OE_URL . 'assets/img/about-avatar.png', 'name' => esc_html__( 'John Doe', 'ocean-extra' ), 'text' => 'Lorem ipsum ex vix illud nonummy novumtatio et his. At vix patrioque scribentur at fugitertissi ext scriptaset verterem molestiae.', 'social_style' => 'color', 'target' => 'blank', 'nofollow' => 'no', 'social_services' => $this->social_services_array, ) ); ?> <p> <label for="<?php echo esc_attr( $this->get_field_id( 'title' ) ); ?>"><?php esc_html_e( 'Title', 'ocean-extra' ); ?>:</label> <input class="widefat" id="<?php echo esc_attr( $this->get_field_id( 'title' ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( 'title' ) ); ?>" type="text" value="<?php echo esc_attr( $instance['title'] ); ?>" /> </p> <p> <label for="<?php echo esc_attr( $this->get_field_id( 'avatar' ) ); ?>"><?php esc_html_e( 'Image URL', 'ocean-extra' ); ?>:</label> <input class="widefat" id="<?php echo esc_attr( $this->get_field_id( 'avatar' ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( 'avatar' ) ); ?>" type="text" value="<?php echo esc_attr( $instance['avatar'] ); ?>" style="margin-bottom:10px;" /> <input class="oceanwp-widget-upload-button button button-secondary" type="button" value="<?php esc_html_e( 'Upload Image', 'ocean-extra' ); ?>" /> </p> <p> <label for="<?php echo esc_attr( $this->get_field_id( 'name' ) ); ?>"><?php esc_html_e( 'Name:', 'ocean-extra' ); ?></label> <input type="text" class="widefat" id="<?php echo esc_attr( $this->get_field_id( 'name' ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( 'name' ) ); ?>" value="<?php echo esc_attr( $instance['name'] ); ?>" /> </p> <p> <label for="<?php echo esc_attr( $this->get_field_id( 'text' ) ); ?>"><?php esc_html_e( 'Description:', 'ocean-extra' ); ?></label> <textarea rows="15" id="<?php echo esc_attr( $this->get_field_id( 'text' ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( 'text' ) ); ?>" class="widefat" style="height: 100px;"> <?php if ( ! empty( $instance['text'] ) ) { echo esc_textarea( $instance['text'] ); } ?> </textarea> </p> <p> <label for="<?php echo esc_attr( $this->get_field_id( 'social_style' ) ); ?>"><?php esc_html_e( 'Social Style:', 'ocean-extra' ); ?></label> <br /> <select class='widget-select widefat' name="<?php echo esc_attr( $this->get_field_name( 'social_style' ) ); ?>" id="<?php echo esc_attr( $this->get_field_id( 'social_style' ) ); ?>"> <option value="color" <?php selected( $instance['social_style'], 'color' ); ?>><?php esc_html_e( 'Color', 'ocean-extra' ); ?></option> <option value="light" <?php selected( $instance['social_style'], 'light' ); ?>><?php esc_html_e( 'Light', 'ocean-extra' ); ?></option> <option value="dark" <?php selected( $instance['social_style'], 'dark' ); ?>><?php esc_html_e( 'Dark', 'ocean-extra' ); ?></option> </select> </p> <p> <label for="<?php echo esc_attr( $this->get_field_id( 'target' ) ); ?>"><?php esc_html_e( 'Social Link Target:', 'ocean-extra' ); ?></label> <select class='widget-select widefat' name="<?php echo esc_attr( $this->get_field_name( 'target' ) ); ?>" id="<?php echo esc_attr( $this->get_field_id( 'target' ) ); ?>"> <option value="blank" <?php selected( $instance['target'], 'blank' ); ?>><?php esc_html_e( 'Blank', 'ocean-extra' ); ?></option> <option value="self" <?php selected( $instance['target'], 'self' ); ?>><?php esc_html_e( 'Self', 'ocean-extra' ); ?></option> </select> </p> <p> <label for="<?php echo esc_attr( $this->get_field_id( 'nofollow' ) ); ?>"><?php esc_html_e( 'Add Nofollow Link Rel:', 'ocean-extra' ); ?></label> <select class='widget-select widefat' name="<?php echo esc_attr( $this->get_field_name( 'nofollow' ) ); ?>" id="<?php echo esc_attr( $this->get_field_id( 'nofollow' ) ); ?>"> <option value="no" <?php selected( $instance['nofollow'], 'no' ); ?>><?php esc_html_e( 'No', 'ocean-extra' ); ?></option> <option value="yes" <?php selected( $instance['nofollow'], 'yes' ); ?>><?php esc_html_e( 'Yes', 'ocean-extra' ); ?></option> </select> </p> <?php $field_id_services = $this->get_field_id( 'social_services' ); $field_name_services = $this->get_field_name( 'social_services' ); ?> <h3 style="margin-top:20px;margin-bottom:0;"><?php esc_html_e( 'Social Links', 'ocean-extra' ); ?></h3> <ul id="<?php echo esc_attr( $field_id_services ); ?>" class="oceanwp-about-me-widget-services-list"> <input type="hidden" id="<?php echo esc_attr( $field_name_services ); ?>" value="<?php echo esc_attr( $field_name_services ); ?>"> <input type="hidden" id="<?php echo esc_attr( wp_create_nonce( 'oceanwp_fontawesome_social_widget_nonce' ) ); ?>"> <?php // Social array. $social_services_array = $this->social_services_array; // Get current services display. $display_services = isset( $instance['social_services'] ) ? $instance['social_services'] : ''; // Loop through social services to display inputs. foreach ( $display_services as $key => $val ) { if ( ! isset( $social_services_array[ $key ] ) ) { continue; } $url = ! empty( $display_services[ $key ]['url'] ) ? esc_url( $display_services[ $key ]['url'] ) : null; $name = $social_services_array[ $key ]['name']; ?> <li id="<?php echo esc_attr( $field_id_services ); ?>_0<?php echo esc_attr( $key ); ?>"> <p> <label for="<?php echo esc_attr( $field_id_services ); ?>-<?php echo esc_attr( $key ); ?>-name"><?php echo esc_html( wp_strip_all_tags( $name ) ); ?>:</label> <input type="hidden" id="<?php echo esc_attr( $field_id_services ); ?>-<?php echo esc_attr( $key ); ?>-url" name="<?php echo esc_attr( $field_name_services . '[' . $key . '][name]' ); ?>" value="<?php echo esc_attr( $name ); ?>"> <input type="text" class="widefat" id="<?php echo esc_attr( $field_id_services ); ?>-<?php echo esc_attr( $key ); ?>-url" name="<?php echo esc_attr( $field_name_services . '[' . $key . '][url]' ); ?>" value="<?php echo esc_attr( $url ); ?>" /> </p> </li> <?php } ?> </ul> <script type="text/javascript"> (function($) { "use strict"; $( document ).ready( function() { var _custom_media = true, _orig_send_attachment = wp.media.editor.send.attachment; $( '.oceanwp-widget-upload-button' ).click(function(e) { var send_attachment_bkp = wp.media.editor.send.attachment, button = $(this), id = button.prev(); _custom_media = true; wp.media.editor.send.attachment = function( props, attachment ) { if ( _custom_media ) { $( id ).val( attachment.url ); } else { return _orig_send_attachment.apply( this, [props, attachment] ); }; } wp.media.editor.open( button ); return false; } ); $( '.add_media').on('click', function() { _custom_media = false; } ); } ); } ) ( jQuery ); </script> <?php } } } register_widget( 'Ocean_Extra_About_Me_Widget' );