गैलरी के लिए मीडिया प्रबंधक बढ़ाएँ


29

मैं वर्डप्रेस 3.5 के बाद गैलरी दृश्य पर मीडिया संपादक को बढ़ाना चाहूंगा।
मैं दाईं ओर एक नया चुनिंदा फ़ील्ड जोड़ना चाहता हूं और चयनित मानों को गैलरी शोर्ट में भेजना चाहता हूं।

यहां छवि विवरण दर्ज करें

मुझे लगता है, समारोह wp.media.galleryमें wp-includes/js/media-editor.jsगैलरी शोर्ट डालने के लिए डिफ़ॉल्ट कार्य है।

मैं एक नया पैरामीटर जोड़ना चाहता हूं और पैरामीटर के मान मीडिया मैनेजर के अंदर चुनिंदा फ़ील्ड से आते हैं।

मैंने अलग-अलग स्रोतों से खेला है, खासकर इस सवाल से , लेकिन बैकबोन मेरे लिए बहुत नया है और मुझे समझ नहीं आता कि यह कैसे काम करता है। मैंने हुक के साथ भी खेला है print_media_templates, लेकिन मीडिया के दृष्टिकोण पर कोई परिणाम नहीं है।

मुझे किन हुक का उपयोग करना चाहिए?

जवाबों:


21

एक छोटा स्रोत, शायद समाधान बनाने के लिए एक प्लगइन के लिए। पहले php भाग में, मीडिया मैनेजर के अंदर बटन के लिए जावास्क्रिप्ट शामिल है। अधिक प्रयोग करने योग्य उत्तर है, लेकिन @One ट्रिक पोनी का उत्तर सही दिशा और JS समाधान था।

छवि पर परिणाम देखें: यहां छवि विवरण दर्ज करें

परिणामी शोर्ट, यदि आकार डिफ़ॉल्ट आकार नहीं: यहां छवि विवरण दर्ज करें

हुक print_media_templatesबटन, मार्कअप को शामिल करने के लिए सही जगह है। इसके अलावा एक स्क्रिप्ट की गणना थी, नियंत्रणों को जोड़ने के लिए समाधान है।

class Custom_Gallery_Setting {
    /**
     * Stores the class instance.
     *
     * @var Custom_Gallery_Setting
     */
    private static $instance = null;


    /**
     * Returns the instance of this class.
     *
     * It's a singleton class.
     *
     * @return Custom_Gallery_Setting The instance
     */
    public static function get_instance() {

        if ( ! self::$instance )
            self::$instance = new self;

        return self::$instance;
    }

    /**
     * Initialises the plugin.
     */
    public function init_plugin() {

        $this->init_hooks();
    }

    /**
     * Initialises the WP actions.
     *  - admin_print_scripts
     */
    private function init_hooks() {

        add_action( 'wp_enqueue_media', array( $this, 'wp_enqueue_media' ) );
        add_action( 'print_media_templates', array( $this, 'print_media_templates' ) );
    }


    /**
     * Enqueues the script.
     */
    public function wp_enqueue_media() {

        if ( ! isset( get_current_screen()->id ) || get_current_screen()->base != 'post' )
            return;

        wp_enqueue_script(
            'custom-gallery-settings',
            plugins_url( 'js/custom-gallery-setting.js', __FILE__ ),
            array( 'media-views' )
        );

    }

    /**
     * Outputs the view template with the custom setting.
     */
    public function print_media_templates() {

        if ( ! isset( get_current_screen()->id ) || get_current_screen()->base != 'post' )
            return;

        ?>
        <script type="text/html" id="tmpl-custom-gallery-setting">
            <label class="setting">
                <span>Size</span>
                <select class="type" name="size" data-setting="size">
                    <?php

                    $sizes = apply_filters( 'image_size_names_choose', array(
                        'thumbnail' => __( 'Thumbnail' ),
                        'medium'    => __( 'Medium' ),
                        'large'     => __( 'Large' ),
                        'full'      => __( 'Full Size' ),
                    ) );

                    foreach ( $sizes as $value => $name ) { ?>
                        <option value="<?php echo esc_attr( $value ); ?>" <?php selected( $value, 'thumbnail' ); ?>>
                            <?php echo esc_html( $name ); ?>
                        </option>
                    <?php } ?>
                </select>
            </label>
        </script>
        <?php
    }

}

// Put your hands up...
add_action( 'admin_init', array( Custom_Gallery_Setting::get_instance(), 'init_plugin' ), 20 );

पालन ​​स्रोत जावास्क्रिप्ट है, उदाहरण के लिए php, फ़ाइल में स्रोत custom-gallery-setting.js

/**
 * Custom Gallery Setting
 */
( function( $ ) {
    var media = wp.media;

    // Wrap the render() function to append controls
    media.view.Settings.Gallery = media.view.Settings.Gallery.extend({
        render: function() {
            media.view.Settings.prototype.render.apply( this, arguments );

            // Append the custom template
            this.$el.append( media.template( 'custom-gallery-setting' ) );

            // Save the setting
            media.gallery.defaults.size = 'thumbnail';
            this.update.apply( this, ['size'] );
            return this;
        }
    } );
} )( jQuery );

4
वाहवाही! ऐसा लगता है कि वर्डप्रेस डेवलपमेंट कोर डेवलपर्स की तुलना में तेज दर से नई मीडिया लाइब्रेरी के बारे में एक ज्ञान-आधार का निर्माण कर रहा है;) और, कैसे नहीं, @OneTrickPony एक बार फिर अपने जादू की थैली चाल का एक और खुलासा करता है, दोनों को यश!
ब्रासोफिलो

बहुत खुबस। अनुवर्ती प्रश्न: शोर्ट में डिफ़ॉल्ट विशेषताओं को दबाने का एक आसान तरीका है? तो [gallery type="thumbnail" ids="1,2"]बन जाता है [gallery ids="1,2"]? मैं एक प्लगइन के लिए एक कस्टम विशेषता जोड़ रहा हूँ वैकल्पिक रूप से एक स्लाइड शो में गैलरी बारी। मैं उस विशेषता को दबाना चाहूंगा जब वह सामान्य WP गैलरी दिखाने के लिए कह रही हो। तो प्लगइन के डी-एक्टिवेशन पर, यह कम cruft को पीछे छोड़ देता है।
किचिन

मुझे लगता है कि इस विषय के बारे में एक नया सवाल जोड़ने का एक बेहतर तरीका है। शोर्ट q / a के बाहर है।
bueltge


@ ब्यूल्ट, क्या मैं आपसे एक कस्टम फील्ड से जुड़े सवाल पर नज़र डाल सकता हूँ: wordpress.stackexchange.com/questions/265852/… ?
इस्तियाक अहमद

19

यदि आप वास्तव में बैकबोन टेम्प्लेट का उपयोग करना चाहते हैं, तो आपका हुक सही है।

मैं template()गैलरी सेटिंग्स दृश्य के लिए फ़ंक्शन को ओवरराइड करने के बजाय HTML टेम्पलेट सम्मिलित करने के लिए jQuery का उपयोग करूंगा । लेकिन मुझे लगता है कि आप पहले से ही जानते हैं, इसलिए मैं बैकबोन संस्करण पोस्ट करूंगा:

add_action('print_media_templates', function(){

  // define your backbone template;
  // the "tmpl-" prefix is required,
  // and your input field should have a data-setting attribute
  // matching the shortcode name
  ?>
  <script type="text/html" id="tmpl-my-custom-gallery-setting">
    <label class="setting">
      <span><?php _e('My setting'); ?></span>
      <select data-setting="my_custom_attr">
        <option value="foo"> Foo </option>
        <option value="bar"> Bar </option>        
        <option value="default_val"> Default Value </option>        
      </select>
    </label>
  </script>

  <script>

    jQuery(document).ready(function(){

      // add your shortcode attribute and its default value to the
      // gallery settings list; $.extend should work as well...
      _.extend(wp.media.gallery.defaults, {
        my_custom_attr: 'default_val'
      });

      // merge default gallery settings template with yours
      wp.media.view.Settings.Gallery = wp.media.view.Settings.Gallery.extend({
        template: function(view){
          return wp.media.template('gallery-settings')(view)
               + wp.media.template('my-custom-gallery-setting')(view);
        }
      });

    });

  </script>
  <?php

});
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.