[ Index ] |
PHP Cross Reference of WordPress |
[Summary view] [Print] [Text view]
1 /******/ (function() { // webpackBootstrap 2 /******/ var __webpack_modules__ = ({ 3 4 /***/ 6045: 5 /***/ (function(module) { 6 7 var State = wp.media.controller.State, 8 l10n = wp.media.view.l10n, 9 AudioDetails; 10 11 /** 12 * wp.media.controller.AudioDetails 13 * 14 * The controller for the Audio Details state 15 * 16 * @memberOf wp.media.controller 17 * 18 * @class 19 * @augments wp.media.controller.State 20 * @augments Backbone.Model 21 */ 22 AudioDetails = State.extend(/** @lends wp.media.controller.AudioDetails.prototype */{ 23 defaults: { 24 id: 'audio-details', 25 toolbar: 'audio-details', 26 title: l10n.audioDetailsTitle, 27 content: 'audio-details', 28 menu: 'audio-details', 29 router: false, 30 priority: 60 31 }, 32 33 initialize: function( options ) { 34 this.media = options.media; 35 State.prototype.initialize.apply( this, arguments ); 36 } 37 }); 38 39 module.exports = AudioDetails; 40 41 42 /***/ }), 43 44 /***/ 580: 45 /***/ (function(module) { 46 47 /** 48 * wp.media.controller.VideoDetails 49 * 50 * The controller for the Video Details state 51 * 52 * @memberOf wp.media.controller 53 * 54 * @class 55 * @augments wp.media.controller.State 56 * @augments Backbone.Model 57 */ 58 var State = wp.media.controller.State, 59 l10n = wp.media.view.l10n, 60 VideoDetails; 61 62 VideoDetails = State.extend(/** @lends wp.media.controller.VideoDetails.prototype */{ 63 defaults: { 64 id: 'video-details', 65 toolbar: 'video-details', 66 title: l10n.videoDetailsTitle, 67 content: 'video-details', 68 menu: 'video-details', 69 router: false, 70 priority: 60 71 }, 72 73 initialize: function( options ) { 74 this.media = options.media; 75 State.prototype.initialize.apply( this, arguments ); 76 } 77 }); 78 79 module.exports = VideoDetails; 80 81 82 /***/ }), 83 84 /***/ 6615: 85 /***/ (function(module) { 86 87 /** 88 * wp.media.model.PostMedia 89 * 90 * Shared model class for audio and video. Updates the model after 91 * "Add Audio|Video Source" and "Replace Audio|Video" states return 92 * 93 * @memberOf wp.media.model 94 * 95 * @class 96 * @augments Backbone.Model 97 */ 98 var PostMedia = Backbone.Model.extend(/** @lends wp.media.model.PostMedia.prototype */{ 99 initialize: function() { 100 this.attachment = false; 101 }, 102 103 setSource: function( attachment ) { 104 this.attachment = attachment; 105 this.extension = attachment.get( 'filename' ).split('.').pop(); 106 107 if ( this.get( 'src' ) && this.extension === this.get( 'src' ).split('.').pop() ) { 108 this.unset( 'src' ); 109 } 110 111 if ( _.contains( wp.media.view.settings.embedExts, this.extension ) ) { 112 this.set( this.extension, this.attachment.get( 'url' ) ); 113 } else { 114 this.unset( this.extension ); 115 } 116 }, 117 118 changeAttachment: function( attachment ) { 119 this.setSource( attachment ); 120 121 this.unset( 'src' ); 122 _.each( _.without( wp.media.view.settings.embedExts, this.extension ), function( ext ) { 123 this.unset( ext ); 124 }, this ); 125 } 126 }); 127 128 module.exports = PostMedia; 129 130 131 /***/ }), 132 133 /***/ 1764: 134 /***/ (function(module) { 135 136 var MediaDetails = wp.media.view.MediaDetails, 137 AudioDetails; 138 139 /** 140 * wp.media.view.AudioDetails 141 * 142 * @memberOf wp.media.view 143 * 144 * @class 145 * @augments wp.media.view.MediaDetails 146 * @augments wp.media.view.Settings.AttachmentDisplay 147 * @augments wp.media.view.Settings 148 * @augments wp.media.View 149 * @augments wp.Backbone.View 150 * @augments Backbone.View 151 */ 152 AudioDetails = MediaDetails.extend(/** @lends wp.media.view.AudioDetails.prototype */{ 153 className: 'audio-details', 154 template: wp.template('audio-details'), 155 156 setMedia: function() { 157 var audio = this.$('.wp-audio-shortcode'); 158 159 if ( audio.find( 'source' ).length ) { 160 if ( audio.is(':hidden') ) { 161 audio.show(); 162 } 163 this.media = MediaDetails.prepareSrc( audio.get(0) ); 164 } else { 165 audio.hide(); 166 this.media = false; 167 } 168 169 return this; 170 } 171 }); 172 173 module.exports = AudioDetails; 174 175 176 /***/ }), 177 178 /***/ 5262: 179 /***/ (function(module) { 180 181 var MediaDetails = wp.media.view.MediaFrame.MediaDetails, 182 MediaLibrary = wp.media.controller.MediaLibrary, 183 184 l10n = wp.media.view.l10n, 185 AudioDetails; 186 187 /** 188 * wp.media.view.MediaFrame.AudioDetails 189 * 190 * @memberOf wp.media.view.MediaFrame 191 * 192 * @class 193 * @augments wp.media.view.MediaFrame.MediaDetails 194 * @augments wp.media.view.MediaFrame.Select 195 * @augments wp.media.view.MediaFrame 196 * @augments wp.media.view.Frame 197 * @augments wp.media.View 198 * @augments wp.Backbone.View 199 * @augments Backbone.View 200 * @mixes wp.media.controller.StateMachine 201 */ 202 AudioDetails = MediaDetails.extend(/** @lends wp.media.view.MediaFrame.AudioDetails.prototype */{ 203 defaults: { 204 id: 'audio', 205 url: '', 206 menu: 'audio-details', 207 content: 'audio-details', 208 toolbar: 'audio-details', 209 type: 'link', 210 title: l10n.audioDetailsTitle, 211 priority: 120 212 }, 213 214 initialize: function( options ) { 215 options.DetailsView = wp.media.view.AudioDetails; 216 options.cancelText = l10n.audioDetailsCancel; 217 options.addText = l10n.audioAddSourceTitle; 218 219 MediaDetails.prototype.initialize.call( this, options ); 220 }, 221 222 bindHandlers: function() { 223 MediaDetails.prototype.bindHandlers.apply( this, arguments ); 224 225 this.on( 'toolbar:render:replace-audio', this.renderReplaceToolbar, this ); 226 this.on( 'toolbar:render:add-audio-source', this.renderAddSourceToolbar, this ); 227 }, 228 229 createStates: function() { 230 this.states.add([ 231 new wp.media.controller.AudioDetails( { 232 media: this.media 233 } ), 234 235 new MediaLibrary( { 236 type: 'audio', 237 id: 'replace-audio', 238 title: l10n.audioReplaceTitle, 239 toolbar: 'replace-audio', 240 media: this.media, 241 menu: 'audio-details' 242 } ), 243 244 new MediaLibrary( { 245 type: 'audio', 246 id: 'add-audio-source', 247 title: l10n.audioAddSourceTitle, 248 toolbar: 'add-audio-source', 249 media: this.media, 250 menu: false 251 } ) 252 ]); 253 } 254 }); 255 256 module.exports = AudioDetails; 257 258 259 /***/ }), 260 261 /***/ 6445: 262 /***/ (function(module) { 263 264 var Select = wp.media.view.MediaFrame.Select, 265 l10n = wp.media.view.l10n, 266 MediaDetails; 267 268 /** 269 * wp.media.view.MediaFrame.MediaDetails 270 * 271 * @memberOf wp.media.view.MediaFrame 272 * 273 * @class 274 * @augments wp.media.view.MediaFrame.Select 275 * @augments wp.media.view.MediaFrame 276 * @augments wp.media.view.Frame 277 * @augments wp.media.View 278 * @augments wp.Backbone.View 279 * @augments Backbone.View 280 * @mixes wp.media.controller.StateMachine 281 */ 282 MediaDetails = Select.extend(/** @lends wp.media.view.MediaFrame.MediaDetails.prototype */{ 283 defaults: { 284 id: 'media', 285 url: '', 286 menu: 'media-details', 287 content: 'media-details', 288 toolbar: 'media-details', 289 type: 'link', 290 priority: 120 291 }, 292 293 initialize: function( options ) { 294 this.DetailsView = options.DetailsView; 295 this.cancelText = options.cancelText; 296 this.addText = options.addText; 297 298 this.media = new wp.media.model.PostMedia( options.metadata ); 299 this.options.selection = new wp.media.model.Selection( this.media.attachment, { multiple: false } ); 300 Select.prototype.initialize.apply( this, arguments ); 301 }, 302 303 bindHandlers: function() { 304 var menu = this.defaults.menu; 305 306 Select.prototype.bindHandlers.apply( this, arguments ); 307 308 this.on( 'menu:create:' + menu, this.createMenu, this ); 309 this.on( 'content:render:' + menu, this.renderDetailsContent, this ); 310 this.on( 'menu:render:' + menu, this.renderMenu, this ); 311 this.on( 'toolbar:render:' + menu, this.renderDetailsToolbar, this ); 312 }, 313 314 renderDetailsContent: function() { 315 var view = new this.DetailsView({ 316 controller: this, 317 model: this.state().media, 318 attachment: this.state().media.attachment 319 }).render(); 320 321 this.content.set( view ); 322 }, 323 324 renderMenu: function( view ) { 325 var lastState = this.lastState(), 326 previous = lastState && lastState.id, 327 frame = this; 328 329 view.set({ 330 cancel: { 331 text: this.cancelText, 332 priority: 20, 333 click: function() { 334 if ( previous ) { 335 frame.setState( previous ); 336 } else { 337 frame.close(); 338 } 339 } 340 }, 341 separateCancel: new wp.media.View({ 342 className: 'separator', 343 priority: 40 344 }) 345 }); 346 347 }, 348 349 setPrimaryButton: function(text, handler) { 350 this.toolbar.set( new wp.media.view.Toolbar({ 351 controller: this, 352 items: { 353 button: { 354 style: 'primary', 355 text: text, 356 priority: 80, 357 click: function() { 358 var controller = this.controller; 359 handler.call( this, controller, controller.state() ); 360 // Restore and reset the default state. 361 controller.setState( controller.options.state ); 362 controller.reset(); 363 } 364 } 365 } 366 }) ); 367 }, 368 369 renderDetailsToolbar: function() { 370 this.setPrimaryButton( l10n.update, function( controller, state ) { 371 controller.close(); 372 state.trigger( 'update', controller.media.toJSON() ); 373 } ); 374 }, 375 376 renderReplaceToolbar: function() { 377 this.setPrimaryButton( l10n.replace, function( controller, state ) { 378 var attachment = state.get( 'selection' ).single(); 379 controller.media.changeAttachment( attachment ); 380 state.trigger( 'replace', controller.media.toJSON() ); 381 } ); 382 }, 383 384 renderAddSourceToolbar: function() { 385 this.setPrimaryButton( this.addText, function( controller, state ) { 386 var attachment = state.get( 'selection' ).single(); 387 controller.media.setSource( attachment ); 388 state.trigger( 'add-source', controller.media.toJSON() ); 389 } ); 390 } 391 }); 392 393 module.exports = MediaDetails; 394 395 396 /***/ }), 397 398 /***/ 2075: 399 /***/ (function(module) { 400 401 var MediaDetails = wp.media.view.MediaFrame.MediaDetails, 402 MediaLibrary = wp.media.controller.MediaLibrary, 403 l10n = wp.media.view.l10n, 404 VideoDetails; 405 406 /** 407 * wp.media.view.MediaFrame.VideoDetails 408 * 409 * @memberOf wp.media.view.MediaFrame 410 * 411 * @class 412 * @augments wp.media.view.MediaFrame.MediaDetails 413 * @augments wp.media.view.MediaFrame.Select 414 * @augments wp.media.view.MediaFrame 415 * @augments wp.media.view.Frame 416 * @augments wp.media.View 417 * @augments wp.Backbone.View 418 * @augments Backbone.View 419 * @mixes wp.media.controller.StateMachine 420 */ 421 VideoDetails = MediaDetails.extend(/** @lends wp.media.view.MediaFrame.VideoDetails.prototype */{ 422 defaults: { 423 id: 'video', 424 url: '', 425 menu: 'video-details', 426 content: 'video-details', 427 toolbar: 'video-details', 428 type: 'link', 429 title: l10n.videoDetailsTitle, 430 priority: 120 431 }, 432 433 initialize: function( options ) { 434 options.DetailsView = wp.media.view.VideoDetails; 435 options.cancelText = l10n.videoDetailsCancel; 436 options.addText = l10n.videoAddSourceTitle; 437 438 MediaDetails.prototype.initialize.call( this, options ); 439 }, 440 441 bindHandlers: function() { 442 MediaDetails.prototype.bindHandlers.apply( this, arguments ); 443 444 this.on( 'toolbar:render:replace-video', this.renderReplaceToolbar, this ); 445 this.on( 'toolbar:render:add-video-source', this.renderAddSourceToolbar, this ); 446 this.on( 'toolbar:render:select-poster-image', this.renderSelectPosterImageToolbar, this ); 447 this.on( 'toolbar:render:add-track', this.renderAddTrackToolbar, this ); 448 }, 449 450 createStates: function() { 451 this.states.add([ 452 new wp.media.controller.VideoDetails({ 453 media: this.media 454 }), 455 456 new MediaLibrary( { 457 type: 'video', 458 id: 'replace-video', 459 title: l10n.videoReplaceTitle, 460 toolbar: 'replace-video', 461 media: this.media, 462 menu: 'video-details' 463 } ), 464 465 new MediaLibrary( { 466 type: 'video', 467 id: 'add-video-source', 468 title: l10n.videoAddSourceTitle, 469 toolbar: 'add-video-source', 470 media: this.media, 471 menu: false 472 } ), 473 474 new MediaLibrary( { 475 type: 'image', 476 id: 'select-poster-image', 477 title: l10n.videoSelectPosterImageTitle, 478 toolbar: 'select-poster-image', 479 media: this.media, 480 menu: 'video-details' 481 } ), 482 483 new MediaLibrary( { 484 type: 'text', 485 id: 'add-track', 486 title: l10n.videoAddTrackTitle, 487 toolbar: 'add-track', 488 media: this.media, 489 menu: 'video-details' 490 } ) 491 ]); 492 }, 493 494 renderSelectPosterImageToolbar: function() { 495 this.setPrimaryButton( l10n.videoSelectPosterImageTitle, function( controller, state ) { 496 var urls = [], attachment = state.get( 'selection' ).single(); 497 498 controller.media.set( 'poster', attachment.get( 'url' ) ); 499 state.trigger( 'set-poster-image', controller.media.toJSON() ); 500 501 _.each( wp.media.view.settings.embedExts, function (ext) { 502 if ( controller.media.get( ext ) ) { 503 urls.push( controller.media.get( ext ) ); 504 } 505 } ); 506 507 wp.ajax.send( 'set-attachment-thumbnail', { 508 data : { 509 urls: urls, 510 thumbnail_id: attachment.get( 'id' ) 511 } 512 } ); 513 } ); 514 }, 515 516 renderAddTrackToolbar: function() { 517 this.setPrimaryButton( l10n.videoAddTrackTitle, function( controller, state ) { 518 var attachment = state.get( 'selection' ).single(), 519 content = controller.media.get( 'content' ); 520 521 if ( -1 === content.indexOf( attachment.get( 'url' ) ) ) { 522 content += [ 523 '<track srclang="en" label="English" kind="subtitles" src="', 524 attachment.get( 'url' ), 525 '" />' 526 ].join(''); 527 528 controller.media.set( 'content', content ); 529 } 530 state.trigger( 'add-track', controller.media.toJSON() ); 531 } ); 532 } 533 }); 534 535 module.exports = VideoDetails; 536 537 538 /***/ }), 539 540 /***/ 8867: 541 /***/ (function(module) { 542 543 /* global MediaElementPlayer */ 544 var AttachmentDisplay = wp.media.view.Settings.AttachmentDisplay, 545 $ = jQuery, 546 MediaDetails; 547 548 /** 549 * wp.media.view.MediaDetails 550 * 551 * @memberOf wp.media.view 552 * 553 * @class 554 * @augments wp.media.view.Settings.AttachmentDisplay 555 * @augments wp.media.view.Settings 556 * @augments wp.media.View 557 * @augments wp.Backbone.View 558 * @augments Backbone.View 559 */ 560 MediaDetails = AttachmentDisplay.extend(/** @lends wp.media.view.MediaDetails.prototype */{ 561 initialize: function() { 562 _.bindAll(this, 'success'); 563 this.players = []; 564 this.listenTo( this.controller.states, 'close', wp.media.mixin.unsetPlayers ); 565 this.on( 'ready', this.setPlayer ); 566 this.on( 'media:setting:remove', wp.media.mixin.unsetPlayers, this ); 567 this.on( 'media:setting:remove', this.render ); 568 this.on( 'media:setting:remove', this.setPlayer ); 569 570 AttachmentDisplay.prototype.initialize.apply( this, arguments ); 571 }, 572 573 events: function(){ 574 return _.extend( { 575 'click .remove-setting' : 'removeSetting', 576 'change .content-track' : 'setTracks', 577 'click .remove-track' : 'setTracks', 578 'click .add-media-source' : 'addSource' 579 }, AttachmentDisplay.prototype.events ); 580 }, 581 582 prepare: function() { 583 return _.defaults({ 584 model: this.model.toJSON() 585 }, this.options ); 586 }, 587 588 /** 589 * Remove a setting's UI when the model unsets it 590 * 591 * @fires wp.media.view.MediaDetails#media:setting:remove 592 * 593 * @param {Event} e 594 */ 595 removeSetting : function(e) { 596 var wrap = $( e.currentTarget ).parent(), setting; 597 setting = wrap.find( 'input' ).data( 'setting' ); 598 599 if ( setting ) { 600 this.model.unset( setting ); 601 this.trigger( 'media:setting:remove', this ); 602 } 603 604 wrap.remove(); 605 }, 606 607 /** 608 * 609 * @fires wp.media.view.MediaDetails#media:setting:remove 610 */ 611 setTracks : function() { 612 var tracks = ''; 613 614 _.each( this.$('.content-track'), function(track) { 615 tracks += $( track ).val(); 616 } ); 617 618 this.model.set( 'content', tracks ); 619 this.trigger( 'media:setting:remove', this ); 620 }, 621 622 addSource : function( e ) { 623 this.controller.lastMime = $( e.currentTarget ).data( 'mime' ); 624 this.controller.setState( 'add-' + this.controller.defaults.id + '-source' ); 625 }, 626 627 loadPlayer: function () { 628 this.players.push( new MediaElementPlayer( this.media, this.settings ) ); 629 this.scriptXhr = false; 630 }, 631 632 setPlayer : function() { 633 var src; 634 635 if ( this.players.length || ! this.media || this.scriptXhr ) { 636 return; 637 } 638 639 src = this.model.get( 'src' ); 640 641 if ( src && src.indexOf( 'vimeo' ) > -1 && ! ( 'Vimeo' in window ) ) { 642 this.scriptXhr = $.getScript( 'https://player.vimeo.com/api/player.js', _.bind( this.loadPlayer, this ) ); 643 } else { 644 this.loadPlayer(); 645 } 646 }, 647 648 /** 649 * @abstract 650 */ 651 setMedia : function() { 652 return this; 653 }, 654 655 success : function(mejs) { 656 var autoplay = mejs.attributes.autoplay && 'false' !== mejs.attributes.autoplay; 657 658 if ( 'flash' === mejs.pluginType && autoplay ) { 659 mejs.addEventListener( 'canplay', function() { 660 mejs.play(); 661 }, false ); 662 } 663 664 this.mejs = mejs; 665 }, 666 667 /** 668 * @return {media.view.MediaDetails} Returns itself to allow chaining. 669 */ 670 render: function() { 671 AttachmentDisplay.prototype.render.apply( this, arguments ); 672 673 setTimeout( _.bind( function() { 674 this.scrollToTop(); 675 }, this ), 10 ); 676 677 this.settings = _.defaults( { 678 success : this.success 679 }, wp.media.mixin.mejsSettings ); 680 681 return this.setMedia(); 682 }, 683 684 scrollToTop: function() { 685 this.$( '.embed-media-settings' ).scrollTop( 0 ); 686 } 687 },/** @lends wp.media.view.MediaDetails */{ 688 instances : 0, 689 /** 690 * When multiple players in the DOM contain the same src, things get weird. 691 * 692 * @param {HTMLElement} elem 693 * @return {HTMLElement} 694 */ 695 prepareSrc : function( elem ) { 696 var i = MediaDetails.instances++; 697 _.each( $( elem ).find( 'source' ), function( source ) { 698 source.src = [ 699 source.src, 700 source.src.indexOf('?') > -1 ? '&' : '?', 701 '_=', 702 i 703 ].join(''); 704 } ); 705 706 return elem; 707 } 708 }); 709 710 module.exports = MediaDetails; 711 712 713 /***/ }), 714 715 /***/ 7697: 716 /***/ (function(module) { 717 718 var MediaDetails = wp.media.view.MediaDetails, 719 VideoDetails; 720 721 /** 722 * wp.media.view.VideoDetails 723 * 724 * @memberOf wp.media.view 725 * 726 * @class 727 * @augments wp.media.view.MediaDetails 728 * @augments wp.media.view.Settings.AttachmentDisplay 729 * @augments wp.media.view.Settings 730 * @augments wp.media.View 731 * @augments wp.Backbone.View 732 * @augments Backbone.View 733 */ 734 VideoDetails = MediaDetails.extend(/** @lends wp.media.view.VideoDetails.prototype */{ 735 className: 'video-details', 736 template: wp.template('video-details'), 737 738 setMedia: function() { 739 var video = this.$('.wp-video-shortcode'); 740 741 if ( video.find( 'source' ).length ) { 742 if ( video.is(':hidden') ) { 743 video.show(); 744 } 745 746 if ( ! video.hasClass( 'youtube-video' ) && ! video.hasClass( 'vimeo-video' ) ) { 747 this.media = MediaDetails.prepareSrc( video.get(0) ); 748 } else { 749 this.media = video.get(0); 750 } 751 } else { 752 video.hide(); 753 this.media = false; 754 } 755 756 return this; 757 } 758 }); 759 760 module.exports = VideoDetails; 761 762 763 /***/ }) 764 765 /******/ }); 766 /************************************************************************/ 767 /******/ // The module cache 768 /******/ var __webpack_module_cache__ = {}; 769 /******/ 770 /******/ // The require function 771 /******/ function __webpack_require__(moduleId) { 772 /******/ // Check if module is in cache 773 /******/ var cachedModule = __webpack_module_cache__[moduleId]; 774 /******/ if (cachedModule !== undefined) { 775 /******/ return cachedModule.exports; 776 /******/ } 777 /******/ // Create a new module (and put it into the cache) 778 /******/ var module = __webpack_module_cache__[moduleId] = { 779 /******/ // no module.id needed 780 /******/ // no module.loaded needed 781 /******/ exports: {} 782 /******/ }; 783 /******/ 784 /******/ // Execute the module function 785 /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); 786 /******/ 787 /******/ // Return the exports of the module 788 /******/ return module.exports; 789 /******/ } 790 /******/ 791 /************************************************************************/ 792 var __webpack_exports__ = {}; 793 // This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk. 794 !function() { 795 /** 796 * @output wp-includes/js/media-audiovideo.js 797 */ 798 799 var media = wp.media, 800 baseSettings = window._wpmejsSettings || {}, 801 l10n = window._wpMediaViewsL10n || {}; 802 803 /** 804 * 805 * Defines the wp.media.mixin object. 806 * 807 * @mixin 808 * 809 * @since 4.2.0 810 */ 811 wp.media.mixin = { 812 mejsSettings: baseSettings, 813 814 /** 815 * Pauses and removes all players. 816 * 817 * @since 4.2.0 818 * 819 * @return {void} 820 */ 821 removeAllPlayers: function() { 822 var p; 823 824 if ( window.mejs && window.mejs.players ) { 825 for ( p in window.mejs.players ) { 826 window.mejs.players[p].pause(); 827 this.removePlayer( window.mejs.players[p] ); 828 } 829 } 830 }, 831 832 /** 833 * Removes the player. 834 * 835 * Override the MediaElement method for removing a player. 836 * MediaElement tries to pull the audio/video tag out of 837 * its container and re-add it to the DOM. 838 * 839 * @since 4.2.0 840 * 841 * @return {void} 842 */ 843 removePlayer: function(t) { 844 var featureIndex, feature; 845 846 if ( ! t.options ) { 847 return; 848 } 849 850 // Invoke features cleanup. 851 for ( featureIndex in t.options.features ) { 852 feature = t.options.features[featureIndex]; 853 if ( t['clean' + feature] ) { 854 try { 855 t['clean' + feature](t); 856 } catch (e) {} 857 } 858 } 859 860 if ( ! t.isDynamic ) { 861 t.node.remove(); 862 } 863 864 if ( 'html5' !== t.media.rendererName ) { 865 t.media.remove(); 866 } 867 868 delete window.mejs.players[t.id]; 869 870 t.container.remove(); 871 t.globalUnbind('resize', t.globalResizeCallback); 872 t.globalUnbind('keydown', t.globalKeydownCallback); 873 t.globalUnbind('click', t.globalClickCallback); 874 delete t.media.player; 875 }, 876 877 /** 878 * 879 * Removes and resets all players. 880 * 881 * Allows any class that has set 'player' to a MediaElementPlayer 882 * instance to remove the player when listening to events. 883 * 884 * Examples: modal closes, shortcode properties are removed, etc. 885 * 886 * @since 4.2.0 887 */ 888 unsetPlayers : function() { 889 if ( this.players && this.players.length ) { 890 _.each( this.players, function (player) { 891 player.pause(); 892 wp.media.mixin.removePlayer( player ); 893 } ); 894 this.players = []; 895 } 896 } 897 }; 898 899 /** 900 * Shortcode modeling for playlists. 901 * 902 * @since 4.2.0 903 */ 904 wp.media.playlist = new wp.media.collection({ 905 tag: 'playlist', 906 editTitle : l10n.editPlaylistTitle, 907 defaults : { 908 id: wp.media.view.settings.post.id, 909 style: 'light', 910 tracklist: true, 911 tracknumbers: true, 912 images: true, 913 artists: true, 914 type: 'audio' 915 } 916 }); 917 918 /** 919 * Shortcode modeling for audio. 920 * 921 * `edit()` prepares the shortcode for the media modal. 922 * `shortcode()` builds the new shortcode after an update. 923 * 924 * @namespace 925 * 926 * @since 4.2.0 927 */ 928 wp.media.audio = { 929 coerce : wp.media.coerce, 930 931 defaults : { 932 id : wp.media.view.settings.post.id, 933 src : '', 934 loop : false, 935 autoplay : false, 936 preload : 'none', 937 width : 400 938 }, 939 940 /** 941 * Instantiates a new media object with the next matching shortcode. 942 * 943 * @since 4.2.0 944 * 945 * @param {string} data The text to apply the shortcode on. 946 * @return {wp.media} The media object. 947 */ 948 edit : function( data ) { 949 var frame, shortcode = wp.shortcode.next( 'audio', data ).shortcode; 950 951 frame = wp.media({ 952 frame: 'audio', 953 state: 'audio-details', 954 metadata: _.defaults( shortcode.attrs.named, this.defaults ) 955 }); 956 957 return frame; 958 }, 959 960 /** 961 * Generates an audio shortcode. 962 * 963 * @since 4.2.0 964 * 965 * @param {Array} model Array with attributes for the shortcode. 966 * @return {wp.shortcode} The audio shortcode object. 967 */ 968 shortcode : function( model ) { 969 var content; 970 971 _.each( this.defaults, function( value, key ) { 972 model[ key ] = this.coerce( model, key ); 973 974 if ( value === model[ key ] ) { 975 delete model[ key ]; 976 } 977 }, this ); 978 979 content = model.content; 980 delete model.content; 981 982 return new wp.shortcode({ 983 tag: 'audio', 984 attrs: model, 985 content: content 986 }); 987 } 988 }; 989 990 /** 991 * Shortcode modeling for video. 992 * 993 * `edit()` prepares the shortcode for the media modal. 994 * `shortcode()` builds the new shortcode after update. 995 * 996 * @since 4.2.0 997 * 998 * @namespace 999 */ 1000 wp.media.video = { 1001 coerce : wp.media.coerce, 1002 1003 defaults : { 1004 id : wp.media.view.settings.post.id, 1005 src : '', 1006 poster : '', 1007 loop : false, 1008 autoplay : false, 1009 preload : 'metadata', 1010 content : '', 1011 width : 640, 1012 height : 360 1013 }, 1014 1015 /** 1016 * Instantiates a new media object with the next matching shortcode. 1017 * 1018 * @since 4.2.0 1019 * 1020 * @param {string} data The text to apply the shortcode on. 1021 * @return {wp.media} The media object. 1022 */ 1023 edit : function( data ) { 1024 var frame, 1025 shortcode = wp.shortcode.next( 'video', data ).shortcode, 1026 attrs; 1027 1028 attrs = shortcode.attrs.named; 1029 attrs.content = shortcode.content; 1030 1031 frame = wp.media({ 1032 frame: 'video', 1033 state: 'video-details', 1034 metadata: _.defaults( attrs, this.defaults ) 1035 }); 1036 1037 return frame; 1038 }, 1039 1040 /** 1041 * Generates an video shortcode. 1042 * 1043 * @since 4.2.0 1044 * 1045 * @param {Array} model Array with attributes for the shortcode. 1046 * @return {wp.shortcode} The video shortcode object. 1047 */ 1048 shortcode : function( model ) { 1049 var content; 1050 1051 _.each( this.defaults, function( value, key ) { 1052 model[ key ] = this.coerce( model, key ); 1053 1054 if ( value === model[ key ] ) { 1055 delete model[ key ]; 1056 } 1057 }, this ); 1058 1059 content = model.content; 1060 delete model.content; 1061 1062 return new wp.shortcode({ 1063 tag: 'video', 1064 attrs: model, 1065 content: content 1066 }); 1067 } 1068 }; 1069 1070 media.model.PostMedia = __webpack_require__( 6615 ); 1071 media.controller.AudioDetails = __webpack_require__( 6045 ); 1072 media.controller.VideoDetails = __webpack_require__( 580 ); 1073 media.view.MediaFrame.MediaDetails = __webpack_require__( 6445 ); 1074 media.view.MediaFrame.AudioDetails = __webpack_require__( 5262 ); 1075 media.view.MediaFrame.VideoDetails = __webpack_require__( 2075 ); 1076 media.view.MediaDetails = __webpack_require__( 8867 ); 1077 media.view.AudioDetails = __webpack_require__( 1764 ); 1078 media.view.VideoDetails = __webpack_require__( 7697 ); 1079 1080 }(); 1081 /******/ })() 1082 ;
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated: Sat Jan 25 01:00:02 2025 | Cross-referenced by PHPXref 0.7.1 |