source: dashboard/lib/js/themeswitchertool.js@ 378

Last change on this file since 378 was 335, checked in by Rick van der Zwet, 13 years ago

New layout and UI

File size: 14.5 KB
Line 
1/* jQuery plugin themeswitcher
2---------------------------------------------------------------------*/
3$.fn.themeswitcher = function(settings){
4 var options = jQuery.extend({
5 loadTheme: null,
6 initialText: 'Switch Theme',
7 width: 150,
8 height: 200,
9 buttonPreText: 'Theme: ',
10 closeOnSelect: true,
11 buttonHeight: 14,
12 cookieName: 'jquery-ui-theme',
13 onOpen: function(){},
14 onClose: function(){},
15 onSelect: function(){}
16 }, settings);
17
18 //markup
19 var button = $('<a href="#" class="jquery-ui-themeswitcher-trigger"><span class="jquery-ui-themeswitcher-icon"></span><span class="jquery-ui-themeswitcher-title">'+ options.initialText +'</span></a>');
20 var switcherpane = $('<div class="jquery-ui-themeswitcher"><div id="themeGallery"> <ul> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/ui-lightness/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_ui_light.png" alt="UI Lightness" title="UI Lightness" /> <span class="themeName">UI lightness</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/ui-darkness/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_ui_dark.png" alt="UI Darkness" title="UI Darkness" /> <span class="themeName">UI darkness</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/smoothness/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_smoothness.png" alt="Smoothness" title="Smoothness" /> <span class="themeName">Smoothness</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/start/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_start_menu.png" alt="Start" title="Start" /> <span class="themeName">Start</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/redmond/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_windoze.png" alt="Redmond" title="Redmond" /> <span class="themeName">Redmond</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/sunny/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_sunny.png" alt="Sunny" title="Sunny" /> <span class="themeName">Sunny</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/overcast/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_overcast.png" alt="Overcast" title="Overcast" /> <span class="themeName">Overcast</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/le-frog/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_le_frog.png" alt="Le Frog" title="Le Frog" /> <span class="themeName">Le Frog</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/flick/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_flick.png" alt="Flick" title="Flick" /> <span class="themeName">Flick</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/pepper-grinder/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_pepper_grinder.png" alt="Pepper Grinder" title="Pepper Grinder" /> <span class="themeName">Pepper Grinder</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/eggplant/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_eggplant.png" alt="Eggplant" title="Eggplant" /> <span class="themeName">Eggplant</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/dark-hive/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_dark_hive.png" alt="Dark Hive" title="Dark Hive" /> <span class="themeName">Dark Hive</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/cupertino/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_cupertino.png" alt="Cupertino" title="Cupertino" /> <span class="themeName">Cupertino</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/south-street/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_south_street.png" alt="South St" title="South St" /> <span class="themeName">South Street</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/blitzer/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_blitzer.png" alt="Blitzer" title="Blitzer" /> <span class="themeName">Blitzer</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/humanity/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_humanity.png" alt="Humanity" title="Humanity" /> <span class="themeName">Humanity</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/hot-sneaks/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_hot_sneaks.png" alt="Hot Sneaks" title="Hot Sneaks" /> <span class="themeName">Hot sneaks</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/excite-bike/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_excite_bike.png" alt="Excite Bike" title="Excite Bike" /> <span class="themeName">Excite Bike</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/vader/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_black_matte.png" alt="Vader" title="Vader" /> <span class="themeName">Vader</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/dot-luv/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_dot_luv.png" alt="Dot Luv" title="Dot Luv" /> <span class="themeName">Dot Luv</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/mint-choc/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_mint_choco.png" alt="Mint Choc" title="Mint Choc" /> <span class="themeName">Mint Choc</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/black-tie/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_black_tie.png" alt="Black Tie" title="Black Tie" /> <span class="themeName">Black Tie</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/trontastic/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_trontastic.png" alt="Trontastic" title="Trontastic" /> <span class="themeName">Trontastic</span> </a></li> <li><a href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/swanky-purse/jquery-ui.css"> <img src="http://static.jquery.com/ui/themeroller/images/themeGallery/theme_30_swanky_purse.png" alt="Swanky Purse" title="Swanky Purse" /> <span class="themeName">Swanky Purse</span> </a></li> </ul></div></div>').find('div').removeAttr('id');
21
22 //button events
23 button.click(
24 function(){
25 if(switcherpane.is(':visible')){ switcherpane.spHide(); }
26 else{ switcherpane.spShow(); }
27 return false;
28 }
29 );
30
31 //menu events (mouseout didn't work...)
32 switcherpane.hover(
33 function(){},
34 function(){if(switcherpane.is(':visible')){$(this).spHide();}}
35 );
36
37 //show/hide panel functions
38 $.fn.spShow = function(){ $(this).css({top: button.offset().top + options.buttonHeight + 6, left: button.offset().left}).slideDown(50); button.css(button_active); options.onOpen(); }
39 $.fn.spHide = function(){ $(this).slideUp(50, function(){options.onClose();}); button.css(button_default); }
40
41
42 /* Theme Loading
43 ---------------------------------------------------------------------*/
44 switcherpane.find('a').click(function(){
45 updateCSS( $(this).attr('href') );
46 var themeName = $(this).find('span').text();
47 button.find('.jquery-ui-themeswitcher-title').text( options.buttonPreText + themeName );
48 $.cookie(options.cookieName, themeName);
49 options.onSelect();
50 if(options.closeOnSelect && switcherpane.is(':visible')){ switcherpane.spHide(); }
51 return false;
52 });
53
54 //function to append a new theme stylesheet with the new style changes
55 function updateCSS(locStr){
56 var cssLink = $('<link href="'+locStr+'" type="text/css" rel="Stylesheet" class="ui-theme" />');
57 $("head").append(cssLink);
58
59
60 if( $("link.ui-theme").size() > 3){
61 $("link.ui-theme:first").remove();
62 }
63 }
64
65 /* Inline CSS
66 ---------------------------------------------------------------------*/
67 var button_default = {
68 fontFamily: 'Trebuchet MS, Verdana, sans-serif',
69 fontSize: '11px',
70 color: '#666',
71 background: '#eee url(http://jqueryui.com/themeroller/themeswitchertool/images/buttonbg.png) 50% 50% repeat-x',
72 border: '1px solid #ccc',
73 '-moz-border-radius': '6px',
74 '-webkit-border-radius': '6px',
75 textDecoration: 'none',
76 padding: '3px 3px 3px 8px',
77 width: options.width - 11,//minus must match left and right padding
78 display: 'block',
79 height: options.buttonHeight,
80 outline: '0'
81 };
82 var button_hover = {
83 'borderColor':'#bbb',
84 'background': '#f0f0f0',
85 cursor: 'pointer',
86 color: '#444'
87 };
88 var button_active = {
89 color: '#aaa',
90 background: '#000',
91 border: '1px solid #ccc',
92 borderBottom: 0,
93 '-moz-border-radius-bottomleft': 0,
94 '-webkit-border-bottom-left-radius': 0,
95 '-moz-border-radius-bottomright': 0,
96 '-webkit-border-bottom-right-radius': 0,
97 outline: '0'
98 };
99
100
101
102 //button css
103 button.css(button_default)
104 .hover(
105 function(){
106 $(this).css(button_hover);
107 },
108 function(){
109 if( !switcherpane.is(':animated') && switcherpane.is(':hidden') ){ $(this).css(button_default); }
110 }
111 )
112 .find('.jquery-ui-themeswitcher-icon').css({
113 float: 'right',
114 width: '16px',
115 height: '16px',
116 background: 'url(http://jqueryui.com/themeroller/themeswitchertool/images/icon_color_arrow.gif) 50% 50% no-repeat'
117 });
118 //pane css
119 switcherpane.css({
120 position: 'absolute',
121 float: 'left',
122 fontFamily: 'Trebuchet MS, Verdana, sans-serif',
123 fontSize: '12px',
124 background: '#000',
125 color: '#fff',
126 padding: '8px 3px 3px',
127 border: '1px solid #ccc',
128 '-moz-border-radius-bottomleft': '6px',
129 '-webkit-border-bottom-left-radius': '6px',
130 '-moz-border-radius-bottomright': '6px',
131 '-webkit-border-bottom-right-radius': '6px',
132 borderTop: 0,
133 zIndex: 999999,
134 width: options.width-6//minus must match left and right padding
135 })
136 .find('ul').css({
137 listStyle: 'none',
138 margin: '0',
139 padding: '0',
140 overflow: 'auto',
141 overflowX: 'hidden', // NEW
142 height: options.height
143 }).end()
144 .find('li').hover(
145 function(){
146 $(this).css({
147 'borderColor':'#555',
148 'background': 'url(http://jqueryui.com/themeroller/themeswitchertool/images/menuhoverbg.png) 50% 50% repeat-x',
149 cursor: 'pointer'
150 });
151 },
152 function(){
153 $(this).css({
154 'borderColor':'#111',
155 'background': '#000',
156 cursor: 'auto'
157 });
158 }
159 ).css({
160 width: options.width-30,
161 height: '',
162 padding: '2px',
163 margin: '1px',
164 border: '1px solid #111',
165 '-moz-border-radius': '4px',
166 clear: 'left',
167 float: 'left'
168 }).end()
169 .find('a').css({
170 color: '#aaa',
171 textDecoration: 'none',
172 float: 'left',
173 width: '100%',
174 outline: '0'
175 }).end()
176 .find('img').css({
177 float: 'left',
178 border: '1px solid #333',
179 margin: '0 2px'
180 }).end()
181 .find('.themeName').css({
182 float: 'left',
183 margin: '3px 0'
184 }).end();
185
186
187
188 $(this).append(button);
189 $('body').append(switcherpane);
190 switcherpane.hide();
191 if( $.cookie(options.cookieName) || options.loadTheme ){
192 var themeName = $.cookie(options.cookieName) || options.loadTheme;
193 switcherpane.find('a:contains('+ themeName +')').trigger('click');
194 }
195
196 return this;
197};
198
199
200
201
202/**
203 * Cookie plugin
204 *
205 * Copyright (c) 2006 Klaus Hartl (stilbuero.de)
206 * Dual licensed under the MIT and GPL licenses:
207 * http://www.opensource.org/licenses/mit-license.php
208 * http://www.gnu.org/licenses/gpl.html
209 *
210 */
211jQuery.cookie = function(name, value, options) {
212 if (typeof value != 'undefined') { // name and value given, set cookie
213 options = options || {};
214 if (value === null) {
215 value = '';
216 options.expires = -1;
217 }
218 var expires = '';
219 if (options.expires && (typeof options.expires == 'number' || options.expires.toUTCString)) {
220 var date;
221 if (typeof options.expires == 'number') {
222 date = new Date();
223 date.setTime(date.getTime() + (options.expires * 24 * 60 * 60 * 1000));
224 } else {
225 date = options.expires;
226 }
227 expires = '; expires=' + date.toUTCString(); // use expires attribute, max-age is not supported by IE
228 }
229 // CAUTION: Needed to parenthesize options.path and options.domain
230 // in the following expressions, otherwise they evaluate to undefined
231 // in the packed version for some reason...
232 var path = options.path ? '; path=' + (options.path) : '';
233 var domain = options.domain ? '; domain=' + (options.domain) : '';
234 var secure = options.secure ? '; secure' : '';
235 document.cookie = [name, '=', encodeURIComponent(value), expires, path, domain, secure].join('');
236 } else { // only name given, get cookie
237 var cookieValue = null;
238 if (document.cookie && document.cookie != '') {
239 var cookies = document.cookie.split(';');
240 for (var i = 0; i < cookies.length; i++) {
241 var cookie = jQuery.trim(cookies[i]);
242 // Does this cookie string begin with the name we want?
243 if (cookie.substring(0, name.length + 1) == (name + '=')) {
244 cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
245 break;
246 }
247 }
248 }
249 return cookieValue;
250 }
251};
Note: See TracBrowser for help on using the repository browser.