WordPress.org

Make WordPress Core

Ticket #28619: 28619.3.patch

File 28619.3.patch, 7.0 KB (added by Fab1en, 6 years ago)
  • wp-includes/media.php

    diff --git wp-includes/media.php wp-includes/media.php
    index 974aa79..270fe54 100644
    function wp_audio_shortcode( $attr, $content = '' ) { 
    15711571                $attr_strings[] = $k . '="' . esc_attr( $v ) . '"';
    15721572        }
    15731573
    1574         $html = '';
    1575         if ( 'mediaelement' === $library && 1 === $instances )
    1576                 $html .= "<!--[if lt IE 9]><script>document.createElement('audio');</script><![endif]-->\n";
     1574        /**
     1575         * Filters the HTML added inside the audio shortcode output.
     1576         *
     1577         * Give the possibility to insert some HTML code before the <audio> tag
     1578         * generated by an audio shortcode.
     1579         *
     1580         * @since 4.0.0
     1581         *
     1582         * @param string $html      Empty variable to be replaced with the HTML snippet to insert before the <audio> tag.
     1583         * @param string $library   Media library used for the audio shortcode.
     1584         * @param int    $instances Unique numeric ID of this audio shortcode instance.
     1585         */
     1586        $html = apply_filters('wp_audio_shortcode_pre_html', '', $library, $instances);
    15771587        $html .= sprintf( '<audio %s controls="controls">', join( ' ', $attr_strings ) );
    15781588
    15791589        $fileurl = '';
    function wp_audio_shortcode( $attr, $content = '' ) { 
    15881598                }
    15891599        }
    15901600
    1591         if ( 'mediaelement' === $library )
    1592                 $html .= wp_mediaelement_fallback( $fileurl );
     1601        /**
     1602         * Filters the HTML added inside the audio shortcode output.
     1603         *
     1604         * Give the possibility to insert some HTML code inside the <audio> tag
     1605         * generated by an audio shortcode.
     1606         *
     1607         * @since 4.0.0
     1608         *
     1609         * @param string $html    Empty variable to be replaced with the HTML snippet to append into the <audio> tag.
     1610         * @param string $library Media library used for the audio shortcode.
     1611         * @param string $fileurl The URL of the audio file.
     1612         * @param int    $post_id Post ID.
     1613         */
     1614        $html .= apply_filters('wp_audio_shortcode_inside_html', '', $library, $fileurl, $post_id);
    15931615        $html .= '</audio>';
    15941616
    15951617        /**
    function wp_audio_shortcode( $attr, $content = '' ) { 
    16071629}
    16081630add_shortcode( 'audio', 'wp_audio_shortcode' );
    16091631
     1632function wp_mediaelement_audio_shortcode_pre_html($html, $library, $instances) {
     1633        if ( 'mediaelement' === $library && 1 === $instances )
     1634                $html .= "<!--[if lt IE 9]><script>document.createElement('audio');</script><![endif]-->\n";
     1635        return $html;
     1636}
     1637add_filter('wp_audio_shortcode_pre_html', 'wp_mediaelement_audio_shortcode_pre_html', 10, 3);
     1638
     1639function wp_mediaelement_audio_shortcode_inside_html($html, $library, $fileurl, $post_id) {
     1640        if ( 'mediaelement' === $library )
     1641                $html .= wp_mediaelement_fallback( $fileurl );
     1642        return $html;
     1643}
     1644add_filter('wp_audio_shortcode_inside_html', 'wp_mediaelement_audio_shortcode_inside_html', 10, 4);
     1645
    16101646/**
    16111647 * Return a filtered list of WP-supported video formats
    16121648 *
    function wp_video_shortcode( $attr, $content = '' ) { 
    17111747                }
    17121748        }
    17131749
    1714         $yt_pattern = '#^https?://(:?www\.)?(:?youtube\.com/watch|youtu\.be/)#';
     1750        $ext_providers_patterns = apply_filters( 'wp_video_external_providers', array(
     1751                'youtube' => array(
     1752                        'pattern' => '#^https?://(:?www\.)?(:?youtube\.com/watch|youtu\.be/)#',
     1753                        'mimetype'    => 'video/youtube',
     1754                ),
     1755        ));
    17151756
    17161757        $primary = false;
     1758        $match = false;
    17171759        if ( ! empty( $src ) ) {
    1718                 if ( ! preg_match( $yt_pattern, $src ) ) {
     1760                foreach($ext_providers_patterns as $provider) {
     1761                        if( preg_match( $provider['pattern'], $src ) ) {
     1762                                $match = true;
     1763                                break;
     1764                        }
     1765                }
     1766                if ( ! $match ) {
    17191767                        $type = wp_check_filetype( $src, wp_get_mime_types() );
    17201768                        if ( ! in_array( strtolower( $type['ext'] ), $default_types ) ) {
    17211769                                return sprintf( '<a class="wp-embedded-video" href="%s">%s</a>', esc_url( $src ), esc_html( $src ) );
    function wp_video_shortcode( $attr, $content = '' ) { 
    17881836                $attr_strings[] = $k . '="' . esc_attr( $v ) . '"';
    17891837        }
    17901838
    1791         $html = '';
    1792         if ( 'mediaelement' === $library && 1 === $instances )
    1793                 $html .= "<!--[if lt IE 9]><script>document.createElement('video');</script><![endif]-->\n";
     1839        /**
     1840         * Filters the HTML added before the video shortcode output.
     1841         *
     1842         * Give the possibility to insert some HTML code before the <video> tag
     1843         * generated by a video shortcode.
     1844         *
     1845         * @since 4.0.0
     1846         *
     1847         * @param string $html      Empty variable to be replaced with the HTML snippet to insert before the <video> tag.
     1848         * @param string $library   Media library used for the video shortcode.
     1849         * @param int    $instances Unique numeric ID of this video shortcode instance.
     1850         */
     1851        $html = apply_filters('wp_video_shortcode_pre_html', '', $library, $instances);
    17941852        $html .= sprintf( '<video %s controls="controls">', join( ' ', $attr_strings ) );
    17951853
    17961854        $fileurl = '';
    function wp_video_shortcode( $attr, $content = '' ) { 
    18001858                        if ( empty( $fileurl ) )
    18011859                                $fileurl = $$fallback;
    18021860
    1803                         if ( 'src' === $fallback && preg_match( $yt_pattern, $src ) ) {
    1804                                 $type = array( 'type' => 'video/youtube' );
    1805                         } else {
     1861                        $match = false;
     1862                        foreach( $ext_providers_patterns as $provider ) {
     1863                                if( 'src' === $fallback && preg_match( $provider['pattern'], $src ) ) {
     1864                                        $match = true;
     1865                                        $type = array( 'type' => $provider['mimetype'] );
     1866                                        break;
     1867                                }
     1868                        }
     1869                        if ( ! $match ) {
    18061870                                $type = wp_check_filetype( $$fallback, wp_get_mime_types() );
    18071871                        }
    18081872                        $url = add_query_arg( '_', $instances, $$fallback );
    function wp_video_shortcode( $attr, $content = '' ) { 
    18171881                $html .= trim( $content );
    18181882        }
    18191883
    1820         if ( 'mediaelement' === $library )
    1821                 $html .= wp_mediaelement_fallback( $fileurl );
     1884        /**
     1885         * Filters the HTML added inside the video shortcode output.
     1886         *
     1887         * Give the possibility to insert some HTML code inside the <video> tag
     1888         * generated by a video shortcode.
     1889         *
     1890         * @since 4.0.0
     1891         *
     1892         * @param string $html    Empty variable to be replaced with the HTML snippet to append into the <video> tag.
     1893         * @param string $library Media library used for the video shortcode.
     1894         * @param string $fileurl The URL of the video file.
     1895         * @param int    $post_id Post ID.
     1896         */
     1897        $html .= apply_filters('wp_video_shortcode_inside_html', '', $library, $fileurl, $post_id);
    18221898        $html .= '</video>';
    18231899
    18241900        $html = sprintf( '<div style="width: %dpx; max-width: 100%%;" class="wp-video">%s</div>', $width, $html );
    function wp_video_shortcode( $attr, $content = '' ) { 
    18381914}
    18391915add_shortcode( 'video', 'wp_video_shortcode' );
    18401916
     1917function wp_mediaelement_video_shortcode_pre_html($html, $library, $instances) {
     1918        if ( 'mediaelement' === $library && 1 === $instances )
     1919                $html .= "<!--[if lt IE 9]><script>document.createElement('video');</script><![endif]-->\n";
     1920        return $html;
     1921}
     1922add_filter('wp_video_shortcode_pre_html', 'wp_mediaelement_video_shortcode_pre_html', 10, 3);
     1923
     1924function wp_mediaelement_video_shortcode_inside_html($html, $library, $fileurl, $post_id) {
     1925        if ( 'mediaelement' === $library )
     1926                $html .= wp_mediaelement_fallback( $fileurl );
     1927        return $html;
     1928}
     1929add_filter('wp_video_shortcode_inside_html', 'wp_mediaelement_video_shortcode_inside_html', 10, 4);
     1930
    18411931/**
    18421932 * Display previous image link that has the same post parent.
    18431933 *