forked from GNUsocial/gnu-social
		
	
		
			
				
	
	
		
			131 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			131 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /** Init for Farbtastic library and page setup
 | |
|  *
 | |
|  * @package   StatusNet
 | |
|  * @author Sarven Capadisli <csarven@status.net>
 | |
|  * @copyright 2009-2011 StatusNet, Inc.
 | |
|  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
 | |
|  * @link      http://status.net/
 | |
|  */
 | |
| $(document).ready(function() {
 | |
|     function InitColors(i, E) {
 | |
|         switch (parseInt(E.id.slice(-1))) {
 | |
|             case 1: default:
 | |
|                 $(E).val(rgb2hex($('body').css('background-color')));
 | |
|                 break;
 | |
|             case 2:
 | |
|                 $(E).val(rgb2hex($('#content').css('background-color')));
 | |
|                 break;
 | |
|             case 3:
 | |
|                 $(E).val(rgb2hex($('#aside_primary_wrapper, #site_nav_local_views_wrapper').css('background-color')));
 | |
|                 break;
 | |
|             case 4:
 | |
|                 $(E).val(rgb2hex($('html body').css('color')));
 | |
|                 break;
 | |
|             case 5:
 | |
|                 $(E).val(rgb2hex($('a').css('color')));
 | |
|                 break;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     function rgb2hex(rgb) {
 | |
|         if (rgb.slice(0,1) == '#') { return rgb; }
 | |
|         rgb = rgb.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/);
 | |
|         return '#' + dec2hex(rgb[1]) + dec2hex(rgb[2]) + dec2hex(rgb[3]);
 | |
|     }
 | |
|     /* dec2hex written by R0bb13 <robertorebollo@gmail.com> */
 | |
|     function dec2hex(x) {
 | |
|         hexDigits = new Array('0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F');
 | |
|         return isNaN(x) ? '00' : hexDigits[(x - x % 16) / 16] + hexDigits[x % 16];
 | |
|     }
 | |
| 
 | |
|     function UpdateColors(S) {
 | |
|         C = $(S).val();
 | |
|         switch (parseInt(S.id.slice(-1))) {
 | |
|             case 1: default:
 | |
|                 $('body').css({'background-color':C});
 | |
|                 break;
 | |
|             case 2:
 | |
|                 $('#content').css({'background-color':C});
 | |
|                 break;
 | |
|             case 3:
 | |
|                 $('#aside_primary_wrapper, #site_nav_local_views_wrapper').css({'background-color':C});
 | |
|                 break;
 | |
|             case 4:
 | |
|                 $('html body').css({'color':C});
 | |
|                 break;
 | |
|             case 5:
 | |
|                 $('a').css({'color':C});
 | |
|                 break;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     function UpdateFarbtastic(e) {
 | |
|         f.linked = e;
 | |
|         f.setColor(e.value);
 | |
|     }
 | |
| 
 | |
|     function UpdateSwatch(e) {
 | |
|         $(e).css({"background-color": e.value,
 | |
|                   "color": f.hsl[2] > 0.5 ? "#000": "#fff"});
 | |
|     }
 | |
| 
 | |
|     function SynchColors(e) {
 | |
|         var S = f.linked;
 | |
|         var C = f.color;
 | |
| 
 | |
|         if (S && S.value && S.value != C) {
 | |
|             S.value = C;
 | |
|             UpdateSwatch(S);
 | |
|             UpdateColors(S);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     function InitFarbtastic() {
 | |
|         $('#settings_design_color').append('<div id="color-picker"></div>');
 | |
|         $('#color-picker').hide();
 | |
| 
 | |
|         f = $.farbtastic('#color-picker', SynchColors);
 | |
|         swatches = $('#settings_design_color .swatch');
 | |
|         swatches.each(InitColors);
 | |
|         swatches
 | |
|             .each(SynchColors)
 | |
|             .blur(function() {
 | |
|                 tv = $(this).val();
 | |
|                 $(this).val(tv.toUpperCase());
 | |
|                 (tv.length == 4) ? ((tv[0] == '#') ? $(this).val('#'+tv[1]+tv[1]+tv[2]+tv[2]+tv[3]+tv[3]) : '') : '';
 | |
|              })
 | |
|             .focus(function() {
 | |
|                 $('#color-picker').show();
 | |
|                 UpdateFarbtastic(this);
 | |
|             })
 | |
|             .change(function() {
 | |
|                 UpdateFarbtastic(this);
 | |
|                 UpdateSwatch(this);
 | |
|                 UpdateColors(this);
 | |
|             }).change();
 | |
|     }
 | |
| 
 | |
|     var f, swatches;
 | |
|     InitFarbtastic();
 | |
|     $('#form_settings_design').bind('reset', function(){
 | |
|         setTimeout(function(){
 | |
|             swatches.each(function(){UpdateColors(this);});
 | |
|             $('#color-picker').remove();
 | |
|             swatches.unbind();
 | |
|             InitFarbtastic();
 | |
|         },10);
 | |
|     });
 | |
| 
 | |
|     $('#design_background-image_off').focus(function() {
 | |
|         $('body').css({'background-image':'none'});
 | |
|     });
 | |
|     $('#design_background-image_on').focus(function() {
 | |
|         $('body').css({'background-image':'url('+$('#design_background-image_onoff img')[0].src+')'});
 | |
|         $('body').css({'background-attachment': 'fixed'});
 | |
|     });
 | |
| 
 | |
|     $('#design_background-image_repeat').click(function() {
 | |
|         ($(this)[0].checked) ? $('body').css({'background-repeat':'repeat'}) : $('body').css({'background-repeat':'no-repeat'});
 | |
|     });
 | |
| });
 |