setSkin.js 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. //设置皮肤
  2. function setSkin(skin_class){
  3. if($('#ace-skins-stylesheet').length == 0) {
  4. //let's load skins stylesheet only when needed!
  5. var ace_style = $('head').find('link.ace-main-stylesheet');
  6. if(ace_style.length == 0) {
  7. ace_style = $('head').find('link[href*="/ace.min.css"],link[href*="/ace-part2.min.css"]');
  8. if(ace_style.length == 0) {
  9. ace_style = $('head').find('link[href*="/ace.css"],link[href*="/ace-part2.css"]');
  10. }
  11. }
  12. var stylesheet_url = ace_style.first().attr('href').replace(/(\.min)?\.css$/i , '-skins$1.css');
  13. $.ajax({
  14. 'url': stylesheet_url
  15. }).done(function() {
  16. var new_link = jQuery('<link />', {type : 'text/css', rel: 'stylesheet', 'id': 'ace-skins-stylesheet'})
  17. if(ace_style.length > 0){
  18. new_link.insertAfter(ace_style.last());
  19. }
  20. else new_link.appendTo('head');
  21. new_link.attr('href', stylesheet_url);
  22. //we set "href" after insertion, for IE to work
  23. applyChanges(skin_class);
  24. if(window.Pace && Pace.running) Pace.stop();
  25. })
  26. }
  27. else {
  28. applyChanges(skin_class);
  29. }
  30. function applyChanges(skin_class) {
  31. //skin cookie tip
  32. var body = $(document.body);
  33. body.removeClass('no-skin skin-1 skin-2 skin-3');
  34. //if(skin_class != 'skin-0') {
  35. body.addClass(skin_class);
  36. ace.data.set('skin', skin_class);
  37. //save the selected skin to cookies
  38. //which can later be used by your server side app to set the skin
  39. //for example: <body class="<?php echo $_COOKIE['ace_skin']; ?>"
  40. //} else ace.data.remove('skin');
  41. var skin3_colors = ['red', 'blue', 'green', ''];
  42. //undo skin-1
  43. $('.ace-nav > li.grey').removeClass('dark');
  44. //undo skin-2
  45. $('.ace-nav > li').removeClass('no-border margin-1');
  46. $('.ace-nav > li:not(:last-child)').removeClass('light-pink').find('> a > '+ace.vars['.icon']).removeClass('pink').end().eq(0).find('.badge').removeClass('badge-warning');
  47. $('.sidebar-shortcuts .btn')
  48. .removeClass('btn-pink btn-white')
  49. .find(ace.vars['.icon']).removeClass('white');
  50. //undo skin-3
  51. $('.ace-nav > li.grey').removeClass('red').find('.badge').removeClass('badge-yellow');
  52. $('.sidebar-shortcuts .btn').removeClass('btn-primary btn-white')
  53. var i = 0;
  54. $('.sidebar-shortcuts .btn').each(function() {
  55. $(this).find(ace.vars['.icon']).removeClass(skin3_colors[i++]);
  56. })
  57. var skin0_buttons = ['btn-success', 'btn-info', 'btn-warning', 'btn-danger'];
  58. if(skin_class == 'no-skin') {
  59. var i = 0;
  60. $('.sidebar-shortcuts .btn').each(function() {
  61. $(this).attr('class', 'btn ' + skin0_buttons[i++%4]);
  62. })
  63. $('.sidebar[data-sidebar-scroll=true]').ace_sidebar_scroll('updateStyle', '');
  64. $('.sidebar[data-sidebar-hover=true]').ace_sidebar_hover('updateStyle', 'no-track scroll-thin');
  65. }
  66. else if(skin_class == 'skin-1') {
  67. $('.ace-nav > li.grey').addClass('dark');
  68. var i = 0;
  69. $('.sidebar-shortcuts')
  70. .find('.btn').each(function() {
  71. $(this).attr('class', 'btn ' + skin0_buttons[i++%4]);
  72. })
  73. $('.sidebar[data-sidebar-scroll=true]').ace_sidebar_scroll('updateStyle', 'scroll-white no-track');
  74. $('.sidebar[data-sidebar-hover=true]').ace_sidebar_hover('updateStyle', 'no-track scroll-thin scroll-white');
  75. }
  76. else if(skin_class == 'skin-2') {
  77. $('.ace-nav > li').addClass('no-border margin-1');
  78. $('.ace-nav > li:not(:last-child)').addClass('light-pink').find('> a > '+ace.vars['.icon']).addClass('pink').end().eq(0).find('.badge').addClass('badge-warning');
  79. $('.sidebar-shortcuts .btn').attr('class', 'btn btn-white btn-pink')
  80. .find(ace.vars['.icon']).addClass('white');
  81. $('.sidebar[data-sidebar-scroll=true]').ace_sidebar_scroll('updateStyle', 'scroll-white no-track');
  82. $('.sidebar[data-sidebar-hover=true]').ace_sidebar_hover('updateStyle', 'no-track scroll-thin scroll-white');
  83. }
  84. //skin-3
  85. //change shortcut buttons classes, this should be hard-coded if you want to choose this skin
  86. else if(skin_class == 'skin-3') {
  87. body.addClass('no-skin');//because skin-3 has many parts of no-skin as well
  88. $('.ace-nav > li.grey').addClass('red').find('.badge').addClass('badge-yellow');
  89. var i = 0;
  90. $('.sidebar-shortcuts .btn').each(function() {
  91. $(this).attr('class', 'btn btn-primary btn-white');
  92. $(this).find(ace.vars['.icon']).addClass(skin3_colors[i++]);
  93. })
  94. $('.sidebar[data-sidebar-scroll=true]').ace_sidebar_scroll('updateStyle', 'scroll-dark no-track');
  95. $('.sidebar[data-sidebar-hover=true]').ace_sidebar_hover('updateStyle', 'no-track scroll-thin');
  96. }
  97. //some sizing differences may be there in skins, so reset scrollbar size
  98. $('.sidebar[data-sidebar-scroll=true]').ace_sidebar_scroll('reset')
  99. //$('.sidebar[data-sidebar-hover=true]').ace_sidebar_hover('reset')
  100. if(ace.vars['old_ie']) ace.helper.redraw(document.body, true);
  101. }
  102. }