 ankitpokhrel    /
                    Dynamic-Featured-Image
                      ankitpokhrel    /
                    Dynamic-Featured-Image
                
                            These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more
| 1 | <?php | ||
| 2 | /** | ||
| 3 | * Plugin Name: Dynamic Featured Image | ||
| 4 | * Plugin URI: http://wordpress.org/plugins/dynamic-featured-image/ | ||
| 5 | * Description: Dynamically adds multiple featured image or post thumbnail functionality to your posts, pages and custom post types. | ||
| 6 | * Version: 3.6.8 | ||
| 7 | * Author: Ankit Pokhrel | ||
| 8 | * Author URI: https://ankitpokhrel.com | ||
| 9 | * License: GPL2 or later | ||
| 10 | * License URI: http://www.gnu.org/licenses/gpl-2.0.html | ||
| 11 | * Text Domain: dynamic-featured-image | ||
| 12 | * Domain Path: /languages | ||
| 13 | * GitHub Plugin URI: https://github.com/ankitpokhrel/Dynamic-Featured-Image | ||
| 14 | * | ||
| 15 | * @package dynamic-featured-image | ||
| 16 | * | ||
| 17 | * Copyright (C) 2013-2019 Ankit Pokhrel <[email protected], https://ankitpokhrel.com> | ||
| 18 | * | ||
| 19 | * This program is free software; you can redistribute it and/or modify | ||
| 20 | * it under the terms of the GNU General Public License as published by | ||
| 21 | * the Free Software Foundation; either version 3 of the License, or | ||
| 22 | * (at your option) any later version. | ||
| 23 | * | ||
| 24 | * This program is distributed in the hope that it will be useful, | ||
| 25 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 26 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 27 | * GNU General Public License for more details. | ||
| 28 | * | ||
| 29 | * You should have received a copy of the GNU General Public License | ||
| 30 | * along with this program. If not, see <http://www.gnu.org/licenses/>. | ||
| 31 | */ | ||
| 32 | |||
| 33 | // Avoid direct calls to this file. | ||
| 34 | if ( ! defined( 'ABSPATH' ) ) { | ||
| 35 | header( 'Status: 403 Forbidden' ); | ||
| 36 | header( 'HTTP/1.1 403 Forbidden' ); | ||
| 37 | exit(); | ||
| 38 | } | ||
| 39 | |||
| 40 | /** | ||
| 41 | * Dynamic Featured Image plugin main class. | ||
| 42 | * | ||
| 43 | * @author Ankit Pokhrel <[email protected]> | ||
| 44 | * @version 3.6.8 | ||
| 45 | */ | ||
| 46 | class Dynamic_Featured_Image { | ||
| 47 | /** | ||
| 48 | * Current version of the plugin. | ||
| 49 | * | ||
| 50 | * @since 3.0.0 | ||
| 51 | */ | ||
| 52 | const VERSION = '3.6.8'; | ||
| 53 | |||
| 54 | /** | ||
| 55 | * Text domain. | ||
| 56 | * | ||
| 57 | * @since 3.6.0 | ||
| 58 | */ | ||
| 59 | const TEXT_DOMAIN = 'dynamic-featured-image'; | ||
| 60 | |||
| 61 | /** | ||
| 62 | * Documentation Link. | ||
| 63 | * | ||
| 64 | * @since 3.6.0 | ||
| 65 | */ | ||
| 66 | const WIKI_LINK = 'https://github.com/ankitpokhrel/Dynamic-Featured-Image/wiki/'; | ||
| 67 | |||
| 68 | /** | ||
| 69 | * Upgrade Link. | ||
| 70 | * | ||
| 71 | * @since 3.6.0 | ||
| 72 | */ | ||
| 73 | const UPGRADE_LINK = 'https://ankitpokhrel.com/explore/dynamic-featured-image-pro/'; | ||
| 74 | |||
| 75 | /** | ||
| 76 | * Image upload directory. | ||
| 77 | * | ||
| 78 | * @var $upload_dir string | ||
| 79 | */ | ||
| 80 | private $upload_dir; | ||
| 81 | |||
| 82 | /** | ||
| 83 | * Image upload URL. | ||
| 84 | * | ||
| 85 | * @var $upload_url string | ||
| 86 | */ | ||
| 87 | private $upload_url; | ||
| 88 | |||
| 89 | /** | ||
| 90 | * Database object. | ||
| 91 | * | ||
| 92 | * @var $db wpdb | ||
| 93 | */ | ||
| 94 | private $db; | ||
| 95 | |||
| 96 | /** | ||
| 97 | * Title for dfi metabox. | ||
| 98 | * | ||
| 99 | * @var $metabox_title string | ||
| 100 | */ | ||
| 101 | protected $metabox_title; | ||
| 102 | |||
| 103 | /** | ||
| 104 | * Users post type filter for dfi metabox. | ||
| 105 | * | ||
| 106 | * @var $user_filter array | ||
| 107 | */ | ||
| 108 | protected $user_filter; | ||
| 109 | |||
| 110 | /** | ||
| 111 | * Constructor. Hooks all interactions to initialize the class. | ||
| 112 | * | ||
| 113 | * @since 1.0.0 | ||
| 114 | * @access public | ||
| 115 | * @global object $wpdb | ||
| 116 | * | ||
| 117 | * @see add_action() | ||
| 118 | */ | ||
| 119 | 1 |     public function __construct() { | |
| 120 | // plugin update warning. | ||
| 121 | 1 | add_action( 'in_plugin_update_message-' . plugin_basename( __FILE__ ), array( $this, 'update_notice' ) ); | |
| 122 | |||
| 123 | 1 | add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_admin_scripts' ) ); | |
| 124 | 1 | add_action( 'add_meta_boxes', array( $this, 'initialize_featured_box' ) ); | |
| 125 | 1 | add_action( 'save_post', array( $this, 'save_meta' ) ); | |
| 126 | 1 | add_action( 'plugins_loaded', array( $this, 'load_plugin_textdomain' ) ); | |
| 127 | |||
| 128 | // handle ajax request. | ||
| 129 | 1 | add_action( 'wp_ajax_dfiMetaBox_callback', array( $this, 'ajax_callback' ) ); | |
| 130 | |||
| 131 | // add action links. | ||
| 132 | 1 | add_filter( 'plugin_action_links_' . plugin_basename( __FILE__ ), array( $this, 'dfi_action_links' ) ); | |
| 133 | |||
| 134 | // media uploader custom fields. | ||
| 135 | 1 | add_filter( 'attachment_fields_to_edit', array( $this, 'media_attachment_custom_fields' ), 10, 2 ); | |
| 136 | 1 | add_filter( 'attachment_fields_to_save', array( $this, 'media_attachment_custom_fields_save' ), 10, 2 ); | |
| 137 | |||
| 138 | // plugin sponsors. | ||
| 139 | 1 | new PluginSponsor(); | |
| 140 | |||
| 141 | // get the site protocol. | ||
| 142 | 1 | $protocol = $this->get_protocol(); | |
| 143 | |||
| 144 | 1 | $this->upload_dir = wp_upload_dir(); | |
| 145 | 1 | $this->upload_url = preg_replace( '#^https?://#', '', $this->upload_dir['baseurl'] ); | |
| 146 | |||
| 147 | // add protocol to the upload url. | ||
| 148 | 1 | $this->upload_url = $protocol . $this->upload_url; | |
| 149 | |||
| 150 | // post type filter added by user. | ||
| 151 | 1 | $this->user_filter = array(); | |
| 152 | |||
| 153 | 1 | global $wpdb; | |
| 154 | 1 | $this->db = $wpdb; | |
| 155 | 1 | } | |
| 156 | |||
| 157 | /** | ||
| 158 | * Return site protocol. | ||
| 159 | * | ||
| 160 | * @since 3.5.1 | ||
| 161 | * @access public | ||
| 162 | * | ||
| 163 | * @return string | ||
| 164 | */ | ||
| 165 |     private function get_protocol() { | ||
| 166 | return is_ssl() ? 'https://' : 'http://'; | ||
| 167 | } | ||
| 168 | |||
| 169 | /** | ||
| 170 | * Add required admin scripts. | ||
| 171 | * | ||
| 172 | * @since 1.0.0 | ||
| 173 | * @access public | ||
| 174 | * | ||
| 175 | * @see wp_enqueue_style() | ||
| 176 | * @see wp_register_script() | ||
| 177 | * @see wp_enqueue_script() | ||
| 178 | * | ||
| 179 | * @return void | ||
| 180 | */ | ||
| 181 | 1 |     public function enqueue_admin_scripts() { | |
| 182 | // enqueue styles. | ||
| 183 | 1 | wp_enqueue_style( 'style-dfi', plugins_url( '/css/style-dfi.css', __FILE__ ), array(), self::VERSION ); | |
| 184 | |||
| 185 | // register script. | ||
| 186 | 1 | wp_register_script( 'scripts-dfi', plugins_url( '/js/script-dfi.js', __FILE__ ), array( 'jquery' ), self::VERSION ); | |
| 187 | |||
| 188 | // localize the script with required data. | ||
| 189 | 1 | wp_localize_script( | |
| 190 | 1 | 'scripts-dfi', | |
| 191 | 1 | 'DFI_SPECIFIC', | |
| 192 | array( | ||
| 193 | 1 | 'upload_url' => $this->upload_url, | |
| 194 | 1 | 'metabox_title' => __( $this->metabox_title, self::TEXT_DOMAIN ), | |
| 195 | 1 | 'mediaSelector_title' => __( 'Dynamic Featured Image - Media Selector', self::TEXT_DOMAIN ), | |
| 196 | 1 | 'mediaSelector_buttonText' => __( 'Set Featured Image', self::TEXT_DOMAIN ), | |
| 197 | 1 | 'ajax_nonce' => wp_create_nonce( plugin_basename( __FILE__ ) ), | |
| 198 | ) | ||
| 199 | 1 | ); | |
| 200 | |||
| 201 | // enqueue scripts. | ||
| 202 | 1 | wp_enqueue_script( 'scripts-dfi' ); | |
| 203 | 1 | } | |
| 204 | |||
| 205 | /** | ||
| 206 | * Add upgrade link. | ||
| 207 | * | ||
| 208 | * @access public | ||
| 209 | * @since 3.5.1 | ||
| 210 | * @action plugin_action_links | ||
| 211 | * | ||
| 212 | * @codeCoverageIgnore | ||
| 213 | * | ||
| 214 | * @param array $links Action links. | ||
| 215 | * | ||
| 216 | * @return array | ||
| 217 | */ | ||
| 218 |     public function dfi_action_links( $links ) { | ||
| 219 | $upgrade_link = array( | ||
| 220 | '<a href="' . self::UPGRADE_LINK . '" target="_blank">Upgrade to Premium</a>' | ||
| 221 | ); | ||
| 222 | |||
| 223 | return array_merge( $links, $upgrade_link ); | ||
| 224 | } | ||
| 225 | |||
| 226 | /** | ||
| 227 | * Add featured meta boxes dynamically. | ||
| 228 | * | ||
| 229 | * @since 1.0.0 | ||
| 230 | * @access public | ||
| 231 | * @global object $post | ||
| 232 | * | ||
| 233 | * @see get_post_meta() | ||
| 234 | * @see get_post_types() | ||
| 235 | * @see add_meta_box() | ||
| 236 | * @see add_filter() | ||
| 237 | * | ||
| 238 | * @return void | ||
| 239 | */ | ||
| 240 |     public function initialize_featured_box() { | ||
| 241 | global $post; | ||
| 242 | |||
| 243 | // make metabox title dynamic. | ||
| 244 | $this->metabox_title = apply_filters( 'dfi_set_metabox_title', __( 'Featured Image', self::TEXT_DOMAIN ) ); | ||
| 245 | |||
| 246 | $featured_data = get_post_meta( $post->ID, 'dfiFeatured', true ); | ||
| 247 | $total_featured = is_array( $featured_data ) ? count( $featured_data ) : 0; | ||
| 248 | |||
| 249 | $default_filter = array( 'attachment', 'revision', 'nav_menu_item' ); | ||
| 250 | $this->user_filter = apply_filters( 'dfi_post_type_user_filter', $this->user_filter ); | ||
| 251 | |||
| 252 | $post_types = array_diff( get_post_types(), array_merge( $default_filter, $this->user_filter ) ); | ||
| 253 | $post_types = apply_filters( 'dfi_post_types', $post_types ); | ||
| 254 | |||
| 255 |         if ( ! empty( $featured_data ) && $total_featured >= 1 ) { | ||
| 256 | $i = 2; | ||
| 257 |             foreach ( $featured_data as $featured ) { | ||
| 258 | $this->dfi_add_meta_box( $post_types, $featured, $i++ ); | ||
| 259 | } | ||
| 260 |         } else { | ||
| 261 | $this->dfi_add_meta_box( $post_types ); | ||
| 262 | } | ||
| 263 | } | ||
| 264 | |||
| 265 | /** | ||
| 266 | * Translates more than one digit number digit by digit. | ||
| 267 | * | ||
| 268 | * @param int $number Integer to be translated. | ||
| 269 | * | ||
| 270 | * @return string Translated number | ||
| 271 | */ | ||
| 272 | 2 |     protected function get_number_translation( $number ) { | |
| 273 | 2 |         if ( $number <= 9 ) { | |
| 274 | 1 | return __( $number, self::TEXT_DOMAIN ); | |
| 275 |         } else { | ||
| 276 | 1 | $pieces = str_split( $number, 1 ); | |
| 277 | 1 | $buffer = ''; | |
| 278 | 1 |             foreach ( $pieces as $piece ) { | |
| 279 | 1 | $buffer .= __( $piece, self::TEXT_DOMAIN ); | |
| 280 | 1 | } | |
| 281 | |||
| 282 | 1 | return $buffer; | |
| 283 | } | ||
| 284 | } | ||
| 285 | |||
| 286 | /** | ||
| 287 | * Adds meta boxes. | ||
| 288 | * | ||
| 289 | * @param array $post_types Post types to show featured image box. | ||
| 290 | * @param object $featured Callback arguments. | ||
| 291 | * @param int $i Index of the featured image. | ||
| 292 | * | ||
| 293 | * @return void | ||
| 294 | */ | ||
| 295 |     private function dfi_add_meta_box( $post_types, $featured = null, $i = null ) { | ||
| 296 |         if ( ! is_null( $i ) ) { | ||
| 297 |             foreach ( $post_types as $type ) { | ||
| 298 | add_meta_box( | ||
| 299 | 'dfiFeaturedMetaBox-' . $i, | ||
| 300 | __( $this->metabox_title, self::TEXT_DOMAIN ) . ' ' . $this->get_number_translation( $i ), | ||
| 301 | array( $this, 'featured_meta_box' ), | ||
| 302 | $type, | ||
| 303 | apply_filters( 'dfi_metabox_context', 'side' ), | ||
| 304 | apply_filters( 'dfi_metabox_priority', 'low' ), | ||
| 305 | array( $featured, $i + 1 ) | ||
| 306 | ); | ||
| 307 | |||
| 308 |                 add_filter( "postbox_classes_{$type}_dfiFeaturedMetaBox-" . $i, array( $this, 'add_metabox_classes' ) ); | ||
| 309 | } | ||
| 310 |         } else { | ||
| 311 |             foreach ( $post_types as $type ) { | ||
| 312 | add_meta_box( | ||
| 313 | 'dfiFeaturedMetaBox', | ||
| 314 | __( $this->metabox_title, self::TEXT_DOMAIN ) . ' ' . __( 2, self::TEXT_DOMAIN ), | ||
| 315 | array( $this, 'featured_meta_box' ), | ||
| 316 | $type, | ||
| 317 | apply_filters( 'dfi_metabox_context', 'side' ), | ||
| 318 | apply_filters( 'dfi_metabox_priority', 'low' ), | ||
| 319 | array( null, null ) | ||
| 320 | ); | ||
| 321 | |||
| 322 |                 add_filter( "postbox_classes_{$type}_dfiFeaturedMetaBox", array( $this, 'add_metabox_classes' ) ); | ||
| 323 | } | ||
| 324 | } | ||
| 325 | } | ||
| 326 | |||
| 327 | /** | ||
| 328 | * Separate thumb and full image url from given URL string. | ||
| 329 | * | ||
| 330 | * @since 3.3.1 | ||
| 331 | * | ||
| 332 | * @param string $url_string Url string. | ||
| 333 | * @param string $state Thumb or full. | ||
| 334 | * | ||
| 335 | * @return string|null | ||
| 336 | */ | ||
| 337 | 3 |     private function separate( $url_string, $state = 'thumb' ) { | |
| 338 | 3 | $image_piece = explode( ',', $url_string ); | |
| 339 | |||
| 340 | 3 |         if ( 'thumb' === $state ) { | |
| 341 | 2 | return isset( $image_piece[0] ) ? $image_piece[0] : null; | |
| 342 | } | ||
| 343 | |||
| 344 | 3 | return isset( $image_piece[1] ) ? $image_piece[1] : null; | |
| 345 | } | ||
| 346 | |||
| 347 | /** | ||
| 348 | * Create a nonce field. | ||
| 349 | * | ||
| 350 | * @since 3.5.0 | ||
| 351 | * | ||
| 352 | * @see wp_nonce_field() | ||
| 353 | * @see plugin_basename() | ||
| 354 | * | ||
| 355 | * @codeCoverageIgnore | ||
| 356 | * | ||
| 357 | * @param string $key Nonce key. | ||
| 358 | * | ||
| 359 | * @return string | ||
| 360 | */ | ||
| 361 |     protected function nonce_field( $key ) { | ||
| 362 | return wp_nonce_field( plugin_basename( __FILE__ ), $key, true, false ); | ||
| 363 | } | ||
| 364 | |||
| 365 | /** | ||
| 366 | * Featured meta box as seen in the admin. | ||
| 367 | * | ||
| 368 | * @since 1.0.0 | ||
| 369 | * @access public | ||
| 370 | * | ||
| 371 | * @param object $post Global post object. | ||
| 372 | * @param array $featured Array containing featured image count. | ||
| 373 | * | ||
| 374 | * @throws Exception Medium size image not found. | ||
| 375 | * @return void | ||
| 376 | */ | ||
| 377 | 2 |     public function featured_meta_box( $post, $featured ) { | |
| 378 | 2 | $featured_img = $featured['args'][0]; | |
| 379 | 2 | $featured_id = is_null( $featured['args'][1] ) ? 2 : --$featured['args'][1]; | |
| 380 | 2 | $featured_img_full = $featured_img; | |
| 381 | 2 | $featured_img_trimmed = $featured_img; | |
| 382 | |||
| 383 | 2 |         if ( ! is_null( $featured_img ) ) { | |
| 384 | 2 | $featured_img_trimmed = $this->separate( $featured_img ); | |
| 385 | 2 | $featured_img_full = $this->separate( $featured_img, 'full' ); | |
| 386 | 2 | } | |
| 387 | |||
| 388 | 2 | $thumbnail = null; | |
| 389 | 2 | $attachment_id = null; | |
| 390 | View Code Duplication |         if ( ! empty( $featured_img_full ) ) { | |
| 0 ignored issues–
                            show | |||
| 391 | $attachment_id = $this->get_image_id( $this->upload_url . $featured_img_full ); | ||
| 392 | 2 | ||
| 393 | 2 | $thumbnail = $this->get_image_thumb_by_attachment_id( $attachment_id, 'medium' ); | |
| 394 | |||
| 395 |             if ( empty( $thumbnail ) ) { | ||
| 396 | 2 | // since medium sized thumbnail image is missing, | |
| 397 | 2 | // let's set full image url as thumbnail. | |
| 398 | 2 | $thumbnail = $featured_img_full; | |
| 399 | } | ||
| 400 | } | ||
| 401 | |||
| 402 | // Add a nonce field. | ||
| 403 | echo $this->nonce_field( 'dfi_fimageplug-' . $featured_id ); // WPCS: XSS ok. | ||
| 404 | echo $this->get_featured_box( $featured_img_trimmed, $featured_img, $featured_id, $thumbnail, $post->ID, $attachment_id ); // WPCS: XSS ok. | ||
| 405 | } | ||
| 406 | |||
| 407 | /** | ||
| 408 | * Returns featured box html content. | ||
| 409 | * | ||
| 410 | * @since 3.1.0 | ||
| 411 | * @access private | ||
| 412 | * | ||
| 413 | * @param string $featured_img_trimmed Medium sized image. | ||
| 414 | 2 | * @param string $featured_img Full sized image. | |
| 415 | 2 | * @param string $featured_id Featured id number for translation. | |
| 416 | 2 | * @param string $thumbnail Thumb sized image. | |
| 417 | 2 | * @param int $post_id Post id. | |
| 418 | * @param int $attachment_id Attachment id. | ||
| 419 | 2 | * | |
| 420 | 2 | * @return string Html content | |
| 421 | */ | ||
| 422 | 2 |     private function get_featured_box( $featured_img_trimmed, $featured_img, $featured_id, $thumbnail, $post_id, $attachment_id ) { | |
| 423 | 2 | $has_featured_image = ! empty( $featured_img_trimmed ) ? ' hasFeaturedImage' : ''; | |
| 424 | $thumbnail = ! is_null( $thumbnail ) ? $thumbnail : ''; | ||
| 425 | $dfi_empty = is_null( $featured_img_trimmed ) ? 'dfiImgEmpty' : ''; | ||
| 426 | 2 | ||
| 427 |         return "<a href='javascript:void(0)' class='dfiFeaturedImage{$has_featured_image}' title='" . __( 'Set Featured Image', self::TEXT_DOMAIN ) . "' data-post-id='" . $post_id . "' data-attachment-id='" . $attachment_id . "'><span class='dashicons dashicons-camera'></span></a><br/> | ||
| 428 |             <img src='" . $thumbnail . "' class='dfiImg {$dfi_empty}'/> | ||
| 429 | <div class='dfiLinks'> | ||
| 430 |                 <a href='javascript:void(0)' data-id='{$featured_id}' data-id-local='" . $this->get_number_translation( $featured_id + 1 ) . "' class='dfiAddNew dashicons dashicons-plus' title='" . __( 'Add New', self::TEXT_DOMAIN ) . "'></a> | ||
| 431 | <a href='javascript:void(0)' class='dfiRemove dashicons dashicons-minus' title='" . __( 'Remove', self::TEXT_DOMAIN ) . "'></a> | ||
| 432 | </div> | ||
| 433 | <div class='dfiClearFloat'></div> | ||
| 434 |             <input type='hidden' name='dfiFeatured[]' value='{$featured_img}'  class='dfiImageHolder' />"; | ||
| 435 | } | ||
| 436 | |||
| 437 | 2 | /** | |
| 438 | 2 | * Load new featured meta box via ajax. | |
| 439 | * | ||
| 440 | 1 | * @since 1.0.0 | |
| 441 | * @access public | ||
| 442 | 1 | * | |
| 443 | * @return void | ||
| 444 | */ | ||
| 445 |     public function ajax_callback() { | ||
| 446 | check_ajax_referer( plugin_basename( __FILE__ ), 'security' ); | ||
| 447 | 1 | ||
| 448 | $featured_id = isset( $_POST['id'] ) ? intval( wp_unslash( $_POST['id'] ) ) : null; | ||
| 449 | |||
| 450 |         if ( ! is_numeric( $featured_id ) ) { | ||
| 451 | return; | ||
| 452 | } | ||
| 453 | |||
| 454 | // @codingStandardsIgnoreStart | ||
| 455 | echo $this->nonce_field( 'dfi_fimageplug-' . $featured_id ); | ||
| 456 | ?> | ||
| 457 | <a href="javascript:void(0)" class="dfiFeaturedImage" | ||
| 458 | title="<?php echo __( 'Set Featured Image', self::TEXT_DOMAIN ) ?>"><span | ||
| 459 | class="dashicons dashicons-camera"></span></a><br/> | ||
| 460 | <img src="" class="dfiImg dfiImgEmpty"/> | ||
| 461 | <div class="dfiLinks"> | ||
| 462 | <a href="javascript:void(0)" data-id="<?php echo $featured_id ?>" | ||
| 463 | data-id-local="<?php echo $this->get_number_translation( $featured_id + 1 ) ?>" | ||
| 464 | 1 | class="dfiAddNew dashicons dashicons-plus" title="<?php echo __( 'Add New', self::TEXT_DOMAIN ) ?>"></a> | |
| 465 | <a href="javascript:void(0)" class="dfiRemove dashicons dashicons-minus" | ||
| 466 | title="<?php echo __( 'Remove', self::TEXT_DOMAIN ) ?>"></a> | ||
| 467 | </div> | ||
| 468 | <div class="dfiClearFloat"></div> | ||
| 469 | <input type="hidden" name="dfiFeatured[]" value="" class="dfiImageHolder"/> | ||
| 470 | <?php | ||
| 471 | // @codingStandardsIgnoreEnd | ||
| 472 | wp_die( '' ); | ||
| 473 | } | ||
| 474 | |||
| 475 | /** | ||
| 476 | * Add custom class 'featured-meta-box' to meta box. | ||
| 477 | * | ||
| 478 | * @since 1.0.0 | ||
| 479 | 1 | * @access public | |
| 480 | 1 | * | |
| 481 | * @see add_metabox_classes | ||
| 482 | 1 | * | |
| 483 | * @param array $classes Classes to add in the meta box. | ||
| 484 | * | ||
| 485 | * @return array | ||
| 486 | */ | ||
| 487 |     public function add_metabox_classes( $classes ) { | ||
| 488 | array_push( $classes, 'featured-meta-box' ); | ||
| 489 | |||
| 490 | return $classes; | ||
| 491 | } | ||
| 492 | |||
| 493 | /** | ||
| 494 | * Add custom fields in media uploader. | ||
| 495 | 1 | * | |
| 496 | 1 | * @since 3.4.0 | |
| 497 | 1 | * | |
| 498 | 1 | * @param array $form_fields Fields to include in media attachment form. | |
| 499 | 1 | * @param array $post Post data. | |
| 500 | * | ||
| 501 | * @return array | ||
| 502 | 1 | */ | |
| 503 |     public function media_attachment_custom_fields( $form_fields, $post ) { | ||
| 504 | $form_fields['dfi-link-to-image'] = array( | ||
| 505 | 'label' => __( 'Link to Image', self::TEXT_DOMAIN ), | ||
| 506 | 'input' => 'text', | ||
| 507 | 'value' => get_post_meta( $post->ID, '_dfi_link_to_image', true ), | ||
| 508 | ); | ||
| 509 | |||
| 510 | return $form_fields; | ||
| 511 | } | ||
| 512 | |||
| 513 | /** | ||
| 514 | * Save values of media uploader custom fields. | ||
| 515 | 1 | * | |
| 516 | 1 | * @since 3.4.0 | |
| 517 | 1 | * | |
| 518 | 1 | * @param array $post Post data for database. | |
| 519 | * @param array $attachment Attachment fields from $_POST form. | ||
| 520 | 1 | * | |
| 521 | * @return array | ||
| 522 | */ | ||
| 523 |     public function media_attachment_custom_fields_save( $post, $attachment ) { | ||
| 524 |         if ( isset( $attachment['dfi-link-to-image'] ) ) { | ||
| 525 | update_post_meta( $post['ID'], '_dfi_link_to_image', $attachment['dfi-link-to-image'] ); | ||
| 526 | } | ||
| 527 | |||
| 528 | return $post; | ||
| 529 | } | ||
| 530 | |||
| 531 | /** | ||
| 532 | * Update featured images in the database. | ||
| 533 | * | ||
| 534 | * @since 1.0.0 | ||
| 535 | * @access public | ||
| 536 | * | ||
| 537 | 2 | * @see plugin_basename() | |
| 538 | * @see update_post_meta() | ||
| 539 | 2 | * @see current_user_can() | |
| 540 | 1 | * | |
| 541 | * @param int $post_id Current post id. | ||
| 542 | * | ||
| 543 | 2 | * @return bool|null | |
| 544 | 2 | */ | |
| 545 |     public function save_meta( $post_id ) { | ||
| 546 | // Check auto save. | ||
| 547 |         if ( defined( 'DOING_AUTOSAVE' ) && DOING_AUTOSAVE ) { | ||
| 548 | 1 | return false; | |
| 549 | 1 | } | |
| 550 | |||
| 551 | 1 |         if ( ! $this->verify_nonces() ) { | |
| 552 | 1 | return false; | |
| 553 | 1 | } | |
| 554 | |||
| 555 | // Check permission before saving data. | ||
| 556 |         if ( current_user_can( 'edit_posts', $post_id ) && isset( $_POST['dfiFeatured'] ) ) { // WPCS: CSRF ok. | ||
| 557 | $featured_images = is_array( $_POST['dfiFeatured'] ) ? $_POST['dfiFeatured'] : array(); // WPCS: sanitization ok, CSRF ok. | ||
| 558 | |||
| 559 | update_post_meta( $post_id, 'dfiFeatured', $this->sanitize_array( $featured_images ) ); | ||
| 560 | } | ||
| 561 | } | ||
| 562 | |||
| 563 | /** | ||
| 564 | * Sanitize array. | ||
| 565 | 1 | * | |
| 566 | 1 | * @since 3.6.0 | |
| 567 | * @access protected | ||
| 568 | 1 | * | |
| 569 | 1 | * @param array $input_array Input array. | |
| 570 | 1 | * | |
| 571 | * @return array | ||
| 572 | 1 | */ | |
| 573 |     protected function sanitize_array( $input_array ) { | ||
| 574 | $sanitized = array(); | ||
| 575 | |||
| 576 |         foreach ( $input_array as $value ) { | ||
| 577 | $sanitized[] = sanitize_text_field( wp_unslash( $value ) ); | ||
| 578 | } | ||
| 579 | |||
| 580 | return $sanitized; | ||
| 581 | } | ||
| 582 | |||
| 583 | /** | ||
| 584 | * Verify metabox nonces. | ||
| 585 | * | ||
| 586 | * @access protected | ||
| 587 | * @see wp_verify_nonce() | ||
| 588 | * | ||
| 589 | * @return bool | ||
| 590 | */ | ||
| 591 |     protected function verify_nonces() { | ||
| 592 | $keys = preg_grep( '/dfi_fimageplug-\d+$/', array_keys( $_POST ) ); // WPCS: CSRF ok. | ||
| 593 | |||
| 594 |         if ( empty( $keys ) ) { | ||
| 595 | return false; | ||
| 596 | } | ||
| 597 | |||
| 598 |         foreach ( $keys as $key ) { | ||
| 599 | // Verify nonce. | ||
| 600 | if ( ! isset( $_POST[ $key ] ) || | ||
| 601 | ! wp_verify_nonce( sanitize_text_field( wp_unslash( $_POST[ $key ] ) ), plugin_basename( __FILE__ ) ) | ||
| 602 |             ) { | ||
| 603 | return false; | ||
| 604 | } | ||
| 605 | } | ||
| 606 | |||
| 607 | return true; | ||
| 608 | } | ||
| 609 | |||
| 610 | 1 | /** | |
| 611 | 1 | * Add update notice. Displayed in plugin update page. | |
| 612 | 1 | * | |
| 613 | * @since 2.0.0 | ||
| 614 | 1 | * @access public | |
| 615 | 1 | * | |
| 616 | * @return void | ||
| 617 | */ | ||
| 618 |     public function update_notice() { | ||
| 619 | $info = __( 'ATTENTION! Please read the <a href="' . self::WIKI_LINK . '" target="_blank">DOCUMENTATION</a> properly before update.', | ||
| 620 | self::TEXT_DOMAIN ); | ||
| 621 | |||
| 622 | echo '<span style="color: red; padding: 7px 0; display: block">' . strip_tags( $info, '<a><b><i><span>' ) . '</span>'; // WPCS: XSS ok. | ||
| 623 | } | ||
| 624 | 6 | ||
| 625 | 6 | /** | |
| 626 | * Execute query. | ||
| 627 | * | ||
| 628 | * @param string $query Query to execute. | ||
| 629 | * | ||
| 630 | * @return null|string | ||
| 631 | */ | ||
| 632 |     private function execute_query( $query ) { | ||
| 633 | return $this->db->get_var( $query ); | ||
| 634 | } | ||
| 635 | |||
| 636 | /** | ||
| 637 | * Get attachment id of the image by image url. | ||
| 638 | * | ||
| 639 | 1 | * @since 3.1.7 | |
| 640 | 1 | * @access protected | |
| 641 | * @global object $wpdb | ||
| 642 | * | ||
| 643 | * @param string $image_url URL of an image. | ||
| 644 | * | ||
| 645 | * @return string | ||
| 646 | */ | ||
| 647 |     protected function get_attachment_id( $image_url ) { | ||
| 648 | return $this->execute_query( $this->db->prepare( 'SELECT ID FROM ' . $this->db->posts . ' WHERE guid = %s', $image_url ) ); | ||
| 649 | } | ||
| 650 | |||
| 651 | /** | ||
| 652 | * Get image url of the image by attachment id. | ||
| 653 | * | ||
| 654 | * @since 2.0.0 | ||
| 655 | * @access public | ||
| 656 | 1 | * | |
| 657 | 1 | * @see wp_get_attachment_image_src() | |
| 658 | * | ||
| 659 | 1 | * @param int $attachment_id attachment id of an image. | |
| 660 | * @param string $size size of the image to fetch (thumbnail, medium, full). | ||
| 661 | * | ||
| 662 | * @return string | ||
| 663 | */ | ||
| 664 |     public function get_image_url( $attachment_id, $size = 'full' ) { | ||
| 665 | $image_thumb = wp_get_attachment_image_src( $attachment_id, $size ); | ||
| 666 | |||
| 667 | return empty( $image_thumb ) ? null : $image_thumb[0]; | ||
| 668 | } | ||
| 669 | |||
| 670 | /** | ||
| 671 | * Get image thumbnail url of specific size by attachment id. | ||
| 672 | * | ||
| 673 | * @since 3.7.0 | ||
| 674 | * @access public | ||
| 675 | * | ||
| 676 | 3 | * @see wp_get_attachment_image_src() | |
| 677 | 3 | * | |
| 678 | 3 | * @param int $attachment_id attachment id of an image. | |
| 679 | * @param string $size size of the image to fetch (thumbnail, medium, full). | ||
| 680 | 3 | * | |
| 681 | * @return string|null | ||
| 682 | */ | ||
| 683 |     public function get_image_thumb_by_attachment_id( $attachment_id, $size = 'thumbnail' ) { | ||
| 684 |         if (empty($attachment_id)) { | ||
| 685 | return null; | ||
| 686 | } | ||
| 687 | |||
| 688 | $image_thumb = wp_get_attachment_image_src( $attachment_id, $size ); | ||
| 689 | |||
| 690 | return empty( $image_thumb ) ? null : $image_thumb[0]; | ||
| 691 | } | ||
| 692 | |||
| 693 | 5 | /** | |
| 694 | 5 | * Get image thumbnail url of specific size by image url. | |
| 695 | * | ||
| 696 | 5 | * @since 2.0.0 | |
| 697 | * @access public | ||
| 698 | * | ||
| 699 | 4 | * @see get_image_id() | |
| 700 | 4 | * @see wp_get_attachment_image_src() | |
| 701 | * | ||
| 702 | 4 | * @param string $image_url url of an image. | |
| 703 | 1 | * @param string $size size of the image to fetch (thumbnail, medium, full). | |
| 704 | 1 | * | |
| 705 | 4 | * @return string | |
| 706 | */ | ||
| 707 | 5 |     public function get_image_thumb( $image_url, $size = 'thumbnail' ) { | |
| 708 | $attachment_id = $this->get_image_id( $image_url ); | ||
| 709 | $image_thumb = wp_get_attachment_image_src( $attachment_id, $size ); | ||
| 710 | |||
| 711 | return empty( $image_thumb ) ? null : $image_thumb[0]; | ||
| 712 | } | ||
| 713 | |||
| 714 | /** | ||
| 715 | * Gets attachment id from given image url. | ||
| 716 | * | ||
| 717 | * @param string $image_url url of an image. | ||
| 718 | * | ||
| 719 | * @since 2.0.0 | ||
| 720 | 1 | * @access public | |
| 721 | 1 | * | |
| 722 | * @return int|null attachment id of an image | ||
| 723 | */ | ||
| 724 |     public function get_image_id( $image_url ) { | ||
| 725 | $attachment_id = $this->get_attachment_id( $image_url ); | ||
| 726 | |||
| 727 |         if ( is_null( $attachment_id ) ) { | ||
| 728 | // check if the image is edited image. | ||
| 729 | // and try to get the attachment id. | ||
| 730 | $image_url = str_replace( $this->upload_url . '/', '', $image_url ); | ||
| 731 | $row = $this->execute_query( $this->db->prepare( 'SELECT post_id FROM ' . $this->db->postmeta . ' WHERE meta_key = %s AND meta_value = %s', '_wp_attached_file', $image_url ) ); | ||
| 732 | |||
| 733 |             if ( ! is_null( $row ) ) { | ||
| 734 | 1 | $attachment_id = $row; | |
| 735 | 1 | } | |
| 736 | } | ||
| 737 | |||
| 738 | return $attachment_id; | ||
| 739 | } | ||
| 740 | |||
| 741 | /** | ||
| 742 | * Get image title. | ||
| 743 | * | ||
| 744 | * @since 2.0.0 | ||
| 745 | * @access public | ||
| 746 | * | ||
| 747 | * @param string $image_url URL of an image. | ||
| 748 | 1 | * | |
| 749 | 1 | * @return string | |
| 750 | */ | ||
| 751 |     public function get_image_title( $image_url ) { | ||
| 752 | return $this->execute_query( $this->db->prepare( 'SELECT post_title FROM ' . $this->db->posts . ' WHERE guid = %s', $image_url ) ); | ||
| 753 | } | ||
| 754 | |||
| 755 | /** | ||
| 756 | * Get image title by id. | ||
| 757 | * | ||
| 758 | * @since 2.0.0 | ||
| 759 | * @access public | ||
| 760 | * | ||
| 761 | * @param int $attachment_id Attachment id of an image. | ||
| 762 | 1 | * | |
| 763 | 1 | * @return string | |
| 764 | */ | ||
| 765 |     public function get_image_title_by_id( $attachment_id ) { | ||
| 766 | return $this->execute_query( $this->db->prepare( 'SELECT post_title FROM ' . $this->db->posts . ' WHERE ID = %d', $attachment_id ) ); | ||
| 767 | } | ||
| 768 | |||
| 769 | /** | ||
| 770 | * Get image caption. | ||
| 771 | * | ||
| 772 | * @since 2.0.0 | ||
| 773 | * @access public | ||
| 774 | * | ||
| 775 | * @param string $image_url URL of an image. | ||
| 776 | * | ||
| 777 | * @return string | ||
| 778 | 1 | */ | |
| 779 | 1 |     public function get_image_caption( $image_url ) { | |
| 780 | return $this->execute_query( $this->db->prepare( 'SELECT post_excerpt FROM ' . $this->db->posts . ' WHERE guid = %s', $image_url ) ); | ||
| 781 | 1 | } | |
| 782 | 1 | ||
| 783 | 1 | /** | |
| 784 | 1 | * Get image caption by id. | |
| 785 | * | ||
| 786 | 1 | * @since 2.0.0 | |
| 787 | * @access public | ||
| 788 | * | ||
| 789 | * @param int $attachment_id Attachment id of an image. | ||
| 790 | * | ||
| 791 | * @return string | ||
| 792 | */ | ||
| 793 |     public function get_image_caption_by_id( $attachment_id ) { | ||
| 794 | return $this->execute_query( $this->db->prepare( 'SELECT post_excerpt FROM ' . $this->db->posts . ' WHERE ID = %d', $attachment_id ) ); | ||
| 795 | } | ||
| 796 | |||
| 797 | /** | ||
| 798 | * Get image alternate text. | ||
| 799 | * | ||
| 800 | * @since 2.0.0 | ||
| 801 | 1 | * @access public | |
| 802 | 1 | * | |
| 803 | * @see get_post_meta() | ||
| 804 | 1 | * | |
| 805 | * @param string $image_url URL of an image. | ||
| 806 | * | ||
| 807 | * @return string | ||
| 808 | */ | ||
| 809 |     public function get_image_alt( $image_url ) { | ||
| 810 | $attachment = $this->db->get_col( $this->db->prepare( 'SELECT ID FROM ' . $this->db->posts . ' WHERE guid = %s', $image_url ) ); | ||
| 811 | |||
| 812 | $alt = null; | ||
| 813 |         if ( ! empty( $attachment ) ) { | ||
| 814 | $alt = get_post_meta( $attachment[0], '_wp_attachment_image_alt' ); | ||
| 815 | } | ||
| 816 | |||
| 817 | 1 | return ( is_null( $alt ) || empty( $alt ) ) ? null : $alt[0]; | |
| 818 | 1 | } | |
| 819 | |||
| 820 | /** | ||
| 821 | * Get image alternate text by attachment id. | ||
| 822 | * | ||
| 823 | * @since 2.0.0 | ||
| 824 | * @access public | ||
| 825 | * | ||
| 826 | * @see get_post_meta() | ||
| 827 | * | ||
| 828 | * @param int $attachment_id Attachment id of an image. | ||
| 829 | * | ||
| 830 | * @return string | ||
| 831 | 1 | */ | |
| 832 | 1 |     public function get_image_alt_by_id( $attachment_id ) { | |
| 833 | $alt = get_post_meta( $attachment_id, '_wp_attachment_image_alt' ); | ||
| 834 | |||
| 835 | return empty( $alt ) ? null : $alt[0]; | ||
| 836 | } | ||
| 837 | |||
| 838 | /** | ||
| 839 | * Get image description. | ||
| 840 | * | ||
| 841 | * @since 3.0.0 | ||
| 842 | * @access public | ||
| 843 | * | ||
| 844 | * @param string $image_url URL of an image. | ||
| 845 | 1 | * | |
| 846 | 1 | * @return string | |
| 847 | */ | ||
| 848 |     public function get_image_description( $image_url ) { | ||
| 849 | return $this->execute_query( $this->db->prepare( 'SELECT post_content FROM ' . $this->db->posts . ' WHERE guid = %s', $image_url ) ); | ||
| 850 | } | ||
| 851 | |||
| 852 | /** | ||
| 853 | * Get image description by id. | ||
| 854 | * | ||
| 855 | * @since 3.0.0 | ||
| 856 | * @access public | ||
| 857 | * | ||
| 858 | * @param int $attachment_id attachment id of an image. | ||
| 859 | * | ||
| 860 | * @return string | ||
| 861 | 2 | */ | |
| 862 | 2 |     public function get_image_description_by_id( $attachment_id ) { | |
| 863 | 2 | return $this->execute_query( $this->db->prepare( 'SELECT post_content FROM ' . $this->db->posts . ' WHERE ID = %d', $attachment_id ) ); | |
| 864 | } | ||
| 865 | 2 | ||
| 866 | 2 | /** | |
| 867 | 2 | * Get link to image. | |
| 868 | 2 | * | |
| 869 | 2 | * @since 3.4.0 | |
| 870 | 2 | * @access public | |
| 871 | * | ||
| 872 | 2 | * @param int $attachment_id Attachment id of an image. | |
| 873 | * | ||
| 874 | * @return string|null | ||
| 875 | */ | ||
| 876 |     public function get_link_to_image( $attachment_id ) { | ||
| 877 | return get_post_meta( $attachment_id, '_dfi_link_to_image', true ); | ||
| 878 | } | ||
| 879 | |||
| 880 | /** | ||
| 881 | * Get all attachment ids of the post. | ||
| 882 | * | ||
| 883 | * @since 2.0.0 | ||
| 884 | * @access public | ||
| 885 | 6 | * | |
| 886 | 6 | * @see get_post_meta() | |
| 887 | 5 | * | |
| 888 | * @param int $post_id id of the current post. | ||
| 889 | * | ||
| 890 | 3 | * @return array | |
| 891 | */ | ||
| 892 | 3 |     public function get_post_attachment_ids( $post_id ) { | |
| 893 | $dfi_images = get_post_meta( $post_id, 'dfiFeatured', true ); | ||
| 894 | $ret_val = array(); | ||
| 895 | |||
| 896 | View Code Duplication |         if ( ! empty( $dfi_images ) && is_array( $dfi_images ) ) { | |
| 0 ignored issues–
                            show This code seems to be duplicated across your project.
                                             Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation. You can also find more detailed suggestions in the “Code” section of your repository.  Loading history... | |||
| 897 |             foreach ( $dfi_images as $dfi_image ) { | ||
| 898 | $dfi_image_full = $this->separate( $dfi_image, 'full' ); | ||
| 899 | $ret_val[] = (int) $this->get_image_id( $this->upload_url . $dfi_image_full ); | ||
| 900 | } | ||
| 901 | } | ||
| 902 | |||
| 903 | return $ret_val; | ||
| 904 | } | ||
| 905 | |||
| 906 | /** | ||
| 907 | * Get real post id. | ||
| 908 | 2 | * | |
| 909 | 2 | * @since 3.6.0 | |
| 910 | * @access protected | ||
| 911 | 2 | * | |
| 912 | * @param int|null $post_id Post id. | ||
| 913 | 2 | * | |
| 914 | * @return int|null | ||
| 915 | */ | ||
| 916 |     protected function get_real_post_id( $post_id = null ) { | ||
| 917 |         if ( ! is_null( $post_id ) && is_numeric( $post_id ) ) { | ||
| 918 | return $post_id; | ||
| 919 | } | ||
| 920 | |||
| 921 | global $post; | ||
| 922 | |||
| 923 | return $post->ID; | ||
| 924 | } | ||
| 925 | |||
| 926 | /** | ||
| 927 | * Fetches featured image data of nth position. | ||
| 928 | * | ||
| 929 | 1 | * @since 3.0.0 | |
| 930 | 1 | * @access public | |
| 931 | 1 | * | |
| 932 | * @see get_featured_images() | ||
| 933 | * | ||
| 934 | 1 | * @param int $position Position of the featured image. | |
| 935 | * @param int $post_id Current post id. | ||
| 936 | 1 | * | |
| 937 | * @return array if found, null otherwise. | ||
| 938 | */ | ||
| 939 |     public function get_nth_featured_image( $position, $post_id = null ) { | ||
| 940 | $post_id = $this->get_real_post_id( ( $post_id ) ); | ||
| 941 | |||
| 942 | $featured_images = $this->get_featured_images( $post_id ); | ||
| 943 | |||
| 944 | return isset( $featured_images[ $position - 2 ] ) ? $featured_images[ $position - 2 ] : null; | ||
| 945 | } | ||
| 946 | |||
| 947 | /** | ||
| 948 | * Check if the image is attached with the particular post. | ||
| 949 | * | ||
| 950 | * @since 2.0.0 | ||
| 951 | 7 | * @access public | |
| 952 | 7 | * | |
| 953 | 7 | * @see get_post_attachment_ids() | |
| 954 | 7 | * | |
| 955 | * @param int $attachment_id Attachment id of an image. | ||
| 956 | 7 | * @param int $post_id Current post id. | |
| 957 | 7 | * | |
| 958 | * @return bool | ||
| 959 | 7 | */ | |
| 960 | 7 |     public function is_attached( $attachment_id, $post_id ) { | |
| 961 | 7 |         if ( empty( $attachment_id ) ) { | |
| 962 | 7 | return false; | |
| 963 | } | ||
| 964 | |||
| 965 | 7 | $attachment_ids = $this->get_post_attachment_ids( $post_id ); | |
| 966 | 7 | ||
| 967 | 7 | return in_array( $attachment_id, $attachment_ids, true ) ? true : false; | |
| 968 | 7 | } | |
| 969 | |||
| 970 | /** | ||
| 971 | * Retrieve featured images for specific post(s). | ||
| 972 | 7 | * | |
| 973 | 7 | * @since 2.0.0 | |
| 974 | 7 | * @access public | |
| 975 | * | ||
| 976 | 7 | * @see get_post_meta() | |
| 977 | * | ||
| 978 | * @param int $post_id id of the current post. | ||
| 979 | * | ||
| 980 | * @return array | ||
| 981 | */ | ||
| 982 |     public function get_featured_images( $post_id = null ) { | ||
| 983 | $post_id = $this->get_real_post_id( $post_id ); | ||
| 984 | $dfi_images = get_post_meta( $post_id, 'dfiFeatured', true ); | ||
| 985 | $ret_images = array(); | ||
| 986 | |||
| 987 |         if ( ! empty( $dfi_images ) && is_array( $dfi_images ) ) { | ||
| 988 | $dfi_images = array_filter( $dfi_images ); | ||
| 989 | 2 | ||
| 990 | $count = 0; | ||
| 991 | 2 |             foreach ( $dfi_images as $dfi_image ) { | |
| 992 | 2 | $dfi_image_trimmed = $this->separate( $dfi_image ); | |
| 993 | $dfi_image_full = $this->separate( $dfi_image, 'full' ); | ||
| 994 | |||
| 995 | 2 |                 try { | |
| 996 | $ret_images[ $count ]['thumb'] = $this->get_real_upload_path( $dfi_image_trimmed ); | ||
| 997 | $ret_images[ $count ]['full'] = $this->get_real_upload_path( $dfi_image_full ); | ||
| 998 | $ret_images[ $count ]['attachment_id'] = $this->get_image_id( $ret_images[ $count ]['full'] ); | ||
| 999 |                 } catch ( Exception $e ) { | ||
| 1000 | /* Ignore the exception and continue with other featured images */ | ||
| 1001 | } | ||
| 1002 | |||
| 1003 | $count ++; | ||
| 1004 | } | ||
| 1005 | } | ||
| 1006 | |||
| 1007 | return $ret_images; | ||
| 1008 | } | ||
| 1009 | |||
| 1010 | 2 | /** | |
| 1011 | 2 | * Check to see if the upload url is already available in path. | |
| 1012 | 2 | * | |
| 1013 | 2 | * @since 3.1.14 | |
| 1014 | * @access protected | ||
| 1015 | 2 | * | |
| 1016 | * @param string $img Uploaded image. | ||
| 1017 | 2 | * | |
| 1018 | 2 | * @return string | |
| 1019 | 2 | */ | |
| 1020 | 2 |     protected function get_real_upload_path( $img ) { | |
| 1021 | // check if upload path is already attached. | ||
| 1022 | 2 |         if ( false !== strpos( $img, $this->upload_url ) || preg_match( '/https?:\/\//', $img ) ) { | |
| 1023 | 2 | return $img; | |
| 1024 | } | ||
| 1025 | 2 | ||
| 1026 | return $this->upload_url . $img; | ||
| 1027 | } | ||
| 1028 | |||
| 1029 | /** | ||
| 1030 | * Retrieve featured images for specific post(s) including the default Featured Image. | ||
| 1031 | * | ||
| 1032 | * @since 3.1.7 | ||
| 1033 | * @access public | ||
| 1034 | * | ||
| 1035 | * @see $this->get_featured_images() | ||
| 1036 | * | ||
| 1037 | * @param int $post_id Current post id. | ||
| 1038 | * | ||
| 1039 | * @return array An array of images or an empty array on failure | ||
| 1040 | */ | ||
| 1041 |     public function get_all_featured_images( $post_id = null ) { | ||
| 1042 | $post_id = $this->get_real_post_id( $post_id ); | ||
| 1043 | $thumbnail_id = get_post_thumbnail_id( $post_id ); | ||
| 1044 | $all_images = array(); | ||
| 1045 | |||
| 1046 |         if ( ! empty( $thumbnail_id ) ) { | ||
| 1047 | $featured_image = array( | ||
| 1048 | 'thumb' => wp_get_attachment_thumb_url( $thumbnail_id ), | ||
| 1049 | 'full' => wp_get_attachment_url( $thumbnail_id ), | ||
| 1050 | 'attachment_id' => $thumbnail_id, | ||
| 1051 | ); | ||
| 1052 | |||
| 1053 | $all_images[] = $featured_image; | ||
| 1054 | } | ||
| 1055 | |||
| 1056 | return array_merge( $all_images, $this->get_featured_images( $post_id ) ); | ||
| 1057 | } | ||
| 1058 | |||
| 1059 | /** | ||
| 1060 | * Load the plugin's textdomain hooked to 'plugins_loaded'. | ||
| 1061 | * | ||
| 1062 | * @since 1.0.0 | ||
| 1063 | * @access public | ||
| 1064 | * | ||
| 1065 | * @see load_plugin_textdomain() | ||
| 1066 | * @see plugin_basename() | ||
| 1067 | * @action plugins_loaded | ||
| 1068 | * | ||
| 1069 | * @codeCoverageIgnore | ||
| 1070 | * | ||
| 1071 | * @return void | ||
| 1072 | */ | ||
| 1073 |     public function load_plugin_textdomain() { | ||
| 1074 | load_plugin_textdomain( | ||
| 1075 | self::TEXT_DOMAIN, | ||
| 1076 | false, | ||
| 1077 | dirname( plugin_basename( __FILE__ ) ) . '/languages/' | ||
| 1078 | ); | ||
| 1079 | } | ||
| 1080 | } | ||
| 1081 | |||
| 1082 | // Sponsors who support this plugin. | ||
| 1083 | include 'sponsors.php'; | ||
| 1084 | |||
| 1085 | /** | ||
| 1086 | * Instantiate the main class. | ||
| 1087 | * | ||
| 1088 | * @since 1.0.0 | ||
| 1089 | * @access public | ||
| 1090 | * | ||
| 1091 |  * @var object $dynamic_featured_image holds the instantiated class {@uses Dynamic_Featured_Image} | ||
| 1092 | */ | ||
| 1093 | global $dynamic_featured_image; | ||
| 1094 | $dynamic_featured_image = new Dynamic_Featured_Image(); | ||
| 1095 | 
 
                                
Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.
You can also find more detailed suggestions in the “Code” section of your repository.