मीडिया मोडल में रिफ्रेश को कैसे ट्रिगर करें


12

मैं एक ऐसा प्लगइन विकसित कर रहा हूं, जो मीडिया मोडल में एक नया टैब जोड़ता है, और मुझे अटैचमेंट टैब के रिफ्रेश को ट्रिगर करने का एक तरीका जानने की जरूरत है ताकि यह नए जोड़े गए अटैचमेंट को दिखाता है। यह वह कोड है जिसका मैं उपयोग कर रहा हूं:

wp.media.view.Toolbar.Custom = wp.media.view.Toolbar.extend({
    initialize: function() {
        _.defaults( this.options, {
            event: 'custom_event',
            close: false,
            items: {
                custom_event: {
                    text: wp.media.view.l10n.customButton,
                    style: 'primary',
                    priority: 80,
                    requires: false,
                    click: this.addAttachment
                }
            }
        });

        wp.media.view.Toolbar.prototype.initialize.apply( this, arguments );
    },

    // triggered when the button is clicked
    addAttachment: function(){
        this.controller.state().addAttachment();
        this.controller.setState( 'insert' );
        // I NEED TO TRIGGER A REFRESH OF THE ATTACHMENTS TAB HERE
    }
});

किसी भी सहायता की सराहना की जाएगी। मीडिया मोडल डॉक्यूमेंटेशन लगभग न के बराबर है।

धन्यवाद


IIRC वे सिर्फ बैकबोन / अंडरस्कोर व्यूज हैं। दूसरे शब्दों में, जब आप मॉडल को अपडेट करते हैं, तो उसे अपने आप से दृश्य को अपडेट करना चाहिए क्योंकि "मॉडल व्यू" को ट्रिगर करना चाहिए।
kaiser

खैर, this.controller.state().addAttachment()फ़ंक्शन सिर्फ AJAX कॉल का उपयोग कर wp.media.post()रहा है, इसलिए मुझे इस AJAX कॉल के बाद कहीं न कहीं एक काल्पनिक "मॉडल अपडेटेड" घटना को ट्रिगर करना होगा। कोई विचार?
लेमन

"कोई विचार?" - वर्तमान में नहीं। यह कुछ ऐसा है जहां मुझे कोर के माध्यम से पढ़ने के लिए कुछ समय निवेश करना होगा (जो अब मेरे पास नहीं है)। आपकी टिप्पणी के बारे में: इसमें मार्कडाउन उपलब्ध है (नीचे "टिप्पणी जोड़ें" बटन देखें)।
कैसर

जवाबों:


2

आप इस लिंक को https://codex.wordpress.org/Javascript_Reference/wp.media चेकआउट कर सकते हैं

jQuery(function($){

  // Set all variables to be used in scope
  var frame,
      metaBox = $('#meta-box-id.postbox'), // Your meta box id here
      addImgLink = metaBox.find('.upload-custom-img'),
      delImgLink = metaBox.find( '.delete-custom-img'),
      imgContainer = metaBox.find( '.custom-img-container'),
      imgIdInput = metaBox.find( '.custom-img-id' );

  // ADD IMAGE LINK



addImgLink.on( 'click', function( event ){

    event.preventDefault();

    // If the media frame already exists, reopen it.
    if ( frame ) {
      frame.open();
      return;
    }

    // Create a new media frame
    frame = wp.media({
      title: 'Select or Upload Media Of Your Chosen Persuasion',
      button: {
        text: 'Use this media'
      },
      multiple: false  // Set to true to allow multiple files to be selected
    });


    // When an image is selected in the media frame...
    frame.on( 'select', function() {

      // Get media attachment details from the frame state
      var attachment = frame.state().get('selection').first().toJSON();

      // Send the attachment URL to our custom image input field.
      imgContainer.append( '<img src="'+attachment.url+'" alt="" style="max-width:100%;"/>' );

      // Send the attachment id to our hidden input
      imgIdInput.val( attachment.id );

      // Hide the add image link
      addImgLink.addClass( 'hidden' );

      // Unhide the remove image link
      delImgLink.removeClass( 'hidden' );
    });

    // Finally, open the modal on click
    frame.open();
  });


  // DELETE IMAGE LINK
  delImgLink.on( 'click', function( event ){

    event.preventDefault();

    // Clear out the preview image
    imgContainer.html( '' );

    // Un-hide the add image link
    addImgLink.removeClass( 'hidden' );

    // Hide the delete image link
    delImgLink.addClass( 'hidden' );

    // Delete the image id from the hidden input
    imgIdInput.val( '' );

  });

});

1

कोशिश करें:

wp.media.editor.get(wpActiveEditor).views._views[".media-frame-content"][0].views._views[""][1].collection.props.set({ignore:(+(new Date()))})

लगता है कि वहाँ एक आसान तरीका होना चाहिए, लेकिन इस बीच में मेरे लिए काम करता है!

इसे करने का एक और बेहतर तरीका:

wp.media.frame.content.get('gallery').collection.props.set({‌​ignore: (+ new Date())});, 

इस मामले में मैं गैलरी टैब को ताज़ा कर रहा हूँ।

उपरोक्त दोनों कोड आज़माएं और देखें कि कौन सा आपके लिए सबसे अच्छा काम करता है।


1
यह मेरे लिए मददगार था! धन्यवाद।
सिद्धेश शिरोडकर 10

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