web-dev-qa-db-ja.com

カスタムの3.5メディアアップローダーに[URLから挿入]タブを追加する方法はありますか

ボタンがクリックされたときにこのJavaScriptを実行してWP 3.5メディアアップローダをウィジェットに挿入しました。

var frame = wp.media( {
    title       : 'Widget Uploader',
    multiple    : false,
    library     : { type : 'image' },
    button      : { text : 'Select Image' }
} );

frame.on( 'close', function() {
    var attachments = frame.state().get( 'selection' ).toJSON();
    imageWidget.render( widget_id, widget_id_string, attachments[0] );
} );

frame.open();
return false;

それは私に "Upload Files"と "Media Library"タブを持っているモーダルを与えます、しかし私はあなたが投稿を編集している間に "Add Media"ボタンをクリックするときあなたが得る "Insert From URL"タブを持ってほしいです/ページ。

enter image description here

私は数時間かけてウェブを調べたり、ソースコードを読んだり、 Daryl Koopersmithのアップローダのバックエンドでのプレゼンテーションを見たりしていました それを理解することができませんでした。

誰かが私を正しい方向に向けることができますか?それを含めるためにwp.media()に渡すことができるパラメータはありますか、それともそれを含む組み込みのビュー/モデルのいずれかを使用する必要がありますか?

16
Ian Dunn

私は同様の理由でソースコードを調べています。デフォルトの "選択"フレームに "添付ファイルの表示設定"を追加したいのですが。私が言うことができる限りでは、これは私たち全員が望むように、wp.media()にパラメータを渡すことによって行うことはできません。 wp.​​mediaには現在2つのフレーム( "post"と "select")があり、それらに付随するビューはプリセットされています。

私が今見ているアプローチは私が必要とするビューの部分を含む新しいフレーム( "select"フレームに基づいて)を作成するためにmedia.view.mediaFrameを拡張することです。これがうまくいったら、コードを投稿します。

編集:

イアン、私は働きたい機能を手に入れました、そしてあなたのものを見つけるのに時間がかかりました。 wp.​​media()は可能な限りモジュラーではありません。これはframeの 'select'と 'post'の値だけを受け入れます。 'select'がデフォルトですので、新しいフレームオブジェクトを作成することはできません。代わりに、2つのフレームオブジェクトのうちの1つを拡張する必要があり(これはすべて/wp-includes/js/media-views.jsにあります)、これもまた不格好です。 UIの一部を追加することは、いくつかのステップからなるプロセスです。あなたはSelectから始めて追加することもできますが、あなたのためにPostフレームのコードから始めてギャラリーのものを取り除きました。これは私のコードですが、動作はしていますが、あまりテストされていません。合理化の余地もあるでしょう。

wp.media.view.MediaFrame.Select = wp.media.view.MediaFrame.Select.extend({

            initialize: function() {
                wp.media.view.MediaFrame.prototype.initialize.apply( this, arguments );

                _.defaults( this.options, {
                    multiple:  true,
                    editing:   false,
                    state:    'insert'
                });

                this.createSelection();
                this.createStates();
                this.bindHandlers();
                this.createIframeStates();
            },

            createStates: function() {
                var options = this.options;

                // Add the default states.
                this.states.add([
                    // Main states.
                    new wp.media.controller.Library({
                        id:         'insert',
                        title:      'Insert Media',
                        priority:   20,
                        toolbar:    'main-insert',
                        filterable: 'image',
                        library:    wp.media.query( options.library ),
                        multiple:   options.multiple ? 'reset' : false,
                        editable:   true,

                        // If the user isn't allowed to edit fields,
                        // can they still edit it locally?
                        allowLocalEdits: true,

                        // Show the attachment display settings.
                        displaySettings: true,
                        // Update user settings when users adjust the
                        // attachment display settings.
                        displayUserSettings: true
                    }),

                    // Embed states.
                    new wp.media.controller.Embed(),
                ]);


                if ( wp.media.view.settings.post.featuredImageId ) {
                    this.states.add( new wp.media.controller.FeaturedImage() );
                }
            },

            bindHandlers: function() {
                // from Select
                this.on( 'router:create:browse', this.createRouter, this );
                this.on( 'router:render:browse', this.browseRouter, this );
                this.on( 'content:create:browse', this.browseContent, this );
                this.on( 'content:render:upload', this.uploadContent, this );
                this.on( 'toolbar:create:select', this.createSelectToolbar, this );
                //

                this.on( 'menu:create:gallery', this.createMenu, this );
                this.on( 'toolbar:create:main-insert', this.createToolbar, this );
                this.on( 'toolbar:create:main-gallery', this.createToolbar, this );
                this.on( 'toolbar:create:featured-image', this.featuredImageToolbar, this );
                this.on( 'toolbar:create:main-embed', this.mainEmbedToolbar, this );

                var handlers = {
                        menu: {
                            'default': 'mainMenu'
                        },

                        content: {
                            'embed':          'embedContent',
                            'edit-selection': 'editSelectionContent'
                        },

                        toolbar: {
                            'main-insert':      'mainInsertToolbar'
                        }
                    };

                _.each( handlers, function( regionHandlers, region ) {
                    _.each( regionHandlers, function( callback, handler ) {
                        this.on( region + ':render:' + handler, this[ callback ], this );
                    }, this );
                }, this );
            },

            // Menus
            mainMenu: function( view ) {
                view.set({
                    'library-separator': new wp.media.View({
                        className: 'separator',
                        priority: 100
                    })
                });
            },

            // Content
            embedContent: function() {
                var view = new wp.media.view.Embed({
                    controller: this,
                    model:      this.state()
                }).render();

                this.content.set( view );
                view.url.focus();
            },

            editSelectionContent: function() {
                var state = this.state(),
                    selection = state.get('selection'),
                    view;

                view = new wp.media.view.AttachmentsBrowser({
                    controller: this,
                    collection: selection,
                    selection:  selection,
                    model:      state,
                    sortable:   true,
                    search:     false,
                    dragInfo:   true,

                    AttachmentView: wp.media.view.Attachment.EditSelection
                }).render();

                view.toolbar.set( 'backToLibrary', {
                    text:     'Return to Library',
                    priority: -100,

                    click: function() {
                        this.controller.content.mode('browse');
                    }
                });

                // Browse our library of attachments.
                this.content.set( view );
            },

            // Toolbars
            selectionStatusToolbar: function( view ) {
                var editable = this.state().get('editable');

                view.set( 'selection', new wp.media.view.Selection({
                    controller: this,
                    collection: this.state().get('selection'),
                    priority:   -40,

                    // If the selection is editable, pass the callback to
                    // switch the content mode.
                    editable: editable && function() {
                        this.controller.content.mode('edit-selection');
                    }
                }).render() );
            },

            mainInsertToolbar: function( view ) {
                var controller = this;

                this.selectionStatusToolbar( view );

                view.set( 'insert', {
                    style:    'primary',
                    priority: 80,
                    text:     'Select Image',
                    requires: { selection: true },

                    click: function() {
                        var state = controller.state(),
                            selection = state.get('selection');

                        controller.close();
                        state.trigger( 'insert', selection ).reset();
                    }
                });
            },

            featuredImageToolbar: function( toolbar ) {
                this.createSelectToolbar( toolbar, {
                    text:  'Set Featured Image',
                    state: this.options.state || 'upload'
                });
            },

            mainEmbedToolbar: function( toolbar ) {
                toolbar.view = new wp.media.view.Toolbar.Embed({
                    controller: this,
                    text: 'Insert Image'
                });
            }

    });

これはwp.media.view.MediaFrame.Postからのコードとmedia.view.MediaFrame.Selectからのコードを組み合わせて、これが元のスコープの外側で実行されるという事実を調整します。 textの値はさまざまなボタンであり、必要に応じて独自のローカライズオブジェクトを参照することができます。 (createStates()の)Libraryコンストラクタの 'filterable'値によって、サポートされるメディアタイプが決まります。

この方法でSelectオブジェクトを拡張したら、現在と同じ方法でインスタンス化し、画像が選択されたときのカスタムハンドラを追加します。 Urlからの挿入は、アップロードされたメディアから選択するときとは異なるイベントを起動する可能性があります。ページ上の他のメディアフレームが影響を受けないように、最初に実際にフレームをインスタンス化し、次にそれを拡張することがおそらくより良いでしょうが、私はこれを試していません。

それが役立つことを願っています -

10
Brendan Gannon

ソースコードを調べると、一般的なメディアモーダルは "Insert from URL"をサポートしていないようです。私がそのタブを得ることができた一つの方法は "post"フレームタイプを指定することでした:

var frame = wp.media( {
                            title       : 'Widget Uploader',
                            multiple    : false,
                            library     : { type : 'image' },
                            button      : { text : 'Select Image' },
                            frame      : 'post'
                        } );

欠点は、指定されたモーダルのタイトルが無視されることです。

1
KalenGi

重要なのは、そのタブは投稿に直接挿入される外部URLを返すのに対し、ウィジェットはメディアIDを返すことになっているということです。基本的には、外部イメージをサーバーにトランスロードする必要があります。

プラグイン Grab&Save がどのように動作するかを確認します。 ( via

0
bfred.it