wp/wp-includes/js/tinymce/plugins/wpeditimage/editor_plugin_src.js
author ymh <ymh.work@gmail.com>
Tue, 09 Jun 2015 03:35:32 +0200
changeset 5 5e2f62d02dcd
parent 0 d970ebf37754
permissions -rw-r--r--
upgrade wordpress + plugins
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
(function() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
	tinymce.create('tinymce.plugins.wpEditImage', {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
		url: '',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
		editor: {},
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     6
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
		init: function(ed, url) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
			var t = this, mouse = {};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
			t.url = url;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
			t.editor = ed;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
			t._createButtons();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
			ed.addCommand('WP_EditImage', t._editImage);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
			ed.onInit.add(function(ed) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
				ed.dom.events.add(ed.getBody(), 'mousedown', function(e) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
					var parent;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
					if ( e.target.nodeName == 'IMG' && ( parent = ed.dom.getParent(e.target, 'div.mceTemp') ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
						if ( tinymce.isGecko )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
							ed.selection.select(parent);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
						else if ( tinymce.isWebKit )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
							ed.dom.events.prevent(e);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
					}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
				});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
				// when pressing Return inside a caption move the caret to a new parapraph under it
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
				ed.dom.events.add(ed.getBody(), 'keydown', function(e) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
					var n, DL, DIV, P, content;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    32
					if ( e.keyCode == 13 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    33
						n = ed.selection.getNode();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
						DL = ed.dom.getParent(n, 'dl.wp-caption');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    36
						if ( DL )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
							DIV = ed.dom.getParent(DL, 'div.mceTemp');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
						if ( DIV ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
							ed.dom.events.cancel(e);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
							P = ed.dom.create('p', {}, '\uFEFF');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
							ed.dom.insertAfter( P, DIV );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
							ed.selection.setCursorLocation(P, 0);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
							return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
						}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
					}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
				});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
				// iOS6 doesn't show the buttons properly on click, show them on 'touchstart'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
				if ( 'ontouchstart' in window ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
					ed.dom.events.add(ed.getBody(), 'touchstart', function(e){
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
						t._showButtons(e);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
					});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
			});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
			// resize the caption <dl> when the image is soft-resized by the user
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
			ed.onMouseUp.add(function(ed, e) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
				if ( tinymce.isWebKit || tinymce.isOpera )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
					return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
				if ( mouse.x && (e.clientX != mouse.x || e.clientY != mouse.y) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
					var n = ed.selection.getNode();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
					if ( 'IMG' == n.nodeName ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
						window.setTimeout(function(){
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
							var DL = ed.dom.getParent(n, 'dl.wp-caption'), width;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
							if ( n.width != mouse.img_w || n.height != mouse.img_h )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
								n.className = n.className.replace(/size-[^ "']+/, '');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
							if ( DL ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    73
								width = ed.dom.getAttrib(n, 'width') || n.width;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    74
								width = parseInt(width, 10);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    75
								ed.dom.setStyle(DL, 'width', 10 + width);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
								ed.execCommand('mceRepaint');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
							}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    78
						}, 100);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    79
					}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    80
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    81
				mouse = {};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    82
			});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    83
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
			// show editimage buttons
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
			ed.onMouseDown.add(function(ed, e){
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
				t._showButtons(e);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
			});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    89
			ed.onBeforeSetContent.add(function(ed, o) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    90
				o.content = ed.wpSetImgCaption(o.content);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    91
			});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
			ed.onPostProcess.add(function(ed, o) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
				if (o.get)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
					o.content = ed.wpGetImgCaption(o.content);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
			});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    98
			ed.wpSetImgCaption = function(content) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
				return t._do_shcode(content);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
			};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
			ed.wpGetImgCaption = function(content) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
				return t._get_shcode(content);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
			};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   106
			// When inserting content, if the caret is inside a caption create new paragraph under
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   107
			// and move the caret there
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
			ed.onBeforeExecCommand.add(function(ed, cmd, ui, val) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
				var node, p;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
				if ( cmd == 'mceInsertContent' ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   112
					node = ed.dom.getParent(ed.selection.getNode(), 'div.mceTemp');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   113
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   114
					if ( !node )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   115
						return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   116
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   117
					p = ed.dom.create('p');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   118
					ed.dom.insertAfter( p, node );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   119
					ed.selection.setCursorLocation(p, 0);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   120
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   121
			});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   122
		},
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   123
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   124
		_do_shcode : function(content) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   125
			return content.replace(/(?:<p>)?\[(?:wp_)?caption([^\]]+)\]([\s\S]+?)\[\/(?:wp_)?caption\](?:<\/p>)?/g, function(a,b,c){
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   126
				var id, cls, w, cap, div_cls, img, trim = tinymce.trim;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   127
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   128
				id = b.match(/id=['"]([^'"]*)['"] ?/);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   129
				if ( id )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   130
					b = b.replace(id[0], '');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   131
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   132
				cls = b.match(/align=['"]([^'"]*)['"] ?/);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   133
				if ( cls )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   134
					b = b.replace(cls[0], '');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   135
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   136
				w = b.match(/width=['"]([0-9]*)['"] ?/);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   137
				if ( w )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   138
					b = b.replace(w[0], '');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   139
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   140
				c = trim(c);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   141
				img = c.match(/((?:<a [^>]+>)?<img [^>]+>(?:<\/a>)?)([\s\S]*)/i);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   142
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   143
				if ( img && img[2] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   144
					cap = trim( img[2] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   145
					img = trim( img[1] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   146
				} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   147
					// old captions shortcode style
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   148
					cap = trim(b).replace(/caption=['"]/, '').replace(/['"]$/, '');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   149
					img = c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   150
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   151
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   152
				id = ( id && id[1] ) ? id[1] : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   153
				cls = ( cls && cls[1] ) ? cls[1] : 'alignnone';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   154
				w = ( w && w[1] ) ? w[1] : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   155
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   156
				if ( !w || !cap )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   157
					return c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   158
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   159
				div_cls = 'mceTemp';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   160
				if ( cls == 'aligncenter' )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   161
					div_cls += ' mceIEcenter';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   162
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   163
				w = parseInt( w, 10 ) + 10;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   164
				return '<div class="'+div_cls+'"><dl id="'+id+'" class="wp-caption '+cls+'" style="width: '+w+
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   165
				'px"><dt class="wp-caption-dt">'+img+'</dt><dd class="wp-caption-dd">'+cap+'</dd></dl></div>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   166
			});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   167
		},
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   168
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   169
		_get_shcode : function(content) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   170
			return content.replace(/<div (?:id="attachment_|class="mceTemp)[^>]*>([\s\S]+?)<\/div>/g, function(a, b){
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   171
				var ret = b.replace(/<dl ([^>]+)>\s*<dt [^>]+>([\s\S]+?)<\/dt>\s*<dd [^>]+>([\s\S]*?)<\/dd>\s*<\/dl>/gi, function(a,b,c,cap){
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   172
					var id, cls, w;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   173
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   174
					w = c.match(/width="([0-9]*)"/);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   175
					w = ( w && w[1] ) ? w[1] : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   176
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   177
					if ( !w || !cap )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   178
						return c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   179
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   180
					id = b.match(/id="([^"]*)"/);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   181
					id = ( id && id[1] ) ? id[1] : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   182
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   183
					cls = b.match(/class="([^"]*)"/);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   184
					cls = ( cls && cls[1] ) ? cls[1] : '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   185
					cls = cls.match(/align[a-z]+/) || 'alignnone';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   186
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   187
					cap = cap.replace(/\r\n|\r/g, '\n').replace(/<[a-zA-Z0-9]+( [^<>]+)?>/g, function(a){
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   188
						// no line breaks inside HTML tags
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   189
						return a.replace(/[\r\n\t]+/, ' ');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   190
					});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   191
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   192
					// convert remaining line breaks to <br>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   193
					cap = cap.replace(/\s*\n\s*/g, '<br />');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   194
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   195
					return '[caption id="'+id+'" align="'+cls+'" width="'+w+'"]'+c+' '+cap+'[/caption]';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   196
				});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   197
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
				if ( ret.indexOf('[caption') !== 0 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   199
					// the caption html seems brocken, try to find the image that may be wrapped in a link
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   200
					// and may be followed by <p> with the caption text.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   201
					ret = b.replace(/[\s\S]*?((?:<a [^>]+>)?<img [^>]+>(?:<\/a>)?)(<p>[\s\S]*<\/p>)?[\s\S]*/gi, '<p>$1</p>$2');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   202
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   203
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   204
				return ret;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   205
			});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   206
		},
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   207
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   208
		_createButtons : function() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   209
			var t = this, ed = tinymce.activeEditor, DOM = tinymce.DOM, editButton, dellButton, isRetina;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   210
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   211
			if ( DOM.get('wp_editbtns') )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   212
				return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   213
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   214
			isRetina = ( window.devicePixelRatio && window.devicePixelRatio > 1 ) || // WebKit, Opera
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   215
				( window.matchMedia && window.matchMedia('(min-resolution:130dpi)').matches ); // Firefox, IE10, Opera
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   216
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   217
			DOM.add(document.body, 'div', {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   218
				id : 'wp_editbtns',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   219
				style : 'display:none;'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   220
			});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   221
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   222
			editButton = DOM.add('wp_editbtns', 'img', {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   223
				src : isRetina ? t.url+'/img/image-2x.png' : t.url+'/img/image.png',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   224
				id : 'wp_editimgbtn',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   225
				width : '24',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   226
				height : '24',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   227
				title : ed.getLang('wpeditimage.edit_img')
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   228
			});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   229
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   230
			tinymce.dom.Event.add(editButton, 'mousedown', function(e) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   231
				t._editImage();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   232
				ed.plugins.wordpress._hideButtons();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   233
			});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   234
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   235
			dellButton = DOM.add('wp_editbtns', 'img', {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   236
				src : isRetina ? t.url+'/img/delete-2x.png' : t.url+'/img/delete.png',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   237
				id : 'wp_delimgbtn',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   238
				width : '24',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   239
				height : '24',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   240
				title : ed.getLang('wpeditimage.del_img')
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   241
			});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   242
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   243
			tinymce.dom.Event.add(dellButton, 'mousedown', function(e) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   244
				var ed = tinymce.activeEditor, el = ed.selection.getNode(), parent;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   245
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
				if ( el.nodeName == 'IMG' && ed.dom.getAttrib(el, 'class').indexOf('mceItem') == -1 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
					if ( (parent = ed.dom.getParent(el, 'div')) && ed.dom.hasClass(parent, 'mceTemp') ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
						ed.dom.remove(parent);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
					} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
						if ( el.parentNode.nodeName == 'A' && el.parentNode.childNodes.length == 1 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   251
							el = el.parentNode;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
						if ( el.parentNode.nodeName == 'P' && el.parentNode.childNodes.length == 1 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   254
							el = el.parentNode;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   255
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   256
						ed.dom.remove(el);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   257
					}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   258
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   259
					ed.execCommand('mceRepaint');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   260
					return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   261
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   262
				ed.plugins.wordpress._hideButtons();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   263
			});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   264
		},
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   265
		
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   266
		_editImage : function() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   267
			var ed = tinymce.activeEditor, url = this.url, el = ed.selection.getNode(), vp, H, W, cls = el.className;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   268
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   269
			if ( cls.indexOf('mceItem') != -1 || cls.indexOf('wpGallery') != -1 || el.nodeName != 'IMG' )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   270
				return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   271
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   272
			vp = tinymce.DOM.getViewPort();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   273
			H = 680 < (vp.h - 70) ? 680 : vp.h - 70;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   274
			W = 650 < vp.w ? 650 : vp.w;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   275
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   276
			ed.windowManager.open({
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   277
				file: url + '/editimage.html',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   278
				width: W+'px',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   279
				height: H+'px',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   280
				inline: true
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   281
			});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   282
		},
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   283
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   284
		_showButtons : function(e) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   285
			var ed = this.editor, target = e.target;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   286
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   287
			if ( target.nodeName != 'IMG' ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   288
				if ( target.firstChild && target.firstChild.nodeName == 'IMG' && target.childNodes.length == 1 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   289
					target = target.firstChild;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   290
				} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   291
					ed.plugins.wordpress._hideButtons();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   292
					return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   293
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   294
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   295
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   296
			if ( ed.dom.getAttrib(target, 'class').indexOf('mceItem') == -1 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   297
				mouse = {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   298
					x: e.clientX,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   299
					y: e.clientY,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   300
					img_w: target.clientWidth,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   301
					img_h: target.clientHeight
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   302
				};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   303
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   304
				if ( e.type == 'touchstart' ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   305
					ed.selection.select(target);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   306
					ed.dom.events.cancel(e);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   307
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   308
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   309
				ed.plugins.wordpress._hideButtons();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   310
				ed.plugins.wordpress._showButtons(target, 'wp_editbtns');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   311
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   312
		},
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   313
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   314
		getInfo : function() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   315
			return {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   316
				longname : 'Edit Image',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   317
				author : 'WordPress',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   318
				authorurl : 'http://wordpress.org',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   319
				infourl : '',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   320
				version : "1.0"
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   321
			};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   322
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   323
	});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   324
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   325
	tinymce.PluginManager.add('wpeditimage', tinymce.plugins.wpEditImage);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   326
})();