113 lines
		
	
	
	
		
			3.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
		
		
			
		
	
	
			113 lines
		
	
	
	
		
			3.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
|  | /* global tinymce */ | ||
|  | tinymce.PluginManager.add('wpgallery', function( editor ) { | ||
|  | 
 | ||
|  | 	function replaceGalleryShortcodes( content ) { | ||
|  | 		return content.replace( /\[gallery([^\]]*)\]/g, function( match ) { | ||
|  | 			return html( 'wp-gallery', match ); | ||
|  | 		}); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	function html( cls, data ) { | ||
|  | 		data = window.encodeURIComponent( data ); | ||
|  | 		return '<img src="' + tinymce.Env.transparentSrc + '" class="wp-media mceItem ' + cls + '" ' + | ||
|  | 			'data-wp-media="' + data + '" data-mce-resize="false" data-mce-placeholder="1" alt="" />'; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	function restoreMediaShortcodes( content ) { | ||
|  | 		function getAttr( str, name ) { | ||
|  | 			name = new RegExp( name + '=\"([^\"]+)\"' ).exec( str ); | ||
|  | 			return name ? window.decodeURIComponent( name[1] ) : ''; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		return content.replace( /(?:<p(?: [^>]+)?>)*(<img [^>]+>)(?:<\/p>)*/g, function( match, image ) { | ||
|  | 			var data = getAttr( image, 'data-wp-media' ); | ||
|  | 
 | ||
|  | 			if ( data ) { | ||
|  | 				return '<p>' + data + '</p>'; | ||
|  | 			} | ||
|  | 
 | ||
|  | 			return match; | ||
|  | 		}); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	function editMedia( node ) { | ||
|  | 		var gallery, frame, data; | ||
|  | 
 | ||
|  | 		if ( node.nodeName !== 'IMG' ) { | ||
|  | 			return; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		// Check if the `wp.media` API exists.
 | ||
|  | 		if ( typeof wp === 'undefined' || ! wp.media ) { | ||
|  | 			return; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		data = window.decodeURIComponent( editor.dom.getAttrib( node, 'data-wp-media' ) ); | ||
|  | 
 | ||
|  | 		// Make sure we've selected a gallery node.
 | ||
|  | 		if ( editor.dom.hasClass( node, 'wp-gallery' ) && wp.media.gallery ) { | ||
|  | 			gallery = wp.media.gallery; | ||
|  | 			frame = gallery.edit( data ); | ||
|  | 
 | ||
|  | 			frame.state('gallery-edit').on( 'update', function( selection ) { | ||
|  | 				var shortcode = gallery.shortcode( selection ).string(); | ||
|  | 				editor.dom.setAttrib( node, 'data-wp-media', window.encodeURIComponent( shortcode ) ); | ||
|  | 				frame.detach(); | ||
|  | 			}); | ||
|  | 		} | ||
|  | 	} | ||
|  | 
 | ||
|  | 	// Register the command so that it can be invoked by using tinyMCE.activeEditor.execCommand('...');
 | ||
|  | 	editor.addCommand( 'WP_Gallery', function() { | ||
|  | 		editMedia( editor.selection.getNode() ); | ||
|  | 	}); | ||
|  | 
 | ||
|  | 	editor.on( 'mouseup', function( event ) { | ||
|  | 		var dom = editor.dom, | ||
|  | 			node = event.target; | ||
|  | 
 | ||
|  | 		function unselect() { | ||
|  | 			dom.removeClass( dom.select( 'img.wp-media-selected' ), 'wp-media-selected' ); | ||
|  | 		} | ||
|  | 
 | ||
|  | 		if ( node.nodeName === 'IMG' && dom.getAttrib( node, 'data-wp-media' ) ) { | ||
|  | 			// Don't trigger on right-click
 | ||
|  | 			if ( event.button !== 2 ) { | ||
|  | 				if ( dom.hasClass( node, 'wp-media-selected' ) ) { | ||
|  | 					editMedia( node ); | ||
|  | 				} else { | ||
|  | 					unselect(); | ||
|  | 					dom.addClass( node, 'wp-media-selected' ); | ||
|  | 				} | ||
|  | 			} | ||
|  | 		} else { | ||
|  | 			unselect(); | ||
|  | 		} | ||
|  | 	}); | ||
|  | 
 | ||
|  | 	// Display gallery, audio or video instead of img in the element path
 | ||
|  | 	editor.on( 'ResolveName', function( event ) { | ||
|  | 		var dom = editor.dom, | ||
|  | 			node = event.target; | ||
|  | 
 | ||
|  | 		if ( node.nodeName === 'IMG' && dom.getAttrib( node, 'data-wp-media' ) ) { | ||
|  | 			if ( dom.hasClass( node, 'wp-gallery' ) ) { | ||
|  | 				event.name = 'gallery'; | ||
|  | 			} | ||
|  | 		} | ||
|  | 	}); | ||
|  | 
 | ||
|  | 	editor.on( 'BeforeSetContent', function( event ) { | ||
|  | 		// 'wpview' handles the gallery shortcode when present
 | ||
|  | 		if ( ! editor.plugins.wpview || typeof wp === 'undefined' || ! wp.mce ) { | ||
|  | 			event.content = replaceGalleryShortcodes( event.content ); | ||
|  | 		} | ||
|  | 	}); | ||
|  | 
 | ||
|  | 	editor.on( 'PostProcess', function( event ) { | ||
|  | 		if ( event.get ) { | ||
|  | 			event.content = restoreMediaShortcodes( event.content ); | ||
|  | 		} | ||
|  | 	}); | ||
|  | }); |