web/wp-admin/js/gallery.dev.js
changeset 204 09a1c134465b
parent 203 f507feede89a
child 205 a4f7897e21a9
equal deleted inserted replaced
203:f507feede89a 204:09a1c134465b
     1 jQuery(document).ready(function($) {
       
     2 	var gallerySortable, gallerySortableInit, w, desc = false;
       
     3 
       
     4 	gallerySortableInit = function() {
       
     5 		gallerySortable = $('#media-items').sortable( {
       
     6 			items: 'div.media-item',
       
     7 			placeholder: 'sorthelper',
       
     8 			axis: 'y',
       
     9 			distance: 2,
       
    10 			handle: 'div.filename',
       
    11 			stop: function(e, ui) {
       
    12 				// When an update has occurred, adjust the order for each item
       
    13 				var all = $('#media-items').sortable('toArray'), len = all.length;
       
    14 				$.each(all, function(i, id) {
       
    15 					var order = desc ? (len - i) : (1 + i);
       
    16 					$('#' + id + ' .menu_order input').val(order);
       
    17 				});
       
    18 			}
       
    19 		} );
       
    20 	}
       
    21 
       
    22 	sortIt = function() {
       
    23 		var all = $('.menu_order_input'), len = all.length;
       
    24 		all.each(function(i){
       
    25 			var order = desc ? (len - i) : (1 + i);
       
    26 			$(this).val(order);
       
    27 		});
       
    28 	}
       
    29 
       
    30 	clearAll = function(c) {
       
    31 		c = c || 0;
       
    32 		$('.menu_order_input').each(function(){
       
    33 			if ( this.value == '0' || c ) this.value = '';
       
    34 		});
       
    35 	}
       
    36 
       
    37 	$('#asc').click(function(){desc = false; sortIt(); return false;});
       
    38 	$('#desc').click(function(){desc = true; sortIt(); return false;});
       
    39 	$('#clear').click(function(){clearAll(1); return false;});
       
    40 	$('#showall').click(function(){
       
    41 		$('#sort-buttons span a').toggle();
       
    42 		$('a.describe-toggle-on').hide();
       
    43 		$('a.describe-toggle-off, table.slidetoggle').show();
       
    44 		$('img.pinkynail').toggle(false);
       
    45 		return false;
       
    46 	});
       
    47 	$('#hideall').click(function(){
       
    48 		$('#sort-buttons span a').toggle();
       
    49 		$('a.describe-toggle-on').show();
       
    50 		$('a.describe-toggle-off, table.slidetoggle').hide();
       
    51 		$('img.pinkynail').toggle(true);
       
    52 		return false;
       
    53 	});
       
    54 
       
    55 	// initialize sortable
       
    56 	gallerySortableInit();
       
    57 	clearAll();
       
    58 
       
    59 	if ( $('#media-items>*').length > 1 ) {
       
    60 		w = wpgallery.getWin();
       
    61 
       
    62 		$('#save-all, #gallery-settings').show();
       
    63 		if ( typeof w.tinyMCE != 'undefined' && w.tinyMCE.activeEditor && ! w.tinyMCE.activeEditor.isHidden() ) {
       
    64 			wpgallery.mcemode = true;
       
    65 			wpgallery.init();
       
    66 		} else {
       
    67 			$('#insert-gallery').show();
       
    68 		}
       
    69 	}
       
    70 });
       
    71 
       
    72 jQuery(window).unload( function () { tinymce = tinyMCE = wpgallery = null; } ); // Cleanup
       
    73 
       
    74 /* gallery settings */
       
    75 var tinymce = null, tinyMCE, wpgallery;
       
    76 
       
    77 wpgallery = {
       
    78 	mcemode : false,
       
    79 	editor : {},
       
    80 	dom : {},
       
    81 	is_update : false,
       
    82 	el : {},
       
    83 
       
    84 	I : function(e) {
       
    85 		return document.getElementById(e);
       
    86 	},
       
    87 
       
    88 	init: function() {
       
    89 		var t = this, li, q, i, it, w = t.getWin();
       
    90 
       
    91 		if ( ! t.mcemode ) return;
       
    92 
       
    93 		li = ('' + document.location.search).replace(/^\?/, '').split('&');
       
    94 		q = {};
       
    95 		for (i=0; i<li.length; i++) {
       
    96 			it = li[i].split('=');
       
    97 			q[unescape(it[0])] = unescape(it[1]);
       
    98 		}
       
    99 
       
   100 		if (q.mce_rdomain)
       
   101 			document.domain = q.mce_rdomain;
       
   102 
       
   103 		// Find window & API
       
   104 		tinymce = w.tinymce;
       
   105 		tinyMCE = w.tinyMCE;
       
   106 		t.editor = tinymce.EditorManager.activeEditor;
       
   107 
       
   108 		t.setup();
       
   109 	},
       
   110 
       
   111 	getWin : function() {
       
   112 		return window.dialogArguments || opener || parent || top;
       
   113 	},
       
   114 
       
   115 	setup : function() {
       
   116 		var t = this, a, ed = t.editor, g, columns, link, order, orderby;
       
   117 		if ( ! t.mcemode ) return;
       
   118 
       
   119 		t.el = ed.selection.getNode();
       
   120 
       
   121 		if ( t.el.nodeName != 'IMG' || ! ed.dom.hasClass(t.el, 'wpGallery') ) {
       
   122 			if ( (g = ed.dom.select('img.wpGallery')) && g[0] ) {
       
   123 				t.el = g[0];
       
   124 			} else {
       
   125 				if ( getUserSetting('galfile') == '1' ) t.I('linkto-file').checked = "checked";
       
   126 				if ( getUserSetting('galdesc') == '1' ) t.I('order-desc').checked = "checked";
       
   127 				if ( getUserSetting('galcols') ) t.I('columns').value = getUserSetting('galcols');
       
   128 				if ( getUserSetting('galord') ) t.I('orderby').value = getUserSetting('galord');
       
   129 				jQuery('#insert-gallery').show();
       
   130 				return;
       
   131 			}
       
   132 		}
       
   133 
       
   134 		a = ed.dom.getAttrib(t.el, 'title');
       
   135 		a = ed.dom.decode(a);
       
   136 
       
   137 		if ( a ) {
       
   138 			jQuery('#update-gallery').show();
       
   139 			t.is_update = true;
       
   140 
       
   141 			columns = a.match(/columns=['"]([0-9]+)['"]/);
       
   142 			link = a.match(/link=['"]([^'"]+)['"]/i);
       
   143 			order = a.match(/order=['"]([^'"]+)['"]/i);
       
   144 			orderby = a.match(/orderby=['"]([^'"]+)['"]/i);
       
   145 
       
   146 			if ( link && link[1] ) t.I('linkto-file').checked = "checked";
       
   147 			if ( order && order[1] ) t.I('order-desc').checked = "checked";
       
   148 			if ( columns && columns[1] ) t.I('columns').value = ''+columns[1];
       
   149 			if ( orderby && orderby[1] ) t.I('orderby').value = orderby[1];
       
   150 		} else {
       
   151 			jQuery('#insert-gallery').show();
       
   152 		}
       
   153 	},
       
   154 
       
   155 	update : function() {
       
   156 		var t = this, ed = t.editor, all = '', s;
       
   157 
       
   158 		if ( ! t.mcemode || ! t.is_update ) {
       
   159 			s = '[gallery'+t.getSettings()+']';
       
   160 			t.getWin().send_to_editor(s);
       
   161 			return;
       
   162 		}
       
   163 
       
   164 		if (t.el.nodeName != 'IMG') return;
       
   165 
       
   166 		all = ed.dom.decode(ed.dom.getAttrib(t.el, 'title'));
       
   167 		all = all.replace(/\s*(order|link|columns|orderby)=['"]([^'"]+)['"]/gi, '');
       
   168 		all += t.getSettings();
       
   169 
       
   170 		ed.dom.setAttrib(t.el, 'title', all);
       
   171 		t.getWin().tb_remove();
       
   172 	},
       
   173 
       
   174 	getSettings : function() {
       
   175 		var I = this.I, s = '';
       
   176 
       
   177 		if ( I('linkto-file').checked ) {
       
   178 			s += ' link="file"';
       
   179 			setUserSetting('galfile', '1');
       
   180 		}
       
   181 
       
   182 		if ( I('order-desc').checked ) {
       
   183 			s += ' order="DESC"';
       
   184 			setUserSetting('galdesc', '1');
       
   185 		}
       
   186 
       
   187 		if ( I('columns').value != 3 ) {
       
   188 			s += ' columns="'+I('columns').value+'"';
       
   189 			setUserSetting('galcols', I('columns').value);
       
   190 		}
       
   191 
       
   192 		if ( I('orderby').value != 'menu_order' ) {
       
   193 			s += ' orderby="'+I('orderby').value+'"';
       
   194 			setUserSetting('galord', I('orderby').value);
       
   195 		}
       
   196 
       
   197 		return s;
       
   198 	}
       
   199 };