Enford 5 anos atrás
pai
commit
9d3cddd3a4
100 arquivos alterados com 20071 adições e 0 exclusões
  1. 44 0
      src/main/webapp/static/My97DatePicker/WdatePicker.js
  2. 5 0
      src/main/webapp/static/My97DatePicker/calendar.js
  3. 14 0
      src/main/webapp/static/My97DatePicker/develop/lang/zh-cn.js
  4. 14 0
      src/main/webapp/static/My97DatePicker/develop/lang/zh-tw.js
  5. 3 0
      src/main/webapp/static/My97DatePicker/develop/readme.txt
  6. 267 0
      src/main/webapp/static/My97DatePicker/develop/skin/default/datepicker.css
  7. 339 0
      src/main/webapp/static/My97DatePicker/develop/skin/twoer/datepicker.css
  8. 277 0
      src/main/webapp/static/My97DatePicker/develop/skin/whyGreen/datepicker.css
  9. 110 0
      src/main/webapp/static/My97DatePicker/docs/css/base.css
  10. 97 0
      src/main/webapp/static/My97DatePicker/docs/demo.htm
  11. 25 0
      src/main/webapp/static/My97DatePicker/docs/demo/index.htm
  12. 163 0
      src/main/webapp/static/My97DatePicker/docs/demo/resource/2.1.asp.htm
  13. 382 0
      src/main/webapp/static/My97DatePicker/docs/demo/resource/2.2.asp.htm
  14. 97 0
      src/main/webapp/static/My97DatePicker/docs/demo/resource/2.3.asp.htm
  15. 335 0
      src/main/webapp/static/My97DatePicker/docs/demo/resource/2.4.asp.htm
  16. 260 0
      src/main/webapp/static/My97DatePicker/docs/demo/resource/2.5.asp-.htm
  17. 260 0
      src/main/webapp/static/My97DatePicker/docs/demo/resource/2.5.asp.htm
  18. 71 0
      src/main/webapp/static/My97DatePicker/docs/demo/resource/2.6.asp.htm
  19. 431 0
      src/main/webapp/static/My97DatePicker/docs/demo/resource/3.asp.htm
  20. 177 0
      src/main/webapp/static/My97DatePicker/docs/demo/resource/999.asp-.htm
  21. 177 0
      src/main/webapp/static/My97DatePicker/docs/demo/resource/999.asp.htm
  22. 61 0
      src/main/webapp/static/My97DatePicker/docs/demo/resource/demo.css
  23. 45 0
      src/main/webapp/static/My97DatePicker/docs/demo/resource/demo_iframe.htm
  24. 16 0
      src/main/webapp/static/My97DatePicker/docs/demo/resource/demo_iframe2.htm
  25. 120 0
      src/main/webapp/static/My97DatePicker/docs/demo/resource/left.htm
  26. 64 0
      src/main/webapp/static/My97DatePicker/docs/demo/resource/main.asp
  27. BIN
      src/main/webapp/static/My97DatePicker/docs/demo/resource/pic1.jpg
  28. BIN
      src/main/webapp/static/My97DatePicker/docs/demo/resource/pic2.jpg
  29. BIN
      src/main/webapp/static/My97DatePicker/docs/demo/resource/pic3.jpg
  30. BIN
      src/main/webapp/static/My97DatePicker/docs/images/block/block-body.gif
  31. BIN
      src/main/webapp/static/My97DatePicker/docs/images/block/block-bottom.gif
  32. BIN
      src/main/webapp/static/My97DatePicker/docs/images/block/block-top.gif
  33. BIN
      src/main/webapp/static/My97DatePicker/docs/images/body.jpg
  34. BIN
      src/main/webapp/static/My97DatePicker/docs/images/footer.jpg
  35. 14 0
      src/main/webapp/static/My97DatePicker/lang/en.js
  36. 14 0
      src/main/webapp/static/My97DatePicker/lang/zh-cn.js
  37. 14 0
      src/main/webapp/static/My97DatePicker/lang/zh-tw.js
  38. 2 0
      src/main/webapp/static/My97DatePicker/skin/WdatePicker.css
  39. BIN
      src/main/webapp/static/My97DatePicker/skin/datePicker.gif
  40. 246 0
      src/main/webapp/static/My97DatePicker/skin/default/datepicker.css
  41. BIN
      src/main/webapp/static/My97DatePicker/skin/default/img.gif
  42. 1 0
      src/main/webapp/static/My97DatePicker/skin/twoer/datepicker.css
  43. BIN
      src/main/webapp/static/My97DatePicker/skin/twoer/img.gif
  44. BIN
      src/main/webapp/static/My97DatePicker/skin/twoer/img.png
  45. BIN
      src/main/webapp/static/My97DatePicker/skin/whyGreen/bg.jpg
  46. 256 0
      src/main/webapp/static/My97DatePicker/skin/whyGreen/datepicker.css
  47. BIN
      src/main/webapp/static/My97DatePicker/skin/whyGreen/img.gif
  48. 165 0
      src/main/webapp/static/mCustomScrollbar/demo/COPYING.txt
  49. 96 0
      src/main/webapp/static/mCustomScrollbar/demo/ajax_example.html
  50. 62 0
      src/main/webapp/static/mCustomScrollbar/demo/auto_hide_scrollbar_demo.html
  51. 105 0
      src/main/webapp/static/mCustomScrollbar/demo/auto_scrolling_example.html
  52. 131 0
      src/main/webapp/static/mCustomScrollbar/demo/callbacks_example.html
  53. 384 0
      src/main/webapp/static/mCustomScrollbar/demo/complete_examples.html
  54. 6 0
      src/main/webapp/static/mCustomScrollbar/demo/demo_files/ajax_content.html
  55. 559 0
      src/main/webapp/static/mCustomScrollbar/demo/demo_files/jquery.mCustomScrollbar.css
  56. BIN
      src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsImg1.jpg
  57. BIN
      src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsImg2.jpg
  58. BIN
      src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb1.jpg
  59. BIN
      src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb2.jpg
  60. BIN
      src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb3.jpg
  61. BIN
      src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb4.jpg
  62. BIN
      src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb5.jpg
  63. BIN
      src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb6.jpg
  64. BIN
      src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb7.jpg
  65. BIN
      src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb8.jpg
  66. BIN
      src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcs_demo_bg.jpg
  67. 105 0
      src/main/webapp/static/mCustomScrollbar/demo/disable_destroy_example.html
  68. 71 0
      src/main/webapp/static/mCustomScrollbar/demo/fluid_scrollbar_example.html
  69. 83 0
      src/main/webapp/static/mCustomScrollbar/demo/full_page_demo.html
  70. 114 0
      src/main/webapp/static/mCustomScrollbar/demo/grid_and_snap_while_scrolling_example.html
  71. 62 0
      src/main/webapp/static/mCustomScrollbar/demo/iframe_example.html
  72. 85 0
      src/main/webapp/static/mCustomScrollbar/demo/infinite_scroll_example.html
  73. 74 0
      src/main/webapp/static/mCustomScrollbar/demo/init_hidden_example.html
  74. 4 0
      src/main/webapp/static/mCustomScrollbar/demo/jquery.mCustomScrollbar.concat.min.js
  75. 474 0
      src/main/webapp/static/mCustomScrollbar/demo/jquery.mCustomScrollbar.css
  76. 969 0
      src/main/webapp/static/mCustomScrollbar/demo/jquery.mCustomScrollbar.js
  77. 131 0
      src/main/webapp/static/mCustomScrollbar/demo/jquery_ui_sortable_example.html
  78. 5 0
      src/main/webapp/static/mCustomScrollbar/demo/js/minified/jquery-1.9.1.min.js
  79. 1 0
      src/main/webapp/static/mCustomScrollbar/demo/js/minified/jquery.mCustomScrollbar.min.js
  80. 12 0
      src/main/webapp/static/mCustomScrollbar/demo/js/minified/jquery.mousewheel.min.js
  81. 9597 0
      src/main/webapp/static/mCustomScrollbar/demo/js/uncompressed/jquery-1.9.1.js
  82. 969 0
      src/main/webapp/static/mCustomScrollbar/demo/js/uncompressed/jquery.mCustomScrollbar.js
  83. 84 0
      src/main/webapp/static/mCustomScrollbar/demo/js/uncompressed/jquery.mousewheel.js
  84. 89 0
      src/main/webapp/static/mCustomScrollbar/demo/keyboard_nav_example.html
  85. 66 0
      src/main/webapp/static/mCustomScrollbar/demo/loading_each_script_separately.html
  86. BIN
      src/main/webapp/static/mCustomScrollbar/demo/mCSB_buttons.png
  87. 67 0
      src/main/webapp/static/mCustomScrollbar/demo/max-height_example.html
  88. 76 0
      src/main/webapp/static/mCustomScrollbar/demo/max-width_example.html
  89. 75 0
      src/main/webapp/static/mCustomScrollbar/demo/multiple_scrollbars_example.html
  90. 129 0
      src/main/webapp/static/mCustomScrollbar/demo/nested_scrollbars_demo.html
  91. 116 0
      src/main/webapp/static/mCustomScrollbar/demo/nested_scrollbars_demo_alt.html
  92. 109 0
      src/main/webapp/static/mCustomScrollbar/demo/nested_scrollbars_demo_alt_2.html
  93. 120 0
      src/main/webapp/static/mCustomScrollbar/demo/scroll_buttons_and_snap_scrolling_examples.html
  94. 213 0
      src/main/webapp/static/mCustomScrollbar/demo/scrollbar_themes_demo.html
  95. 63 0
      src/main/webapp/static/mCustomScrollbar/demo/simple_example.html
  96. 92 0
      src/main/webapp/static/mCustomScrollbar/demo/simple_example_all_params.html
  97. BIN
      src/main/webapp/static/mCustomScrollbar/demo/source_files/mCSB_buttons.psd
  98. 103 0
      src/main/webapp/static/mCustomScrollbar/demo/textarea_example.html
  99. 4 0
      src/main/webapp/static/mCustomScrollbar/jquery.mCustomScrollbar.concat.min.js
  100. 0 0
      src/main/webapp/static/mCustomScrollbar/jquery.mCustomScrollbar.css

Diferenças do arquivo suprimidas por serem muito extensas
+ 44 - 0
src/main/webapp/static/My97DatePicker/WdatePicker.js


Diferenças do arquivo suprimidas por serem muito extensas
+ 5 - 0
src/main/webapp/static/My97DatePicker/calendar.js


+ 14 - 0
src/main/webapp/static/My97DatePicker/develop/lang/zh-cn.js

@@ -0,0 +1,14 @@
+var $lang={
+errAlertMsg: "不合法的日期格式或者日期超出限定范围,需要撤销吗?",
+aWeekStr: ["周","日","一","二","三","四","五","六"],
+aLongWeekStr:["周","星期日","星期一","星期二","星期三","星期四","星期五","星期六"],
+aMonStr: ["一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一","十二"],
+aLongMonStr: ["一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月"],
+clearStr: "清空",
+todayStr: "今天",
+okStr: "确定",
+updateStr: "确定",
+timeStr: "时间",
+quickStr: "快速选择", 
+err_1: '最小日期不能大于最大日期!'
+}

+ 14 - 0
src/main/webapp/static/My97DatePicker/develop/lang/zh-tw.js

@@ -0,0 +1,14 @@
+var $lang={
+errAlertMsg: "不合法的日期格式或者日期超出限定範圍,需要撤銷嗎?",
+aWeekStr: ["周","日","一","二","三","四","五","六"],
+aLongWeekStr:["周","星期日","星期一","星期二","星期三","星期四","星期五","星期六"],
+aMonStr: ["一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一","十二"],
+aLongMonStr: ["一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月"],
+clearStr: "清空",
+todayStr: "今天",
+okStr: "確定",
+updateStr: "確定",
+timeStr: "時間",
+quickStr: "快速選擇",
+err_1: '最小日期不能大於最大日期!'
+}

+ 3 - 0
src/main/webapp/static/My97DatePicker/develop/readme.txt

@@ -0,0 +1,3 @@
+正式发布时,可将此文件夹删去
+
+

+ 267 - 0
src/main/webapp/static/My97DatePicker/develop/skin/default/datepicker.css

@@ -0,0 +1,267 @@
+/* 
+ * My97 DatePicker 4.7
+ * 皮肤名称:default
+ */
+
+/* 日期选择容器 DIV */
+.WdateDiv{
+	width:180px;
+	background-color:#FFFFFF;
+	border:#bbb 1px solid;
+	padding:2px;
+}
+/* 双月日历的宽度 */
+.WdateDiv2{
+	width:360px;
+}
+.WdateDiv *{font-size:9pt;}
+
+/****************************
+ * 导航图标 全部是A标签
+ ***************************/
+.WdateDiv .NavImg a{
+	display:block;
+	cursor:pointer;
+	height:16px;
+	width:16px;
+}
+
+.WdateDiv .NavImgll a{
+	float:left;
+	background:transparent url(img.gif) no-repeat scroll 0 0;
+}
+.WdateDiv .NavImgl a{
+	float:left;
+	background:transparent url(img.gif) no-repeat scroll -16px 0;
+}
+.WdateDiv .NavImgr a{
+	float:right;
+	background:transparent url(img.gif) no-repeat scroll -32px 0;
+}
+.WdateDiv .NavImgrr a{
+	float:right;
+	background:transparent url(img.gif) no-repeat scroll -48px 0;
+}
+
+/****************************
+ * 年份月份相关
+ ***************************/
+/* 年份月份栏 DIV */
+.WdateDiv #dpTitle{
+	height:24px;
+	margin-bottom:2px;
+	padding:1px;
+}
+/* 年份月份输入框 INPUT */
+.WdateDiv .yminput{
+	margin-top:2px;
+	text-align:center;
+	height:20px;
+	border:0px;
+	width:50px;
+	cursor:pointer;		
+}
+/* 年份月份输入框获得焦点时的样式 INPUT */
+.WdateDiv .yminputfocus{
+	margin-top:2px;
+	text-align:center;
+	font-weight:bold;
+	height:20px;
+	color:blue;
+	border:#ccc 1px solid;
+	width:50px;
+}
+/* 菜单选择框 DIV */
+.WdateDiv .menuSel{
+	z-index:1;
+	position:absolute;
+	background-color:#FFFFFF;	
+	border:#ccc 1px solid;
+	display:none;
+}
+/* 菜单的样式 TD */
+.WdateDiv .menu{
+	cursor:pointer;
+	background-color:#fff;
+}
+/* 菜单的mouseover样式 TD */
+.WdateDiv .menuOn{
+	cursor:pointer;
+	background-color:#BEEBEE;
+}
+/* 菜单无效时的样式 TD */
+.WdateDiv .invalidMenu{
+	color:#aaa;
+}
+/* 年选择框的偏移 DIV */
+.WdateDiv .YMenu{
+	margin-top:20px;
+	
+}
+/* 月选择框的偏移 DIV */
+.WdateDiv .MMenu{
+	margin-top:20px;
+	*width:62px;
+}
+/* 时选择框的位置 DIV */
+.WdateDiv .hhMenu{
+	margin-top:-90px; 
+	margin-left:26px;
+}
+/* 分选择框的位置 DIV */
+.WdateDiv .mmMenu{
+	margin-top:-46px; 
+	margin-left:26px;
+}
+/* 秒选择框的位置 DIV */
+.WdateDiv .ssMenu{
+	margin-top:-24px; 
+	margin-left:26px;
+}
+
+/****************************
+ * 周相关
+ ***************************/
+ .WdateDiv .Wweek {
+ 	text-align:center;
+	background:#DAF3F5;
+	border-right:#BDEBEE 1px solid;
+ }
+/****************************
+ * 星期,日期相关
+ ***************************/
+/* 星期栏 TR */
+.WdateDiv .MTitle{
+	background-color:#BDEBEE;
+}
+.WdateDiv .WdayTable2{
+	border-collapse:collapse;
+	border:#c5d9e8 1px solid;
+}
+.WdateDiv .WdayTable2 table{
+	border:0;
+}
+/* 日期栏表格 TABLE */
+.WdateDiv .WdayTable{
+	line-height:20px;
+	border:#c5d9e8 1px solid;
+}
+.WdateDiv .WdayTable td{
+	text-align:center;
+}
+/* 日期格的样式 TD */
+.WdateDiv .Wday{
+	cursor:pointer;
+}
+/* 日期格的mouseover样式 TD */
+.WdateDiv .WdayOn{
+	cursor:pointer;
+	background-color:#C0EBEF;
+}
+/* 周末日期格的样式 TD */
+.WdateDiv .Wwday{
+	cursor:pointer;
+	color:#FF2F2F;
+}
+/* 周末日期格的mouseover样式 TD */
+.WdateDiv .WwdayOn{
+	cursor:pointer;
+	color:#000;
+	background-color:#C0EBEF;
+}
+.WdateDiv .Wtoday{
+	cursor:pointer;
+	color:blue;
+}
+.WdateDiv .Wselday{
+	background-color:#A9E4E9;
+}
+.WdateDiv .WspecialDay{
+	background-color:#66F4DF;
+}
+/* 其他月份的日期 */
+.WdateDiv .WotherDay{ 
+	cursor:pointer;
+	color:#6A6AFF;	
+}
+/* 其他月份的日期mouseover样式 */
+.WdateDiv .WotherDayOn{ 
+	cursor:pointer;
+	background-color:#C0EBEF;	
+}
+/* 无效日期的样式,即在日期范围以外日期格的样式,不能选择的日期 */
+.WdateDiv .WinvalidDay{
+	color:#aaa;
+}
+
+/****************************
+ * 时间相关
+ ***************************/
+/* 时间栏 DIV */
+.WdateDiv #dpTime{
+	float:left;
+	margin-top:3px;
+	margin-right:30px;
+}
+/* 时间文字 SPAN */
+.WdateDiv #dpTime #dpTimeStr{
+	margin-left:1px;
+}
+/* 时间输入框 INPUT */
+.WdateDiv #dpTime input{
+	width:18px;
+	height:20px;
+	text-align:center;
+	border:#ccc 1px solid;	
+}
+/* 时间 时 INPUT */
+.WdateDiv #dpTime .tB{
+	border-right:0px;
+}
+/* 时间 分和间隔符 ':' INPUT */
+.WdateDiv #dpTime .tE{
+	border-left:0;
+	border-right:0;
+}
+/* 时间 秒 INPUT */
+.WdateDiv #dpTime .tm{
+	width:7px;
+	border-left:0;
+	border-right:0;
+}
+/* 时间右边的向上按钮 BUTTON */
+.WdateDiv #dpTime #dpTimeUp{
+	height:10px;
+	width:13px;
+	border:0px;
+	background:url(img.gif) no-repeat -32px -16px;
+}
+/* 时间右边的向下按钮 BUTTON */
+.WdateDiv #dpTime #dpTimeDown{
+	height:10px;
+	width:13px;
+	border:0px;
+    background:url(img.gif) no-repeat -48px -16px;
+}
+/****************************
+ * 其他
+ ***************************/
+ .WdateDiv #dpQS {
+ 	float:left;
+	margin-right:3px;
+	margin-top:3px;
+	background:url(img.gif) no-repeat 0px -16px;
+	width:20px;
+	height:20px;
+	cursor:pointer;
+ }
+.WdateDiv #dpControl {
+	text-align:right;	
+}
+.WdateDiv .dpButton{ 
+	height:20px;
+	width:45px;
+	border:#ccc 1px solid;
+	margin-top:2px;
+	margin-right:1px;
+}

+ 339 - 0
src/main/webapp/static/My97DatePicker/develop/skin/twoer/datepicker.css

@@ -0,0 +1,339 @@
+/* 
+ * My97 DatePicker 4.8 
+ * auther : zhangkun , hejianting(design)
+ * email : zhangkun_net@hotmail.com
+ * date : 2012-05-25
+ */ 
+.WdateDiv
+{
+	position:relative;
+	padding:5px;
+	width:180px;
+	*width:190px;
+	font-size:12px;
+	color:#333;
+	border:solid 1px #DEDEDE;
+	background-color:#F2F0F1;
+}
+
+.WdateDiv2
+{
+	width:360px;
+}
+
+.WdateDiv .NavImg a,.WdateDiv .yminput,.WdateDiv .yminputfocus,.WdateDiv #dpQS 
+{
+	background:url(img.gif) no-repeat;
+}
+
+.WdateDiv .NavImg a
+{
+	float:left;
+	width:16px;
+	height:16px;
+	cursor:pointer;
+}
+.WdateDiv .NavImgll a
+{
+	background-position:0px 5px;
+}
+.WdateDiv .NavImgl a
+{
+	background-position:0px -10px;
+}
+.WdateDiv .NavImgr a
+{
+	background-position:0px -25px;
+	float:right;
+}
+.WdateDiv .NavImgrr a
+{
+	background-position:0px -40px;
+	float:right;
+}
+
+.WdateDiv #dpTitle
+{
+	padding:3px 0px 0px 0px;
+	line-height:0px;
+	height:20px;
+	*height:23;
+}
+
+.WdateDiv .yminput,.WdateDiv .yminputfocus
+{
+	margin-left:3px;
+	width:50px;
+	height:20px;
+	line-height:16px;
+	border:solid 1px #F2F0F1;
+	cursor:pointer;
+	background-position:35px -68px;
+}
+
+.WdateDiv .yminputfocus
+{
+	background-color:#fff;
+	border:solid 1px #D8D8D8;
+}
+
+.WdateDiv .menuSel{
+	z-index:1;
+	position:absolute;
+	background-color:#FFFFFF;
+	border:#A3C6C8 1px solid;
+	display:none;
+}
+
+.WdateDiv .menu
+{
+	background:#fff;
+}
+.WdateDiv .menuOn
+{
+	color:#fff;
+	background:#0088CC;
+}
+
+.WdateDiv .invalidMenu{
+	color:#aaa;
+}
+
+.WdateDiv .MMenu,.WdateDiv .YMenu
+{
+	padding:2px;
+	margin-top:20px;
+	margin-left:-1px;
+	width:68px;
+	border:solid 1px #D9D9D9;
+}
+.WdateDiv .MMenu table,.WdateDiv .YMenu table
+{
+	width:100%;
+}
+.WdateDiv .MMenu table td,.WdateDiv .YMenu table td
+{
+	padding:0px;
+	line-height:20px;
+	text-align:center;
+	font-size:12px;
+	cursor: pointer;
+}
+
+.WdateDiv .Wweek {
+ 	text-align:center;
+	background:#DAF3F5;
+	border-right:#BDEBEE 1px solid;
+ }
+
+.WdateDiv td
+{
+	padding:1px;
+	line-height:20px;
+	font-size:12px;
+	color:#999999;
+	background:#fff;
+	cursor:pointer;
+}
+.WdateDiv .MTitle td
+{
+	line-height:24px;
+	color:#7D7D7D;
+	background:#F2F0F1;
+	cursor: default;
+}
+
+.WdateDiv .WdayTable2
+{
+	border-collapse:collapse;
+	border:#808080 1px solid;
+}
+.WdateDiv .WdayTable2 table
+{
+	border:0;
+}
+
+.WdateDiv .WdayTable{
+	line-height:20px;	
+	color:#13777e;
+	background-color:#edfbfb;
+}
+.WdateDiv .WdayTable td{
+	text-align:center;
+}
+
+.WdateDiv .Wday
+{
+	color:#323232;
+}
+
+.WdateDiv .WdayOn
+{
+	color:#fff;
+	background-color:#0088CC;	
+}
+
+.WdateDiv .Wwday
+{
+	color:#0088CC;
+}
+
+.WdateDiv .WwdayOn
+{
+	color:#fff;
+	background-color:#0088CC;	
+}
+.WdateDiv .Wtoday
+{
+	color:#FF6D10;
+	background:#E0EDFE;
+}
+.WdateDiv .Wselday
+{
+	color:#fff;
+	background-color:#0088CC;	
+}
+.WdateDiv .WspecialDay{
+	background-color:#66F4DF;
+}
+
+.WdateDiv .WotherDay
+{ 
+	color:#D4D4D4;	
+}
+.WdateDiv .WotherDayOn
+{
+	color:#fff;
+	background-color:#0088CC;	
+}
+
+.WdateDiv .WinvalidDay{
+	color:#aaa;
+}
+
+.WdateDiv #dpTime
+{
+	position:relative;
+	margin-top:5px;
+}
+
+.WdateDiv #dpTime #dpTimeStr
+{
+	display:inline-block;
+	width:28px;
+	*width:30px;
+	color:#7d7d7d;
+}
+
+.WdateDiv #dpTime input
+{
+	padding:0px;
+	margin:0px;
+	width:25px;
+	height:20px;
+	line-height:20px;
+	text-align:center;
+	color:#333;
+	border:#D9D9D9 1px solid;	
+}
+
+.WdateDiv #dpTime .tm
+{
+	width:7px;
+	border:none;
+	background:#F2F0F1;
+}
+
+.WdateDiv #dpTime #dpTimeUp
+{
+	display:none;
+}
+
+.WdateDiv #dpTime #dpTimeDown
+{
+	display:none;
+}
+
+.WdateDiv #dpQS 
+ {
+ 	float:left;
+	margin-right:3px;
+	margin-top:9px;
+	*margin-top:6px;
+	width:16px;
+	height:16px;
+	cursor:pointer;
+	background-position:0px -90px;
+ }
+.WdateDiv #dpControl 
+{
+	text-align:right;
+	margin-top:3px;
+}
+.WdateDiv .dpButton
+{ 
+	margin-left:2px;
+	line-height:18px;
+	*line-height:16px;
+	width:45px;
+	background-color:#C3C3C3;
+	*background-color:#0055CC;
+	color:#fff;
+	border:none;
+	cursor: pointer;
+}
+.WdateDiv .dpButton:hover
+{ 
+	background-color:#0663A2;
+}
+
+.WdateDiv .hhMenu,
+.WdateDiv .mmMenu,
+.WdateDiv .ssMenu
+{
+	position:absolute;
+	padding:3px;
+	font-size:12px;
+	color:#333;
+	border:solid 1px #DEDEDE;
+	background-color:#F2F0F1;
+}
+
+.WdateDiv #dpTime .menu,.WdateDiv #dpTime .menuOn
+{
+	width:18px;
+	height:18px;
+	line-height:18px;
+	text-align:center;
+	background:#fff;
+}
+.WdateDiv #dpTime .menuOn
+{
+	background:#0088CC;
+}
+
+.WdateDiv #dpTime td
+{
+	background:#F2F0F1;
+}
+
+.WdateDiv .hhMenu
+{
+	top:-87px;
+	left:35px;
+	left:32px\9;
+}
+
+.WdateDiv .mmMenu
+{
+	top:-47px;
+	left:35px;
+	left:32px\9;
+}
+
+.WdateDiv .ssMenu
+{
+	top:-27px;
+	left:35px;
+	left:32px\9;
+}

+ 277 - 0
src/main/webapp/static/My97DatePicker/develop/skin/whyGreen/datepicker.css

@@ -0,0 +1,277 @@
+/* 
+ * My97 DatePicker 4.7
+ * 皮肤名称:whyGreen
+ */
+ 
+/* 日期选择容器 DIV */
+.WdateDiv{
+	width:180px;
+	background-color:#fff;
+	border:#C5E1E4 1px solid;
+	padding:2px;
+}
+/* 双月日历的宽度 */
+.WdateDiv2{
+	width:360px;
+}
+.WdateDiv *{font-size:9pt;}
+
+/****************************
+ * 导航图标 全部是A标签
+ ***************************/
+.WdateDiv .NavImg a{
+	cursor:pointer;
+	display:block;
+	width:16px;
+	height:16px;
+	margin-top:1px;
+}
+
+.WdateDiv .NavImgll a{
+	float:left;
+	background:url(img.gif) no-repeat;
+}
+.WdateDiv .NavImgl a{
+	float:left;
+	background:url(img.gif) no-repeat -16px 0px;
+}
+.WdateDiv .NavImgr a{
+	float:right;
+	background:url(img.gif) no-repeat -32px 0px;
+}
+.WdateDiv .NavImgrr a{
+	float:right;
+	background:url(img.gif) no-repeat -48px 0px;
+}
+/****************************
+ * 年份月份相关
+ ***************************/
+/* 年份月份栏 DIV */
+.WdateDiv #dpTitle{
+	height:24px;
+	padding:1px;
+	border:#c5d9e8 1px solid;
+	background:url(bg.jpg);
+	margin-bottom:2px;
+}
+/* 年份月份输入框 INPUT */
+.WdateDiv .yminput{
+	margin-top:2px;
+	text-align:center;
+	border:0px;
+	height:20px;
+	width:50px;
+	color:#034c50;
+	background-color:transparent;
+	cursor:pointer;
+}
+/* 年份月份输入框获得焦点时的样式 INPUT */
+.WdateDiv .yminputfocus{
+	margin-top:2px;
+	text-align:center;
+	border:#939393 1px solid;
+	font-weight:bold;
+	color:#034c50;	
+	height:20px;
+	width:50px;
+}
+/* 菜单选择框 DIV */
+.WdateDiv .menuSel{
+	z-index:1;
+	position:absolute;
+	background-color:#FFFFFF;
+	border:#A3C6C8 1px solid;
+	display:none;
+}
+/* 菜单的样式 TD */
+.WdateDiv .menu{
+	cursor:pointer;
+	background-color:#fff;
+	color:#11777C;
+}
+/* 菜单的mouseover样式 TD */
+.WdateDiv .menuOn{
+	cursor:pointer;
+	background-color:#BEEBEE;
+}
+/* 菜单无效时的样式 TD */
+.WdateDiv .invalidMenu{
+	color:#aaa;
+}
+/* 年选择框的偏移 DIV */
+.WdateDiv .YMenu{
+	margin-top:20px;
+}
+/* 月选择框的偏移 DIV */
+.WdateDiv .MMenu{
+	margin-top:20px;
+	*width:62px;
+}
+/* 时选择框的位置 DIV */
+.WdateDiv .hhMenu{
+	margin-top:-90px; 
+	margin-left:26px;
+}
+/* 分选择框的位置 DIV */
+.WdateDiv .mmMenu{
+	margin-top:-46px; 
+	margin-left:26px;
+}
+/* 秒选择框的位置 DIV */
+.WdateDiv .ssMenu{
+	margin-top:-24px; 
+	margin-left:26px;
+}
+
+/****************************
+ * 周相关
+ ***************************/
+ .WdateDiv .Wweek {
+ 	text-align:center;
+	background:#DAF3F5;
+	border-right:#BDEBEE 1px solid;
+ }
+/****************************
+ * 星期,日期相关
+ ***************************/
+ /* 星期栏 TR */
+.WdateDiv .MTitle{
+	color:#13777e;
+	background-color:#bdebee;
+}
+.WdateDiv .WdayTable2{
+	border-collapse:collapse;
+	border:#BEE9F0 1px solid;
+}
+.WdateDiv .WdayTable2 table{
+	border:0;
+}
+/* 日期栏表格 TABLE */
+.WdateDiv .WdayTable{
+	line-height:20px;	
+	color:#13777e;
+	background-color:#edfbfb;
+	border:#BEE9F0 1px solid;
+}
+.WdateDiv .WdayTable td{
+	text-align:center;
+}
+/* 日期格的样式 TD */
+.WdateDiv .Wday{
+	cursor:pointer;
+}
+/* 日期格的mouseover样式 TD */
+.WdateDiv .WdayOn{
+	cursor:pointer;
+	background-color:#74d2d9 ;
+}
+/* 周末日期格的样式 TD */
+.WdateDiv .Wwday{
+	cursor:pointer;
+	color:#ab1e1e;
+}
+/* 周末日期格的mouseover样式 TD */
+.WdateDiv .WwdayOn{
+	cursor:pointer;
+	background-color:#74d2d9;
+}
+.WdateDiv .Wtoday{
+	cursor:pointer;
+	color:blue;
+}
+.WdateDiv .Wselday{
+	background-color:#A7E2E7;
+}
+.WdateDiv .WspecialDay{
+	background-color:#66F4DF;
+}
+/* 其他月份的日期 */
+.WdateDiv .WotherDay{ 
+	cursor:pointer;
+	color:#0099CC;	
+}
+/* 其他月份的日期mouseover样式 */
+.WdateDiv .WotherDayOn{ 
+	cursor:pointer;
+	background-color:#C0EBEF;	
+}
+/* 无效日期的样式,即在日期范围以外日期格的样式,不能选择的日期 */
+.WdateDiv .WinvalidDay{
+	color:#aaa;
+}
+
+/****************************
+ * 时间相关
+ ***************************/
+/* 时间栏 DIV */
+.WdateDiv #dpTime{
+	float:left;
+	margin-top:3px;
+	margin-right:30px;
+}
+/* 时间文字 SPAN */
+.WdateDiv #dpTime #dpTimeStr{
+	margin-left:1px;
+	color:#497F7F;
+}
+/* 时间输入框 INPUT */
+.WdateDiv #dpTime input{
+	height:20px;
+	width:18px;
+	text-align:center;
+	color:#333;
+	border:#61CAD0 1px solid;	
+}
+/* 时间 时 INPUT */
+.WdateDiv #dpTime .tB{
+	border-right:0px;
+}
+/* 时间 分和间隔符 ':' INPUT */
+.WdateDiv #dpTime .tE{
+	border-left:0;
+	border-right:0;
+}
+/* 时间 秒 INPUT */
+.WdateDiv #dpTime .tm{
+	width:7px;
+	border-left:0;
+	border-right:0;
+}
+/* 时间右边的向上按钮 BUTTON */
+.WdateDiv #dpTime #dpTimeUp{
+	height:10px;
+	width:13px;
+	border:0px;
+	background:url(img.gif) no-repeat -32px -16px;
+}
+/* 时间右边的向下按钮 BUTTON */
+.WdateDiv #dpTime #dpTimeDown{
+	height:10px;
+	width:13px;
+	border:0px;
+	background:url(img.gif) no-repeat -48px -16px;
+}
+/****************************
+ * 其他
+ ***************************/
+ .WdateDiv #dpQS {
+ 	float:left;
+	margin-right:3px;
+	margin-top:3px;
+	background:url(img.gif) no-repeat 0px -16px;
+	width:20px;
+	height:20px;
+	cursor:pointer;
+ }
+.WdateDiv #dpControl {
+	text-align:right;
+	margin-top:3px;
+}
+.WdateDiv .dpButton{ 
+	height:20px;
+	width:45px;
+	margin-top:2px;
+	border:#38B1B9 1px solid;
+	background-color:#CFEBEE;
+	color:#08575B;
+}

+ 110 - 0
src/main/webapp/static/My97DatePicker/docs/css/base.css

@@ -0,0 +1,110 @@
+* {
+	margin: 0;
+	padding: 0;
+}
+body {
+	background: #5b5b5b;
+	color: #000;
+	text-align: center;
+	line-height: 1.6;
+}
+body, input, select, textarea, table {
+	font-family: "ËÎÌå",Arial, Simsun, Verdana, sans-serif;
+	font-size: 9pt;
+	color:#333;
+}
+img {
+	border: none;
+}
+a {
+	color: #4264BD;
+}
+li {
+	line-height:20px;
+}
+.dCenter {
+	width: 800px;
+	margin: 0 auto;
+	text-align: left;
+}
+
+.dBody{
+	background:url("../images/body.jpg") repeat-y top;
+}
+
+.nav {
+	list-style:none;
+	float: right;
+	margin-right: 25px;
+}
+.nav li {
+	margin-left: 20px;
+	float: left;
+}
+
+.navbar {
+	height: 0px;
+	line-height: 28px;
+	margin-bottom: 6px;
+	color: #fff;	
+	font-size: 14px;
+}
+.navbar a {
+	color: #fff;
+	text-decoration: none;
+}
+.navbar a:hover {
+	text-decoration: none;
+	color: #ccc;
+}
+
+.res-block {
+	BACKGROUND: url("../images/block/block-top.gif") no-repeat; MARGIN-BOTTOM: 15px; WIDTH: 210px; PADDING-TOP: 5px
+}
+.res-block-inner {
+	PADDING-RIGHT: 11px; PADDING-LEFT: 11px; BACKGROUND: url("../images/block/block-body.gif") repeat-y left; PADDING-BOTTOM: 6px; PADDING-TOP: 6px
+}
+.res-block-bottom {
+	BACKGROUND: url("../images/block/block-bottom.gif") no-repeat; WIDTH: 210px;height:5px;
+}
+.res-block H3 {
+	MARGIN-BOTTOM: 8px; FONT: bold 12px ËÎÌå,tahoma,arial,sans-serif; COLOR: #555
+}
+.res-block UL {
+	FONT: 12px tahoma,arial,sans-serif; MARGIN-LEFT: 15px; COLOR: #555; LIST-STYLE-TYPE: disc
+}
+.res-block UL LI {
+	MARGIN: 0px 0px 5px 3px
+}
+#footer {
+	background:url("../images/footer.jpg") no-repeat;
+	height:47px;
+	text-align:center;
+	padding-top:9px;
+	color:#CCC;
+	font-family:Arial;
+}
+#footer a {
+	color: #DDD;
+	text-decoration: none;
+}
+/*.logo {
+	float: left;
+	margin: 6px 0 0 13px;
+}
+
+#footer {
+	margin-bottom: 25px;
+	line-height: normal;
+	color: #666;
+	text-align: center;
+	clear: both;
+}
+#footer a {
+	color: #666;
+}
+#footer a{text-decoration:none;}
+#footer a:hover{text-decoration:underline;color:#333;}
+* html .mmlink{width:200px;float:right;margin-right:250px;}
+.mmlink{width:250px;float:right;margin-right:450px; }
+*/

+ 97 - 0
src/main/webapp/static/My97DatePicker/docs/demo.htm

@@ -0,0 +1,97 @@
+<script language="javascript" type="text/javascript" src="../WdatePicker.js"></script>
+
+
+<input class="Wdate" type="text" onClick="WdatePicker()"> <font color=red>&lt;- 点我弹出日期控件</font>
+
+<script src="${ctxStatic}/My97DatePicker/WdatePicker.js" type="text/javascript"></script>
+
+<input id="inputDate" name="inputDate" type="text" readonly="readonly"
+	value="<fmt:formatDate value="${article.inputDate}" pattern="yyyy-MM-dd HH:mm:ss" maxlength="20" class="input-medium Wdate"/>"
+	onclick="WdatePicker({dateFmt:'yyyy-MM-dd HH:mm:ss',isShowClear:false,startDate:'%y-%M-01 00:00:00',alwaysUseStartDate:true});"/>
+						
+<br><br><br><br>
+更多demo请访问官方主页 <a href="http://www.my97.net">http://www.my97.net</a>
+
+<br><br>
+<h1>请务必仔细阅读下面的文字</h1><br>
+<pre>
+注意:此版本为 4.8 Beta2 build 20111221
+
+更新内容:
+[新增]preload预载选项
+[增强]验证功能可被关闭errDealMode=-1
+[修改]调整周算法模式,新增weekMethod属性
+[修改]去除My97DatePicker.htm
+[修改]position改成相对坐标(原来为绝对坐标)
+[修正]跨域错误问题
+[修正]onchange不能触发的问题
+[修正]兼容Safari5
+[修正]&lt;script&gt;空标签时的错误
+[修正]平面模式下的几个偶发问题
+[修正]双月日历下跨年选择出错的问题
+[修正]修正复杂iframe下,弹出位置偏移的问题(很偶发的情况)
+
+
+
+使用方法:
+
+1. 去官方网站看看,你当前下载的是否是最新的版本,很多bug都是因为使用的不是最新版本造成的
+官方主页:<a href="http://www.my97.net" target="_blank">http://www.my97.net</a>
+
+
+2. 将My97DatePicker整个目录包,放入您的项目的相应目录下
+
+My97DatePicker目录下各文件的作用:
+  1.1 My97DatePicker目录是一个整体,不可破坏里面的目录结构,也不可对里面的文件改名,可以改目录名
+  1.2 各目录及文件的用途:
+    WdatePicker.js 配置文件,在调用的地方仅需使用该文件,可多个共存,以xx_WdatePicker.js方式命名
+    calendar.js 日期库主文件,无需引入
+    目录lang 存放语言文件,你可以根据需要清理或添加语言文件
+    目录skin 存放皮肤的相关文件,你可以根据需要清理或添加皮肤文件包
+
+
+3. 您可以根据您自己的需要,删除不必要的皮肤和语言文件
+
+
+4. 您可以根据您自己的需要,添加新的皮肤包
+皮肤中心地址:<a href="http://www.my97.net/dp/skin.asp" target="_blank">http://www.my97.net/dp/skin.asp</a>
+
+
+5. 详细阅读在线演示和使用说明,大部分问题都可以通过这里解决,请细看
+在线演示:<a href="http://www.my97.net/dp/demo/" target="_blank">http://www.my97.net/dp/demo/</a>
+
+
+6. 如果遇到无法解决的问题
+请先参考:<a href="http://www.my97.net/dp/support.asp" target="_blank">http://www.my97.net/dp/support.asp</a>
+
+
+7. 如果遇到问题,而技术支持页面无法解决的
+您可以通过技术支持页面中提供的联系方式联系我,注意:问问题时,一定要附上相关的HTML代码和详细的错误信息
+
+
+8. 您有什么意见或建议,你可以通过技术支持页面中提供的联系方式联系我
+
+
+9. 如果您对日期控件的许可协议有兴趣,您可以访问:<a href="http://www.my97.net/dp/license.asp">http://www.my97.net/dp/license.asp</a>
+
+
+10.最后祝大家项目顺利,月月加薪!
+
+---------------------------------------------------------------------
+官方主页
+<a href="http://www.my97.net" target="_blank">http://www.my97.net</a>
+
+在线演示和使用说明
+<a href="http://www.my97.net/dp/demo/" target="_blank">http://www.my97.net/dp/demo/</a>
+
+皮肤中心:
+<a href="http://www.my97.net/dp/skin.asp" target="_blank">http://www.my97.net/dp/skin.asp</a>
+
+许可协议
+<a href="http://www.my97.net/dp/license.asp">http://www.my97.net/dp/license.asp</a>  
+
+源代码:
+<a href="http://www.my97.net/dp/source.asp" target="_blank">http://www.my97.net/dp/source.asp</a>
+
+技术支持页面
+<a href="http://www.my97.net/dp/support.asp" target="_blank">http://www.my97.net/dp/support.asp</a></pre>

+ 25 - 0
src/main/webapp/static/My97DatePicker/docs/demo/index.htm

@@ -0,0 +1,25 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
+<title>My97ÈÕÆÚ¿Ø¼þ ÑÝʾ & Îĵµ My97 DatePicker Demo & Doc</title>
+<script>
+window.onload = function() {
+var mainFrm = document.getElementById('mainFrm');
+var loc = location.href.toLowerCase()
+var start=loc.indexOf('?')+1;
+if(start>0){	
+	mainFrm.src = "resource/"+loc.substr(start);
+}
+else{
+	mainFrm.src = "resource/main.asp";
+}
+}
+</script>
+</head>
+<frameset rows="*" cols="242,*">
+  <frame src="resource/left.htm" tppabs="http://www.my97.net/dp/demo/resource/left.htm" id="leftFrm" />
+  <frame src="about:blank" id="mainFrm" name="mainFrm" />  
+</frameset>
+<noframes></noframes>
+</html>

+ 163 - 0
src/main/webapp/static/My97DatePicker/docs/demo/resource/2.1.asp.htm

@@ -0,0 +1,163 @@
+
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
+<meta name="keywords" content="日期控件 datepicker calendar 日历控件 javascript js日历控件 带时间 自定义格式 月历控件 日期时间 日期选择" />
+<title>My97日期控件 功能演示 常规功能 My97 Datepicker Demo</title>
+<link href="../../css/base.css" tppabs="http://www.my97.net/dp/css/base.css" rel="stylesheet" type="text/css" />
+<link href="demo.css" tppabs="http://www.my97.net/dp/demo/resource/demo.css" rel="stylesheet" type="text/css" />
+</head>
+<body>
+<iframe src="../../head.asp" tppabs="http://www.my97.net/dp/head.asp" scrolling="no" frameborder="0" height="100px" width="100%"></iframe>
+<script language="JavaScript" type="text/javascript" src="../../../WdatePicker.js" tppabs="http://www.my97.net/dp/My97DatePicker/WdatePicker.js"></script>
+<div class="dCenter dBody">
+  <div id="content">
+
+
+    <h2>二. 功能及示例<a name="m2" id="m2"></a></h2>
+    <h3>1. 常规功能<a name="m21" id="m21"></a></h3>
+    <ol>
+      <li>支持多种调用模式 <a name="m211" id="m211"></a>
+        <p>除了支持常规在input单击或获得焦点调用外,还支持使用其他的元素如:&lt;img&gt;&lt;div&gt;等触发WdatePicker函数来调用弹出日期框</p>
+        <div>
+          <h4>示例1-1-1 常规调用</h4>
+          <p>
+            <input type="text" id="d11" onClick="WdatePicker()"/>
+            <br />
+            &lt;input id=&quot;d11&quot; type=&quot;text&quot; <span class="STYLE1">onClick=&quot;WdatePicker()&quot;</span>/&gt;</p>
+        </div>
+        <div>
+          <h4>示例1-1-2 图标触发</h4>
+          <p>
+            <input id="d12" type="text"/>
+            <img src="../../../skin/datePicker.gif" tppabs="http://www.my97.net/dp/My97DatePicker/skin/datePicker.gif" width="16" height="22" align="absmiddle" style="cursor:pointer" onClick="WdatePicker({el:'d12'})" /> <br />
+            &lt;input id=&quot;<span class="STYLE1">d12</span>&quot; type=&quot;text&quot;/&gt;<br />
+            &lt;img onclick=&quot;WdatePicker({<span class="STYLE2">el:</span><span class="STYLE1">'d12'</span>})&quot;  src=&quot;../skin/datePicker.gif&quot; width=&quot;16&quot; height=&quot;22&quot; align=&quot;absmiddle&quot;&gt;<br />
+          <span class="STYLE1">注意:</span>只需要传入控件的id即可</p>
+        </div>
+      </li>
+      <li>下拉,输入,导航选择日期<a name="m212" id="m212"></a>
+        <p>年月时分秒输入框都具备以下三种特性 <br />
+          1.
+          通过导航图标选择<br />
+          <img src="pic1.jpg" tppabs="http://www.my97.net/dp/demo/resource/pic1.jpg" width="180" height="197" /><br />
+          <br />
+          2. 直接使用键盘输入数字<br />
+          <img src="pic2.jpg" tppabs="http://www.my97.net/dp/demo/resource/pic2.jpg" width="180" height="197" /><br />
+          <br />
+          3. 直接从弹出的下拉框中选择<br />
+          <img src="pic3.jpg" tppabs="http://www.my97.net/dp/demo/resource/pic3.jpg" width="180" height="197" /><br />
+          <br />
+          <span class="STYLE2">另:年份输入框有智能提示功能,当用户连续点击同一个导航按钮5次时,会自动弹出年份下拉框</span></p>
+      </li>
+      <li>支持周显示 <a name="m213" id="m213"></a>
+        <p>可以通过配置isShowWeek属性决定是否限制周,并且在返回日期的时候还可以通过自带的自定义事件和API函数返回选择的周</p>
+        <br />
+        <div>
+          <h4>示例1-2-1 周显示简单应用 </h4>
+          <p>
+            <input id="d121" type="text" onfocus="WdatePicker({isShowWeek:true})"/>
+            <br />
+            &lt;input id=&quot;d121&quot; type=&quot;text&quot; onfocus=&quot;WdatePicker({<span class="STYLE2">isShowWeek:</span><span class="STYLE1">true</span>})&quot;/&gt;<br />
+            <br />
+          <span class="STYLE1">注意:周算法参考的是ISO8601定义的方法,如果您对此有疑问,请详见:</span><a href="javascript:if(confirm('http://en.wikipedia.org/wiki/ISO_week_date  \n\n该文件未被 Teleport Pro 下载,因为 它位于起始地址以设置的边界以外的域或路径中。  \n\n你想要从服务器打开它吗?'))window.location='http://en.wikipedia.org/wiki/ISO_week_date'" tppabs="http://en.wikipedia.org/wiki/ISO_week_date" target="_blank">http://en.wikipedia.org/wiki/ISO_week_date</a><br />
+          <br />
+          周算法选择<span class="STYLE1">(4.8新增)</span><br />
+          相关属性:<span class="STYLE2">weekMethod</span><br />
+周算法不同的地方有一些差异<br />
+常见算法有两种<br />
+1. ISO8601:规定第一个星期四为第一周,默认值<br />
+2. MSExcel:1月1日所在的周</p>
+        </div>
+        <div>
+          <h4>示例1-2-2 利用onpicked事件把周赋值给另外的文本框</h4>
+          <p>
+            <input type="text" class="Wdate" id="d122" onFocus="WdatePicker({isShowWeek:true,onpicked:function(){$dp.$('d122_1').value=$dp.cal.getP('W','W');$dp.$('d122_2').value=$dp.cal.getP('W','WW');}})"/>
+            &nbsp;&nbsp;
+            您选择了第
+            <input type="text" id="d122_1" size="3"/>
+            (W格式)周, 另外您可以使用WW格式:
+            <input  type="text" id="d122_2" size="3"/>
+            周 <br />
+            &lt;input type=&quot;text&quot; class=&quot;Wdate&quot; id=&quot;d122&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">isShowWeek:</span><span class="STYLE1">true</span>,<span class="STYLE2">onpicked:</span><span class="STYLE1">function() {$dp.$('d122_1').value=$dp.cal.getP('W','W');$dp.$('d122_2').value=$dp.cal.getP('W','WW');}</span>})&quot;/&gt;<br />
+            <br />
+            onpicked 用法详见<a href="2.5.asp.htm#m251" tppabs="http://www.my97.net/dp/demo/resource/2.5.asp#m251">自定义事件</a><br />
+            $dp.cal.getP 用法详见<a href="999.asp.htm#m5" tppabs="http://www.my97.net/dp/demo/resource/999.asp#m5">内置函数和属性</a><br />
+          </p>
+        </div>
+      </li>
+      <li>只读开关,高亮周末功能 <a name="m214" id="m214"></a>
+        <p>设置readOnly属性 true 或 false 可指定日期框是否只读 <br />
+          设置highLineWeekDay属性 ture 或 false 可指定是否高亮周末 </p>
+      </li>
+      <li>操作按钮自定义 <a name="m215" id="m215"></a>
+        <p>清空按钮和今天按钮,可以根据需要进行自定义,它们分别对应 isShowClear 和 isShowToday 默认值都是true</p>
+        <div>
+          <h4>示例1-5 禁用清空功能</h4>
+          <p> 最好把readOnly置为true,否则即使隐藏了清空按钮,用户依然可以在输入框里把值delete掉<br />
+            <input class="Wdate" type="text" id="d15" onFocus="WdatePicker({isShowClear:false,readOnly:true})"/>
+            <br />
+            &lt;input class=&quot;Wdate&quot; type=&quot;text&quot; id=&quot;d15&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">isShowClear:</span><span class="STYLE1">false</span>,<span class="STYLE2">readOnly:</span><span class="STYLE1">true</span>})&quot;/&gt;</p>
+        </div>
+      </li>
+      <li>自动选择显示位置<a name="m216" id="m216"></a>
+        <p>当控件处在页面边界时,它会自动选择显示的位置,所以没有必要担心弹出框会被页面边界遮住的问题了.</p>
+      </li>
+      <li>自定义弹出位置 <a name="m217" id="m217"></a>
+        <p>当控件处在页面边界时,它会自动选择显示的位置.此外你还可以使用position参数对弹出位置做调整.</p>
+        <br />
+        <div>
+          <h4>示例1-6 通过position属性,自定义弹出位置</h4>
+          <p>使用positon属性指定,弹出日期的坐标为{left:100,top:50}<br />
+            <input class="Wdate" type="text" id="d16" onfocus="WdatePicker({position:{left:100,top:50}})"/>
+            <br />
+            &lt;input class=&quot;Wdate&quot; type=&quot;text&quot; id=&quot;d16&quot; onfocus=&quot;WdatePicker({<span class="STYLE2">position:</span><span class="STYLE1">{left:100,top:50}</span>})&quot;/&gt;<br />
+            <br />
+            position属性的详细用法详见<a href="3.asp.htm#m31" tppabs="http://www.my97.net/dp/demo/resource/3.asp#m31">属性表</a></p>
+        </div>
+      </li>
+      <li>自定义星期的第一天<span class="STYLE1">(4.6新增)</span><a name="m218" id="m218"></a>
+        <p>各个国家的习惯不同,有些喜欢以星期日作为第一天,有些以星期一作为第一天.<br />
+相关属性:<span class="STYLE2">firstDayOfWeek</span>: 可设置 0 - 6 的任意一个数字,0:星期日 1:星期一 以此类推</p>
+      <div>
+          <h4>示例1-7 以星期一作为第一天</h4>
+          <p>
+            <input class="Wdate" type="text" id="d17" onfocus="WdatePicker({firstDayOfWeek:1})"/>
+            <br />
+            &lt;input class=&quot;Wdate&quot; type=&quot;text&quot; id=&quot;d17&quot; onfocus=&quot;WdatePicker({<span class="STYLE2">firstDayOfWeek:</span><span class="STYLE1">1</span>})&quot;/&gt;<br />
+          </p>
+        </div>
+      </li>
+    </ol>
+    <h3><a href="2.2.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.2.asp">2. 特色功能</a> <a name="m22" id="m22"></a></h3>
+    <h3><a href="2.3.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.3.asp">3. 多语言和自定义皮肤</a><a name="m23" id="m23"></a></h3>
+    <h3><a href="2.4.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp">4. 日期范围限制</a><a name="m24" id="m24"></a></h3>
+    <h3><a href="2.5.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.5.asp">5. 自定义事件</a><a name="m25" id="m25"></a></h3>
+    <h3><a href="2.6.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.6.asp">6. 快速选择功能</a> <a name="m26" id="m26"></a></h3>
+    <h2><a href="3.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/3.asp">三. 配置说明</a><a name="m3" id="m3"></a></h2>
+    <h2><a href="999.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/999.asp">四. 如何使用</a><a name="m4" id="m4"></a></h2>
+    <br />
+    <br />
+  </div>
+  <div style="clear:both"></div>
+</div>
+<div class="dCenter dBody" style="padding-left:72px">
+<script type="text/javascript"><!--
+google_ad_client = "ca-pub-6343250634002651";
+/* 底部 */
+google_ad_slot = "0599809152";
+google_ad_width = 728;
+google_ad_height = 90;
+//-->
+</script>
+<script type="text/javascript">
+</script>
+</div>
+<div id="footer" class="dCenter">&copy; 2010 <a href="mailto:smallcarrot@163.com">My97</a> All Rights Reserved.&nbsp;&nbsp;&nbsp;&nbsp;<script type="text/javascript">
+var _bdhmProtocol = (("https:" == document.location.protocol) ? " https://" : " http://");
+document.write(unescape("%3Cscript src='" + _bdhmProtocol + "hm.baidu.com/h.js%3F489957c212e14340592fb2e4921b2f1d' type='text/javascript'%3E%3C/script%3E"));
+</script>&nbsp;&nbsp;&nbsp;&nbsp;浙ICP备11060275号
+</div>
+</body>
+</html>

+ 382 - 0
src/main/webapp/static/My97DatePicker/docs/demo/resource/2.2.asp.htm

@@ -0,0 +1,382 @@
+
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
+<meta name="keywords" content="日期控件 datepicker calendar 日历控件 javascript js日历控件 带时间 自定义格式 月历控件 日期时间 日期选择" />
+<title>My97日期控件 功能演示 特色功能 常规功能 My97 Datepicker Demo</title>
+<link href="../../css/base.css" tppabs="http://www.my97.net/dp/css/base.css" rel="stylesheet" type="text/css" />
+<link href="demo.css" tppabs="http://www.my97.net/dp/demo/resource/demo.css" rel="stylesheet" type="text/css" />
+</head>
+<body>
+<iframe src="../../head.asp" tppabs="http://www.my97.net/dp/head.asp" scrolling="no" frameborder="0" height="100px" width="100%"></iframe>
+<script language="JavaScript" type="text/javascript" src="../../../WdatePicker.js" tppabs="http://www.my97.net/dp/My97DatePicker/WdatePicker.js"></script>
+<div class="dCenter dBody">
+  <div id="content">
+
+    <h2>二. 功能及示例<a name="m2" id="m2"></a></h2>
+<h3>2. 特色功能 <a name="m22" id="m22"></a></h3>
+    <ol>
+      <li>平面显示
+        <a name="m221" id="m221"></a>
+        <p>日期控件支持平面显示功能,只要设置一下eCont属性就可以把它当作日历来使用了,无需触发条件,直接显示在页面上</p>
+        <br />
+        <div>
+          <h4>示例2-1 平面显示演示</h4>
+          <div id="div1" style="border:0;padding:5px"></div>
+          <script> 
+WdatePicker({eCont:'div1',onpicked:function(dp){alert('你选择的日期是:'+dp.cal.getDateStr())}})
+</script>
+          <p> &lt;div id=&quot;<span class="STYLE1">div1</span>&quot;&gt;&lt;/div&gt;<br />
+            &lt;script&gt;<br />
+            WdatePicker({<span class="STYLE2">eCont:</span><span class="STYLE1">'div1'</span>,onpicked:function(dp){alert('你选择的日期是:'+dp.cal.getDateStr())}})<br />
+            &lt;/script&gt;<br />
+            <br />
+            $dp.cal.getDateStr 用法详见<a href="999.asp.htm#m5" tppabs="http://www.my97.net/dp/demo/resource/999.asp#m5">内置函数和属性</a></p>
+        </div>
+      </li>
+      <li>支持多种容器
+        <a name="m222" id="m222"></a>
+        <p>除了可以将值返回给input以外,还可以通过配置el属性将值返回给其他的元素(如:textarea,div,span)等,带有innerHTML属性的HTML元素</p>
+        <div>
+          <h4>示例2-2 将日期返回到&lt;span&gt;中</h4>
+          <p><span id="demospan">2008-01-01</span> <img onClick="WdatePicker({el:'demospan'})" src="../../../skin/datePicker.gif" tppabs="http://www.my97.net/dp/My97DatePicker/skin/datePicker.gif" width="16" height="22" align="absmiddle" style="cursor:pointer" /><br />
+            <br />
+            代码:<br />
+            &lt;span id=&quot;<span class="STYLE1">demospan</span>&quot;&gt;2008-01-01&lt;/span&gt; <br />
+            &lt;img onClick=&quot;WdatePicker({<span class="STYLE2">el:</span><span class="STYLE1">'demospan'</span>})&quot; src=&quot;../../../skin/datePicker.gif&quot; width=&quot;16&quot; height=&quot;22&quot; align=&quot;absmiddle&quot; style=&quot;cursor:pointer&quot;  /&gt;</p>
+        </div>
+      </li>
+      <li>起始日期功能 <a name="m223" id="m223"></a><br />
+        <span class="STYLE1">注意:日期格式必须与 realDateFmt 和 realTimeFmt 一致而不是与 dateFmt 一致</span>
+        <p>有时在项目中需要选择生日之类的日期,而默认点开始日期都是当前日期,导致年份选择非常麻烦,你可以通过起始日期功能加上配置alwaysUseStartDate属性轻松解决此类问题</p>
+        <div>
+          <h4>示例2-3-1 起始日期简单应用 </h4>
+          <p>默认的起始日期为 1980-05-01<br />
+            当日期框<span class="STYLE2">为空值时</span>,将使用 1980-05-01 做为起始日期 <br />
+            <br />
+            <input type="text" id="d221" onFocus="WdatePicker({startDate:'1980-05-01'})"/>
+            <br />
+            &lt;input type=&quot;text&quot; id=&quot;d221&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">startDate:</span><span class="STYLE1">'1980-05-01'</span>})&quot;/&gt;</p>
+        </div>
+        <div>
+          <h4>示例2-3-2 alwaysUseStartDate属性应用</h4>
+          <p>默认的起始日期为 1980-05-01<br />
+            当日期框<span class="STYLE2">无论是何值</span>,始终使用 1980-05-01 做为起始日期 <br />
+            <br />
+            <input type="text" id="d222" onfocus="WdatePicker({startDate:'1980-05-01',alwaysUseStartDate:true})"/>
+            <br />
+            &lt;input type=&quot;text&quot; id=&quot;d222&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">startDate:</span><span class="STYLE1">'1980-05-01'</span>,<span class="STYLE2">alwaysUseStartDate:</span><span class="STYLE1">true</span>})&quot;/&gt;</p>
+        </div>
+        <div>
+          <h4>示例2-3-3 使用内置参数</h4>
+          <p>除了使用静态的日期值以外,还可以使用动态参数(如:%y,%M分别表示当前年和月)<br />
+            <br />
+            下例演示,<span class="STYLE2">年月日使用当年当月的1日,时分秒使用00:00:00作为起始时间</span><br />
+            <br />
+            <input type="text" id="d233" onFocus="WdatePicker({startDate:'%y-%M-01 00:00:00',dateFmt:'yyyy-MM-dd HH:mm:ss',alwaysUseStartDate:true})"/>
+            <br />
+            &lt;input type=&quot;text&quot; id=&quot;d233&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">startDate:</span><span class="STYLE1">'%y-%M-01 00:00:00'</span>,dateFmt:'yyyy-MM-dd HH:mm:ss',<span class="STYLE2">alwaysUseStartDate:</span><span class="STYLE1">true</span>})&quot;/&gt;</p>
+        </div>
+      </li>
+      <li>自定义格式
+        <a name="m224" id="m224"></a>
+        <p>yMdHmswW分别代表年月日时分秒星期周,你可以任意组合这些元素来自定义你个性化的日期格式. </p>
+        <br />
+        日期格式表
+        <table width="100%" border="0" cellspacing="1" bgcolor="#000000">
+          <tr>
+            <th width="12%">格式</th>
+            <th width="88%">说明</th>
+          </tr>
+          <tr>
+            <td align="center">y</td>
+            <td>将年份表示为最多两位数字。如果年份多于两位数,则结果中仅显示两位低位数。</td>
+          </tr>
+          <tr>
+            <td align="center">yy </td>
+            <td>同上,如果小于两位数,前面补零。</td>
+          </tr>
+          <tr>
+            <td align="center">yyy</td>
+            <td>将年份表示为三位数字。如果少于三位数,前面补零。</td>
+          </tr>
+          <tr>
+            <td align="center">yyyy</td>
+            <td>将年份表示为四位数字。如果少于四位数,前面补零。</td>
+          </tr>
+          <tr>
+            <td align="center">M</td>
+            <td>将月份表示为从 1 至 12 的数字</td>
+          </tr>
+          <tr>
+            <td align="center">MM</td>
+            <td>同上,如果小于两位数,前面补零。</td>
+          </tr>
+          <tr>
+            <td align="center">MMM</td>
+            <td>返回月份的缩写 一月 至 十二月 (英文状态下 Jan to Dec) 。</td>
+          </tr>
+          <tr>
+            <td align="center">MMMM</td>
+            <td>返回月份的全称 一月 至 十二月 (英文状态下 January to December) 。</td>
+          </tr>
+          <tr>
+            <td align="center">d</td>
+            <td>将月中日期表示为从 1 至 31 的数字。</td>
+          </tr>
+          <tr>
+            <td align="center">dd</td>
+            <td>同上,如果小于两位数,前面补零。</td>
+          </tr>
+          <tr>
+            <td align="center">H </td>
+            <td>将小时表示为从 0 至 23 的数字。</td>
+          </tr>
+          <tr>
+            <td align="center">HH</td>
+            <td>同上,如果小于两位数,前面补零。</td>
+          </tr>
+          <tr>
+            <td align="center">m</td>
+            <td>将分钟表示为从 0 至 59 的数字。</td>
+          </tr>
+          <tr>
+            <td align="center">mm</td>
+            <td>同上,如果小于两位数,前面补零。</td>
+          </tr>
+          <tr>
+            <td align="center">s</td>
+            <td>将秒表示为从 0 至 59 的数字。</td>
+          </tr>
+          <tr>
+            <td align="center">ss</td>
+            <td>同上,如果小于两位数,前面补零。</td>
+          </tr>
+          <tr>
+            <td align="center">w</td>
+            <td>返回星期对应的数字 0 (星期天) - 6 (星期六) 。</td>
+          </tr>
+          <tr>
+            <td align="center">D</td>
+            <td>返回星期的缩写 一 至 六 (英文状态下 Sun to Sat) 。</td>
+          </tr>
+          <tr>
+            <td align="center">DD</td>
+            <td>返回星期的全称 星期一 至 星期六 (英文状态下 Sunday to Saturday) 。</td>
+          </tr>
+          <tr>
+            <td align="center">W</td>
+            <td>返回周对应的数字 (1 - 53) 。</td>
+          </tr>
+          <tr>
+            <td align="center">WW</td>
+            <td>同上,如果小于两位数,前面补零 (01 - 53) 。</td>
+          </tr>
+        </table>
+        <br />
+        示例<br />
+        <table width="100%" border="0" cellspacing="1" bgcolor="#000000">
+          <tr>
+            <th width="191">格式字符串</th>
+            <th width="460">值</th>
+          </tr>
+          <tr>
+            <td>yyyy-MM-dd HH:mm:ss</td>
+            <td>2008-03-12 19:20:00</td>
+          </tr>
+          <tr>
+            <td>yy年M月</td>
+            <td>08年3月</td>
+          </tr>
+          <tr>
+            <td>yyyyMMdd</td>
+            <td>20080312</td>
+          </tr>
+          <tr>
+            <td>今天是:yyyy年M年d HH时mm分 </td>
+            <td>今天是:2008年3月12日 19时20分</td>
+          </tr>
+          <tr>
+            <td>H:m:s</td>
+            <td>19:20:0</td>
+          </tr>
+          <tr>
+            <td>y年</td>
+            <td>8年</td>
+          </tr>
+          <tr>
+            <td>MMMM d, yyyy</td>
+            <td>三月 12, 2008</td>
+          </tr>
+        </table>
+        <div>
+          <h4>示例 2-4-1: 年月日时分秒</h4>
+          <p>
+            <input type="text" id="d241" onfocus="WdatePicker({dateFmt:'yyyy年MM月dd日 HH时mm分ss秒'})" class="Wdate" style="width:300px"/>
+            <br />
+            &lt;input type=&quot;text&quot; id=&quot;d241&quot; onfocus=&quot;WdatePicker({<span class="STYLE2">dateFmt:</span><span class="STYLE1">'yyyy年MM月dd日 HH时mm分ss秒'</span>})&quot; class=&quot;Wdate&quot; style=&quot;width:300px&quot;/&gt;<br />
+            <br />
+          <span class="STYLE1">注意:</span>点两次才能选择日期的原因,详见 <a href="3.asp.htm#autopickdate" tppabs="http://www.my97.net/dp/demo/resource/3.asp#autopickdate">autoPickDate</a> 属性</p>
+        </div>
+        <div>
+          <h4>示例 2-4-2 时分秒</h4>
+          <p>
+            <input type="text" id="d242" onfocus="WdatePicker({skin:'whyGreen',dateFmt:'H:mm:ss'})" class="Wdate"/>
+            <br />
+            &lt;input type=&quot;text&quot; id=&quot;d242&quot; onfocus=&quot;WdatePicker({skin:'whyGreen',<span class="STYLE2">dateFmt:</span><span class="STYLE1">'H:mm:ss'</span>})&quot; class=&quot;Wdate&quot;/&gt;<br />
+            <br />
+            <span class="STYLE1">注意:</span>这里提前使用了皮肤(skin)属性,所以你会看到一个不同的皮肤,皮肤属性详见<a href="2.3.asp.htm#m232" tppabs="http://www.my97.net/dp/demo/resource/2.3.asp#m232">自定义和动态切换皮肤</a> </p>
+        </div>
+        <div>
+          <h4>示例 2-4-3 年月</h4>
+          <p>
+            <input type="text" id="d243" onfocus="WdatePicker({skin:'whyGreen',dateFmt:'yyyy年MM月'})" class="Wdate"/>
+            <br />
+            &lt;input type=&quot;text&quot; id=&quot;d243&quot; onfocus=&quot;WdatePicker({skin:'whyGreen',<span class="STYLE2">dateFmt:</span><span class="STYLE1">'yyyy年MM月'</span>})&quot; class=&quot;Wdate&quot;/&gt;</p>
+        </div>
+        <div>
+          <h4>示例 2-4-4 取得系统可识别的日期值<span class="STYLE1">(重要)</span></h4>
+          <p>类似于 1999年7月5日 这样的日期是不能够被系统识别的,他必须转换为能够识别的类型如 1999-07-05 <br />
+            <br />
+            <input id="d244" type="text" class="Wdate" onfocus="WdatePicker({dateFmt:'yyyy年M月d日',vel:'d244_2'})"/>
+            真实的日期值是:
+            <input id="d244_2" type="text" />
+            <br />
+            &lt;input id=&quot;d244&quot; type=&quot;text&quot; class=&quot;Wdate&quot; onfocus=&quot;WdatePicker(<span class="STYLE2">{dateFmt:</span><span class="STYLE1">'yyyy年M月d日'</span>,<span class="STYLE2">vel:</span><span class="STYLE1">'d244_2'</span>})&quot;/&gt;<br />
+            &lt;input id=&quot;<span class="STYLE1">d244_2</span>&quot; type=&quot;text&quot; /&gt;<br />
+            <br />
+            <span class="STYLE1">注意:</span>在实际应用中,一般会把vel指定为一个<span class="STYLE2">hidden控件</span>,这里是为了把真实值展示出来,所以使用文本框<br />
+            <span class="STYLE1">关键属性:</span> <span class="STYLE2">vel</span> 指定一个控件或控件的ID,必须具有value属性(如input),用于存储真实值(也就是realDateFmt和realTimeFmt格式化后的值)</p>
+        </div>
+        <div>
+          <h4>示例 2-4-5 星期, 月 日, 年<span class="STYLE1">(4.6新增)</span></h4>
+          <p>
+            <input type="text" id="d245" style="width:200px" onfocus="WdatePicker({dateFmt:'DD, MMMM d, yyyy'})" class="Wdate"/>
+            <br />
+            &lt;input type=&quot;text&quot; id=&quot;d245&quot; onfocus=&quot;WdatePicker({<span class="STYLE2">dateFmt:</span><span class="STYLE1">'DD, MMMM d, yyyy'</span>})&quot; class=&quot;Wdate&quot;/&gt;</p>
+        </div>
+      </li>
+      <li> 双月日历功能<span class="STYLE1">(4.6新增)</span> <a name="m225" id="m225"></a>
+        <p>可以同时弹出两个月的日历</p>
+        <div>
+          <h4>示例2-5  双月日历功能</h4>
+          <p>
+            <input class="Wdate" type="text" onfocus="WdatePicker({doubleCalendar:true,dateFmt:'yyyy-MM-dd'})"/>
+            <br />
+            &lt;input class=&quot;Wdate&quot; type=&quot;text&quot; onfocus=&quot;WdatePicker({<span class="STYLE2">doubleCalendar:</span><span class="STYLE1">true</span>,dateFmt:'yyyy-MM-dd'})&quot;/&gt;<br />
+            <br />
+          <span class="STYLE1">注意:</span>双月日历一般只用于包含年月日三个元素的场景,另外设置该属性时,autoPickDate自动设置为true</p>
+        </div>
+      </li>
+      <li>自动纠错功能
+        <a name="m226" id="m226"></a>
+        <p>纠错处理可设置为3种模式:提示(默认) 自动纠错 标记,当日期框中的值不符合格式时,系统会尝试自动修复,如果修复失败会根据您设置的纠错处理模式进行处理,错误判断功能非常智能它可以保证用户输入的值是一个合法的值</p>
+        <div>
+          <h4>示例2-6-1 不合法的日期演示</h4>
+          <p>请在下面的日期框中<span class="STYLE2">填入一个不合法的日期(如:1997-02-29)</span>,再<span class="STYLE2">尝试离开焦点</span><br />
+            使用默认容错模式 <span class="STYLE2">提示模式</span> errDealMode = 0 在输入错误日期时,会先<span class="STYLE2">提示</span> <br />
+            <input type="text" class="Wdate" id="d261" onclick="WdatePicker()"/>
+            <br />
+            <br />
+            <span class="STYLE1">注意:</span>1997年不是闰年哦</p>
+        </div>
+        <div>
+          <h4>示例2-6-2 超出日期限制范围的日期也被认为是一个不合法的日期</h4>
+          <p>最大日期是2000-01-10 ,如果在下框中填入的日期 大于 2000-01-10(如2000-01-12)也会被认为是不合法的日期 <br />
+            <span class="STYLE2">自动纠错模式</span> errDealMode = 1 在输入错误日期时,<span class="STYLE2">自动恢复前一次正确的值</span><br />
+            <input name="text" type="text" class="Wdate" onfocus="WdatePicker({errDealMode:1,maxDate:'2000-01-10'})"/>
+          </p>
+        </div>
+        <div>
+          <h4>示例2-6-3 使用无效天和无效日期功能限制的日期也被认为是一个不合法的日期</h4>
+          <p>如:<br />
+            2008-02-20 无效日期限制<br />
+            2008-02-02 2008-02-09 2008-02-16 2008-02-23 无效天限制<br />
+            都是无效日期<br />
+            您可以尝试在下框中输入这些日期,并离开焦点<br />
+            <br />
+            <span class="STYLE2">标记模式</span> errDealMode = 2 在输入错误日期时,<span class="STYLE2">不做提示和更改,只是做一个标记,但此时日期框不会马上隐藏</span><br />
+            <input name="text2" type="text" class="Wdate" onfocus="WdatePicker({errDealMode:2,maxDate:'2010-01-10',disabledDays:[6],disabledDates:['2008-02-20']})" value="2008-02-12"/>
+            <br />
+            <br />
+            <span class="STYLE1">注意:</span>标记类:WdateFmtErr是在skin目录下WdatePicker.css中定义的</p>
+        </div>
+      </li>
+      <li>跨无限级框架显示
+        <a name="m227" id="m227"></a>
+        <p>无论你把日期控件放在哪里,你都不需要担心会被外层的iframe所遮挡进而影响客户体验,因为My97日期控件是可以跨无限级框架显示的</p>
+        <div>
+          <h4>示例2-7 跨无限级框架演示</h4>
+          <p>可无限跨越框架iframe,无论怎么嵌套框架都不必担心了,即使有滚动条也不怕<br />
+          <span class="STYLE1">注意:Javascript是无法跨越frameset的,但是My97日期控件可无限跨越框架iframe,任何的frameset都可以使用iframe代替</span></p>
+          <iframe src="demo_iframe.htm" tppabs="http://www.my97.net/dp/demo/resource/demo_iframe.htm" width="100%" height="220px" frameborder="0"></iframe>
+        </div>
+      </li>
+      <li>民国年日历和其他特殊日历
+        <a name="m228" id="m228"></a>
+        <p>当年份格式设置为yyy格式时,利用年份差量属性yearOffset(默认值1911民国元年),可实现民国年日历和其他特殊日历</p>
+        <div>
+          <h4>示例2-8 民国年演示</h4>
+          <p>
+            <input type="text" id="d28" onClick="WdatePicker({dateFmt:'yyy/MM/dd'})"/>
+            <br />
+            &lt;input type=&quot;text&quot; id=&quot;d28&quot; onClick=&quot;WdatePicker({<span class="STYLE2">dateFmt:</span><span class="STYLE1">'yyy/MM/dd'</span>})&quot;/&gt;<br />
+            <br />
+            <span class="STYLE1">注意:</span>年份格式设置成yyy时,真正的日期将会减去一个差量<span class="STYLE2">yearOffset(默认值为:1911)</span>,如果是民国年使用默认值即可无需另外配置,如果是其他的差量,可以通过参数的形式配置</p>
+        </div>
+      </li>
+      <li>编辑功能 <a name="m229" id="m229"></a>
+        <p>当日期框里面有值时,修改完某个属性后,只要点击这个按钮就可以实现时间和日期的编辑</p>
+        <div>
+          <h4>示例2-9 日期和时间的编辑演示</h4>
+          <p>您可以尝试对下面框中的月份改为1,然后点击<span class="STYLE2">更新</span>,你会发现日期由 2000-<span class="STYLE1">02</span>-29 01:00:00 变为 2000-<span class="STYLE1">01</span>-29 01:00:00<br />
+            <input class="Wdate" type="text" style="width:200px"  onfocus="WdatePicker({dateFmt:'yyyy-MM-dd HH:mm:ss'})" value="2000-02-29 01:00:00"/>
+          </p>
+        </div>
+      </li>
+      <li>为编程带来方便
+        <a name="m22a" id="m22a"></a>
+        <p>如果el的值是this,可省略,即所有的el:this都可以不写 <br />
+          日期框设置为disabled时,禁止更改日期(不弹出选择框) <br />
+          如果没有定义onpicked事件,自动触发文本框的onchange事件 <br />
+          如果没有定义oncleared事件,清空时,自动触发onchange事件</p>
+      </li>
+      <li>其他属性
+        <a name="m22b" id="m22b"></a>
+        <p>设置readOnly属性,可指定日期框是否只读 <br />
+          设置highLineWeekDay属性,可指定是否高亮周末 <br />
+          设置isShowOthers属性,可指定是否显示其他月的日期 <br />
+          加上class="Wdate"就会在选择框右边出现日期图标</p>
+      </li>
+    </ol>
+    <h3><a href="2.3.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.3.asp">3. 多语言和自定义皮肤</a><a name="m23" id="m23"></a></h3>
+    <h3><a href="2.4.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp">4. 日期范围限制</a><a name="m24" id="m24"></a></h3>
+    <h3><a href="2.5.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.5.asp">5. 自定义事件</a><a name="m25" id="m25"></a></h3>
+    <h3><a href="2.6.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.6.asp">6. 快速选择功能</a> <a name="m26" id="m26"></a></h3>
+    <h2><a href="3.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/3.asp">三. 配置说明</a><a name="m3" id="m3"></a></h2>
+    <h2><a href="999.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/999.asp">四. 如何使用</a><a name="m4" id="m4"></a></h2>
+    <br />
+    <br />
+  </div>
+  <div style="clear:both"></div>
+</div>
+<div class="dCenter dBody" style="padding-left:72px">
+<script type="text/javascript"><!--
+google_ad_client = "ca-pub-6343250634002651";
+/* 底部 */
+google_ad_slot = "0599809152";
+google_ad_width = 728;
+google_ad_height = 90;
+//-->
+</script>
+<script type="text/javascript">
+</script>
+</div>
+<div id="footer" class="dCenter">&copy; 2010 <a href="mailto:smallcarrot@163.com">My97</a> All Rights Reserved.&nbsp;&nbsp;&nbsp;&nbsp;<script type="text/javascript">
+var _bdhmProtocol = (("https:" == document.location.protocol) ? " https://" : " http://");
+document.write(unescape("%3Cscript src='" + _bdhmProtocol + "hm.baidu.com/h.js%3F489957c212e14340592fb2e4921b2f1d' type='text/javascript'%3E%3C/script%3E"));
+</script>&nbsp;&nbsp;&nbsp;&nbsp;浙ICP备11060275号
+</div>
+</body>
+</html>

+ 97 - 0
src/main/webapp/static/My97DatePicker/docs/demo/resource/2.3.asp.htm

@@ -0,0 +1,97 @@
+
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
+<meta name="keywords" content="日期控件 datepicker calendar 日历控件 javascript js日历控件 带时间 自定义格式 月历控件 日期时间 日期选择" />
+<title>My97日期控件 功能演示 语言和皮肤 My97 Datepicker Demo</title>
+<link href="../../css/base.css" tppabs="http://www.my97.net/dp/css/base.css" rel="stylesheet" type="text/css" />
+<link href="demo.css" tppabs="http://www.my97.net/dp/demo/resource/demo.css" rel="stylesheet" type="text/css" />
+</head>
+<body>
+<iframe src="../../head.asp" tppabs="http://www.my97.net/dp/head.asp" scrolling="no" frameborder="0" height="100px" width="100%"></iframe>
+<script language="JavaScript" type="text/javascript" src="../../../WdatePicker.js" tppabs="http://www.my97.net/dp/My97DatePicker/WdatePicker.js"></script>
+<div class="dCenter dBody">
+  <div id="content">
+
+    <h2>二. 功能及示例<a name="m2" id="m2"></a></h2>
+<h3>3. 多语言和自定义皮肤<a name="m23" id="m23"></a></h3>
+    <br />
+    <ol>
+      <li>多语言支持
+        <a name="m231" id="m231"></a>
+        <p>通过lang属性,可以为每个日期控件单独配置语言,当然也可以通过WdatePicker.js配置全局的语言<br />
+          语言列表和语言安装说明详见<a href="3.asp.htm#m32" tppabs="http://www.my97.net/dp/demo/resource/3.asp#m32">语言配置</a></p>
+        <div>
+          <h4>示例3-1 多语言示例 </h4>
+          <p>繁体中文:
+            <input name="text3" type="text" class="Wdate" id="d311" onfocus="WdatePicker({lang:'zh-tw'})"/>
+            <br />
+            &lt;input id=&quot;d311&quot; class=&quot;Wdate&quot; type=&quot;text&quot; onFocus=&quot;WdatePicker({<span class="STYLE1">lang:</span><span class="STYLE2">'zh-tw'</span>})&quot;/&gt;</p>
+          <p> 英文:
+            <input name="text3" type="text" class="Wdate" id="d312" onfocus="WdatePicker({lang:'en'})"/>
+            <br />
+            &lt;input id=&quot;d312&quot; class=&quot;Wdate&quot; type=&quot;text&quot; onFocus=&quot;WdatePicker({<span class="STYLE1">lang:</span><span class="STYLE2">'en'</span>})&quot;/&gt;</p>
+          <p>简体中文:
+            <input name="text3" type="text" class="Wdate" id="d313" onfocus="WdatePicker({lang:'zh-cn'})"/>
+            <br />
+            &lt;input id=&quot;d313&quot; class=&quot;Wdate&quot; type=&quot;text&quot; onFocus=&quot;WdatePicker({<span class="STYLE1">lang:</span><span class="STYLE2">'zh-cn'</span>})&quot;/&gt;<br />
+            <br />
+            <span class="STYLE1">注意:</span>默认情况lang='auto',即根据浏览器的语言自动选择语言.<br />
+            <br />
+            <span class="STYLE1">技巧:</span>很多项目中,可能有固定的语言选项,希望可以在日期选择的属性设置中强制某种语言,即:可以通过后台代码控制语言的选择,其实这个实现起来是很容易的,My97Datepicker是支持多个配置文件共存的,你可以配置类似cn_WdatePicker.js,en_WdatePicker.js(注意命名规则,必须以WdatePicker.js结尾)等等,在这些WdatePicker.js里面设置不同的默认语言,皮肤,格式等其他可以设置的参数,然后在页面里根据你的系统变量引入不同的xx_WdatePicker.js即可<br />
+          </p>
+        </div>
+      </li>
+      <li>自定义和动态切换皮肤
+        <a name="m232" id="m232"></a>
+        <a href="javascript:if(confirm('http://www.my97.net/dp/skin.asp  \n\n该文件未被 Teleport Pro 下载,因为 它位于起始地址以设置的边界以外的域或路径中。  \n\n你想要从服务器打开它吗?'))window.location='http://www.my97.net/dp/skin.asp'" tppabs="http://www.my97.net/dp/skin.asp" target="_top" class="STYLE1">立刻转到皮肤中心</a>
+        <p>通过skin属性,可以为每个日期控件单独配置皮肤,当然也可以通过WdatePicker.js配置全局的皮肤<br />
+          皮肤列表和皮肤安装说明详见<a href="3.asp.htm#m33" tppabs="http://www.my97.net/dp/demo/resource/3.asp#m33">皮肤配置</a></p>
+        <div>
+          <h4>示例3-2 皮肤演示</h4>
+          <p><b>默认皮肤default</b>: skin:'default'<br />
+            <input id="d321" class="Wdate" type="text" onfocus="WdatePicker()"/>
+            <br />
+            &lt;input id=&quot;d321&quot; class=&quot;Wdate&quot; type=&quot;text&quot; onfocus=&quot;WdatePicker()&quot;/&gt;<br />
+            <br />
+            <span class="STYLE1">注意:</span>在WdatePicker里配置了skin='default',所以此处可省略,同理,如果你把WdatePicker里的skin配置成'whyGreen'那么在不指定皮肤的情况下都使用'whyGreen'皮肤了</p>
+          <p><br />
+            <b>whyGreen皮肤</b>: skin:'whyGreen' <font color="#FF0000"><br />
+            </font>
+            <input id="d322" class="Wdate" type="text" onfocus="WdatePicker({skin:'whyGreen'})"/>
+            <br />
+            &lt;input id=&quot;d322&quot; class=&quot;Wdate&quot; type=&quot;text&quot;  onfocus=&quot;WdatePicker({<span class="STYLE2">skin:</span><span class="STYLE1">'whyGreen'</span>})&quot;/&gt;<br/><br/>
+            <span class="STYLE1">注意:</span>更多皮肤,请到<a href="javascript:if(confirm('http://www.my97.net/dp/skin.asp  \n\n该文件未被 Teleport Pro 下载,因为 它位于起始地址以设置的边界以外的域或路径中。  \n\n你想要从服务器打开它吗?'))window.location='http://www.my97.net/dp/skin.asp'" tppabs="http://www.my97.net/dp/skin.asp" target="_top">皮肤中心</a>下载</p>
+        </div>
+      </li>
+    </ol>
+    <h3><a href="2.4.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp">4. 日期范围限制</a><a name="m24" id="m24"></a></h3>
+    <h3><a href="2.5.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.5.asp">5. 自定义事件</a><a name="m25" id="m25"></a></h3>
+    <h3><a href="2.6.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.6.asp">6. 快速选择功能</a> <a name="m26" id="m26"></a></h3>
+    <h2><a href="3.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/3.asp">三. 配置说明</a><a name="m3" id="m3"></a></h2>
+    <h2><a href="999.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/999.asp">四. 如何使用</a><a name="m4" id="m4"></a></h2>
+    <br />
+    <br />
+  </div>
+  <div style="clear:both"></div>
+</div>
+<div class="dCenter dBody" style="padding-left:72px">
+<script type="text/javascript"><!--
+google_ad_client = "ca-pub-6343250634002651";
+/* 底部 */
+google_ad_slot = "0599809152";
+google_ad_width = 728;
+google_ad_height = 90;
+//-->
+</script>
+<script type="text/javascript">
+</script>
+</div>
+<div id="footer" class="dCenter">&copy; 2010 <a href="mailto:smallcarrot@163.com">My97</a> All Rights Reserved.&nbsp;&nbsp;&nbsp;&nbsp;<script type="text/javascript">
+var _bdhmProtocol = (("https:" == document.location.protocol) ? " https://" : " http://");
+document.write(unescape("%3Cscript src='" + _bdhmProtocol + "hm.baidu.com/h.js%3F489957c212e14340592fb2e4921b2f1d' type='text/javascript'%3E%3C/script%3E"));
+</script>&nbsp;&nbsp;&nbsp;&nbsp;浙ICP备11060275号
+</div>
+</body>
+</html>

+ 335 - 0
src/main/webapp/static/My97DatePicker/docs/demo/resource/2.4.asp.htm

@@ -0,0 +1,335 @@
+
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
+<meta name="keywords" content="日期控件 datepicker calendar 日历控件 javascript js日历控件 带时间 自定义格式 月历控件 日期时间 日期选择" />
+<title>My97日期控件 功能演示 日期范围限制 My97 Datepicker Demo</title>
+<link href="../../css/base.css" tppabs="http://www.my97.net/dp/css/base.css" rel="stylesheet" type="text/css" />
+<link href="demo.css" tppabs="http://www.my97.net/dp/demo/resource/demo.css" rel="stylesheet" type="text/css" />
+</head>
+<body>
+<iframe src="../../head.asp" tppabs="http://www.my97.net/dp/head.asp" scrolling="no" frameborder="0" height="100px" width="100%"></iframe>
+<script language="JavaScript" type="text/javascript" src="../../../WdatePicker.js" tppabs="http://www.my97.net/dp/My97DatePicker/WdatePicker.js"></script>
+<div class="dCenter dBody">
+  <div id="content">
+
+    <h2>二. 功能及示例<a name="m2" id="m2"></a></h2>
+<h3>4. 日期范围限制<a name="m24" id="m24"></a></h3>
+	<oL>
+              <LI>静态限制<a name="m241" id="m241"></a><br />
+                <span class="STYLE1">注意:日期格式必须与 realDateFmt 和 realTimeFmt 一致而不是与 dateFmt 一致</span>
+                <p>你可以给通过配置minDate(最小日期),maxDate(最大日期)为静态日期值,来限定日期的范围</p><div>
+          <h4>示例4-1-1 限制日期的范围是 2006-09-10到2008-12-20</h4>
+          <p><input id="d411" class="Wdate" type="text" onfocus="WdatePicker({skin:'whyGreen',minDate:'2006-09-10',maxDate:'2008-12-20'})"/><br />
+&lt;input id=&quot;d411&quot; class=&quot;Wdate&quot; type=&quot;text&quot; onfocus=&quot;WdatePicker({skin:'whyGreen',<span class="STYLE2">minDate:</span><span class="STYLE1">'2006-09-10',</span><span class="STYLE2">maxDate:</span><span class="STYLE1">'2008-12-20'</span>})&quot;/&gt;</p>
+        </div><div>
+          <h4>示例4-1-2 限制日期的范围是 2008-3-8 11:30:00 到 2008-3-10 20:59:30</h4>
+          <p><input type="text" class="Wdate" id="d412" onfocus="WdatePicker({skin:'whyGreen',dateFmt:'yyyy-MM-dd HH:mm:ss',minDate:'2008-03-08 11:30:00',maxDate:'2008-03-10 20:59:30'})" value="2008-03-09 11:00:00"/><br />
+&lt;input type=&quot;text&quot; class=&quot;Wdate&quot; id=&quot;d412&quot; onfocus=&quot;WdatePicker({skin:'whyGreen',<span class="STYLE2">dateFmt:</span><span class="STYLE1">'yyyy-MM-dd HH:mm:ss',</span><span class="STYLE2">minDate:</span><span class="STYLE1">'2008-03-08 11:30:00',</span><span class="STYLE2">maxDate:</span><span class="STYLE1">'2008-03-10 20:59:30'</span>})&quot; value=&quot;2008-03-09 11:00:00&quot;/&gt;</p>
+        </div><div>
+          <h4>示例4-1-3 限制日期的范围是 2008年2月 到 2008年10月</h4>
+          <p><input type="text" class="Wdate" id="d413" onfocus="WdatePicker({dateFmt:'yyyy年M月',minDate:'2008-2',maxDate:'2008-10'})"/><br />
+&lt;input type=&quot;text&quot; class=&quot;Wdate&quot; id=&quot;d413&quot; onfocus=&quot;WdatePicker({<span class="STYLE2">dateFmt:</span><span class="STYLE1">'yyyy年M月',</span><span class="STYLE2">minDate:</span><span class="STYLE1">'2008-2',</span><span class="STYLE2">maxDate:</span><span class="STYLE1">'2008-10'</span>})&quot;/&gt;</p>
+        </div><div>
+          <h4>示例4-1-4 限制日期的范围是 8:00:00 到 11:30:00</h4>
+          <p><input type="text" class="Wdate" id="d414" onfocus="WdatePicker({dateFmt:'H:mm:ss',minDate:'8:00:00',maxDate:'11:30:00'})"/><br />
+&lt;input type=&quot;text&quot; class=&quot;Wdate&quot; id=&quot;d414&quot; onfocus=&quot;WdatePicker({<span class="STYLE2">dateFmt:</span><span class="STYLE1">'H:mm:ss',</span><span class="STYLE2">minDate:</span><span class="STYLE1">'8:00:00',</span><span class="STYLE2">maxDate:</span><span class="STYLE1">'11:30:00'</span>})&quot;/&gt;</p>
+        </div></LI>
+              <LI>动态限制<a name="m242" id="m242"></a><br />
+                <span class="STYLE1">注意:日期格式必须与 realDateFmt 和 realTimeFmt 一致而不是与 dateFmt 一致</span>
+                <p>你可以通过系统给出的动态变量,如%y(当前年),%M(当前月)等来限度日期范围,你还可以通过{}进行表达式运算,如:{%d+1}:表示明天<br />
+                <br />
+              动态变量表</p>
+                <table width="335" border="0" cellpadding="3" cellspacing="1" bgcolor="#000000">
+                  <tr>
+                    <th width="62">格式</th>
+                    <th width="258">说明</th>
+                  </tr>
+                  <tr>
+                    <td align="center">%y </td>
+                    <td>当前年</td>
+                  </tr>
+                  <tr>
+                    <td align="center">%M </td>
+                    <td>当前月</td>
+                  </tr>
+                  <tr>
+                    <td align="center">%d </td>
+                    <td>当前日</td>
+                  </tr>
+                  <tr>
+                    <td align="center">%ld</td>
+                    <td>本月最后一天</td>
+                  </tr>
+                  <tr>
+                    <td align="center">%H </td>
+                    <td>当前时</td>
+                  </tr>
+                  <tr>
+                    <td align="center">%m </td>
+                    <td>当前分</td>
+                  </tr>
+                  <tr>
+                    <td align="center">%s </td>
+                    <td>当前秒</td>
+                  </tr>
+                  <tr>
+                    <td align="center">{}</td>
+                    <td>运算表达式,如:{%d+1}:表示明天</td>
+                  </tr>
+                  <tr>
+                    <td align="center">#F{}</td>
+                    <td>{}之间是函数可写自定义JS代码</td>
+                  </tr>
+                </table>
+				<div>
+          <h4>示例4-2-1 只能选择今天以前的日期(包括今天)</h4>
+          <p><input id="d421" class="Wdate" type="text" onfocus="WdatePicker({skin:'whyGreen',maxDate:'%y-%M-%d'})"/><br />
+&lt;input id=&quot;d421&quot; class=&quot;Wdate&quot; type=&quot;text&quot; onfocus=&quot;WdatePicker({skin:'whyGreen',<span class="STYLE2">maxDate:</span><span class="STYLE1">'%y-%M-%d'</span>})&quot;/&gt;</p>
+        </div>
+		<div>
+          <h4>示例4-2-2 <span class="STYLE2">使用了运算表达式</span> 只能选择今天以后的日期(不包括今天)</h4>
+          <p><input id="d422" class="Wdate" type="text" onfocus="WdatePicker({minDate:'%y-%M-{%d+1}'})"/><br />
+&lt;input id=&quot;d422&quot; class=&quot;Wdate&quot; type=&quot;text&quot; onfocus=&quot;WdatePicker({<span class="STYLE2">minDate:</span><span class="STYLE1">'%y-%M-{%d+1}'</span>})&quot;/&gt;</p>
+        </div>
+		<div>
+          <h4>示例4-2-3 只能选择本月的日期1号至本月最后一天</h4>
+          <p><input id="d423" class="Wdate" type="text" onfocus="WdatePicker({minDate:'%y-%M-01',maxDate:'%y-%M-%ld'})"/><br />
+&lt;input id=&quot;d423&quot; class=&quot;Wdate&quot; type=&quot;text&quot; onfocus=&quot;WdatePicker({<span class="STYLE2">minDate:</span><span class="STYLE1">'%y-%M-01',</span><span class="STYLE2">maxDate:</span><span class="STYLE1">'%y-%M-%ld'</span>})&quot;/&gt;</p>
+        </div>
+		<div>
+          <h4>示例4-2-4 只能选择今天7:00:00至明天21:00:00的日期</h4>
+          <p><input id="d424" class="Wdate" type="text" onfocus="WdatePicker({dateFmt:'yyyy-M-d H:mm:ss',minDate:'%y-%M-%d 7:00:00',maxDate:'%y-%M-{%d+1} 21:00:00'})"/><br />
+&lt;input id=&quot;d424&quot; class=&quot;Wdate&quot; type=&quot;text&quot; onfocus=&quot;WdatePicker({dateFmt:'yyyy-M-d H:mm:ss',<span class="STYLE2">minDate:</span><span class="STYLE1">'%y-%M-%d 7:00:00',</span><span class="STYLE2">maxDate:</span><span class="STYLE1">'%y-%M-{%d+1} 21:00:00'</span>})&quot;/&gt;</p>
+        </div>
+		<div>
+          <h4>示例4-2-5 <span class="STYLE2">使用了运算表达式</span> 只能选择 20小时前 至 30小时后 的日期</h4>
+          <p><input id="d425" class="Wdate" type="text" onClick="WdatePicker({dateFmt:'yyyy-MM-dd HH:mm',minDate:'%y-%M-%d {%H-20}:%m:%s',maxDate:'%y-%M-%d {%H+30}:%m:%s'})"/><br />
+&lt;input id=&quot;d425&quot; class=&quot;Wdate&quot; type=&quot;text&quot; onClick=&quot;WdatePicker({dateFmt:'yyyy-MM-dd HH:mm',<span class="STYLE2">minDate:</span><span class="STYLE1">'%y-%M-%d {%H-20}:%m:%s'</span>,<span class="STYLE2">maxDate:</span><span class="STYLE1">'%y-%M-%d {%H+30}:%m:%s'</span>})&quot;/&gt;</p>
+        </div>
+              </LI>
+              <LI>脚本自定义限制<a name="m243" id="m243"></a><br />
+                <span class="STYLE1">注意:日期格式必须与 realDateFmt 和 realTimeFmt 一致而不是与 dateFmt 一致</span>
+                <p>系统提供了$dp.$D和$dp.$DV这两个API来辅助你进行日期运算,此外你还可以通过在 #F{} 中填入你自定义的脚本,做任何你想做的日期限制</p><div>
+          <h4>示例4-3-1 前面的日期不能大于后面的日期且两个日期都不能大于 2020-10-01</h4>
+          <p>合同有效期从
+            <input type="text" class="Wdate" id="d4311" onfocus="WdatePicker({maxDate:'#F{$dp.$D(\'d4312\')||\'2020-10-01\'}'})"/>
+到
+<input type="text" class="Wdate" id="d4312" onfocus="WdatePicker({minDate:'#F{$dp.$D(\'d4311\')}',maxDate:'2020-10-01'})"/>
+<br />
+          &lt;input id=&quot;d4311&quot; class=&quot;Wdate&quot; type=&quot;text&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">maxDate:</span><span class="STYLE1">'#F{$dp.$D(\'d4312\')||\'2020-10-01\'}'</span>})&quot;/&gt; <br />
+&lt;input id=&quot;d4312&quot; class=&quot;Wdate&quot; type=&quot;text&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">minDate:</span><span class="STYLE1">'#F{$dp.$D(\'d4311\')}'</span>,<span class="STYLE2">maxDate:'2020-10-01'</span>})&quot;/&gt;<br />
+          <br />
+          <span class="STYLE1">注意:</span><br />
+          两个日期的日期格式必须相同<br />
+          <br />$dp.$ 相当于 document.getElementById 函数.<br />
+那么为什么里面的 ' 使用 \' 呢? 那是因为 &quot; 和 ' 都被外围的函数使用了,故使用转义符 \ ,否则会提示JS语法错误.<br />
+所以您在其他地方使用时注意把 \' 改成 &quot; 或者 ' 来使用.<br />
+<br />
+#F{$dp.$D(\'d4312\')||\'2020-10-01\'}
+  表示当 d4312 为空时, 采用 2020-10-01 的值作为最大值<br />
+          </p>
+        </div><div>
+          <h4>示例4-3-2 前面的日期+3天 不能大于 后面的日期</h4>
+          <p>日期从
+            <input type="text" class="Wdate" id="d4321" onfocus="WdatePicker({maxDate:'#F{$dp.$D(\'d4322\',{d:-3});}'})"/>
+到
+<input type="text" class="Wdate" id="d4322" onfocus="WdatePicker({minDate:'#F{$dp.$D(\'d4321\',{d:3});}'})"/>
+<br />
+&lt;input type=&quot;text&quot; class=&quot;Wdate&quot; id=&quot;d4321&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">maxDate:</span><span class="STYLE1">'#F{$dp.$D(\'d4322\',{d:-3});}'</span>})&quot;/&gt;<br />
+&lt;input type=&quot;text&quot; class=&quot;Wdate&quot; id=&quot;d4322&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">minDate:</span><span class="STYLE1">'#F{$dp.$D(\'d4321\',{d:3});}'</span>})&quot;/&gt;<br />
+          <br />
+          使用 <span class="STYLE2">$dp.$D 函数</span> 可以将日期框中的值,加上定义的日期差量:<br />
+两个参数: <span class="STYLE1">id={字符类型}需要处理的文本框的id值</span> , <span class="STYLE1">obj={对象类型}日期差量</span><br />
+<span class="STYLE2">日期差量用法:</span><br />
+属性y,M,d,H,m,s分别代表年月日时分秒<br />
+如 <br />
+为空时,表示直接取值,不做差量(示例4-3-1中的参数就是空的)<br />
+{M:5,d:7} 表示 五个月零7天<br />
+{y:1,d:-3} 表示 1年少3天<br />
+{d:1,H:1} 表示一天多1小时</p>
+        </div><div>
+          <h4>示例4-3-3 前面的日期+3月零2天 不能大于 后面的日期 且 前面日期都不能大于 2020-4-3减去3月零2天 后面日期 不能大于 2020-4-3</h4>
+          <p>住店日期从
+            <input type="text" class="Wdate" id="d4331" onfocus="WdatePicker({maxDate:'#F{$dp.$D(\'d4332\',{M:-3,d:-2})||$dp.$DV(\'2020-4-3\',{M:-3,d:-2})}'})"/>
+到
+<input type="text" class="Wdate" id="d4332" onfocus="WdatePicker({minDate:'#F{$dp.$D(\'d4331\',{M:3,d:2});}',maxDate:'2020-4-3'})"/>
+<br />
+&lt;input type=&quot;text&quot; class=&quot;Wdate&quot; id=&quot;d4331&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">maxDate:</span>'<span class="STYLE1">#F{$dp.$D(\'d4332\',{M:-3,d:-2})||$dp.$DV(\'2020-4-3\',{M:-3,d:-2})}</span>'})&quot;/&gt;<br />
+&lt;input type=&quot;text&quot; class=&quot;Wdate&quot; id=&quot;d4332&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">minDate:</span>'<span class="STYLE1">#F{$dp.$D(\'d4331\',{M:3,d:2});}</span>',<span class="STYLE1">maxDate:</span>'<span class="STYLE1">2020-4-3</span>'})&quot;/&gt;<br />
+<br />
+<span class="STYLE1">注意:<br />
+</span>#F{$dp.$D(\'d4332\',{M:-3,d:-2}) || $dp.$DV(\'2020-4-3\',{M:-3,d:-2})}<br />
+表示当 d4332 为空时, 采用 $dp.$DV(\'2020-4-3\',{M:-3,d:-2})} 的值作为最大值</p>
+          <p>使用 <span class="STYLE2">$dp.$DV 函数</span> 可以将显式传入的值,加上定义的日期差量:<br />
+            两个参数: <span class="STYLE1">value={字符类型}需要处理的值</span> , <span class="STYLE1">obj={对象类型}日期差量</span><br />
+            用法同上面的 <span class="STYLE2">$dp.$D</span> 类似,如 $dp.$DV(\'2020-4-3\',{M:-3,d:-2}) 表示 2020-4-3减去3月零2天</p>
+        </div><div>
+          <h4>示例4-3-4 发挥你的JS才能,定义任何你想要的日期限制</h4>
+          <p>自动转到随机生成的一天,当然,此示例没有实际的用途,只是为演示目的<br />
+            <script>
+	//返回一个随机的日期
+	function randomDate(){
+		var Y = 2000 + Math.round(Math.random() * 10);
+		var M = 1 + Math.round(Math.random() * 11);
+		var D = 1 + Math.round(Math.random() * 27);
+		return Y+'-'+M+'-'+D;
+	}
+            </script>
+            <input type="text" class="Wdate" id="d434" onfocus="var date=randomDate();WdatePicker({minDate:date,maxDate:date})"/>
+            <br />
+&lt;script&gt;<br />
+//返回一个随机的日期<br />
+function randomDate(){<br />
+var Y = 2000 + Math.round(Math.random() * 10);<br />
+var M = 1 + Math.round(Math.random() * 11);<br />
+var D = 1 + Math.round(Math.random() * 27);<br />
+return Y+'-'+M+'-'+D;<br />
+}<br />
+&lt;/script&gt;<br />
+&lt;input type=&quot;text&quot; class=&quot;Wdate&quot; id=&quot;d434&quot; onFocus=&quot;<span class="STYLE1">var date=randomDate();WdatePicker({minDate:date,maxDate:date})</span>&quot;/&gt;</p>
+        </div>
+              </LI>
+              <LI>无效天<a name="m244" id="m244"></a>
+                <p>可以使用此功能禁用周日至周六所对应的日期,相关属性:disabledDays (0至6 分别代表 周日至周六)</p><div>
+          <h4>示例4-4-1 禁用 周六 所对应的日期</h4>
+          <p><input id="d441" type="text" class="Wdate" onFocus="WdatePicker({disabledDays:[6]})"/><br />
+&lt;input id=&quot;d441&quot; type=&quot;text&quot; class=&quot;Wdate&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">disabledDays:</span><span class="STYLE1">[6]</span>})&quot;/&gt;</p>
+        </div><div>
+          <h4>示例4-4-2 禁用 周六 周日 所对应的日期</h4>
+          <p><input id="d442" type="text" class="Wdate" onFocus="WdatePicker({disabledDays:[0,6]})"/><br />            
+          &lt;input id=&quot;d442&quot; type=&quot;text&quot; class=&quot;Wdate&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">disabledDays:</span><span class="STYLE1">[0,6]</span>})&quot;/&gt;</p>
+        </div>
+              </LI>
+              <LI>无效日期<a name="m245" id="m245"></a><br />
+                <span class="STYLE1">注意:日期格式必须与 realDateFmt 和 realTimeFmt 一致而不是与 dateFmt 一致</span>
+                <p>可以使用此功能禁用,所指定的一个或多个日期,只要你熟悉正则表达式,你可以尽情发挥<br /><br />
+                <span class="STYLE2">用法(正则匹配):</span> <br />
+如果你熟悉正则表达式,会很容易理解下面的匹配用法<br />
+如果不熟悉,可以参考下面的常用示例 <br />
+['2008-02-01','2008-02-29'] 表示禁用 2008-02-01 和 2008-02-29<br />
+['2008-..-01','2008-02-29'] 表示禁用 2008-所有月份-01 和 2008-02-29<br />
+['200[0-8]]-02-01','2008-02-29'] 表示禁用 [2000至2008]-02-01 和 2008-02-29<br />
+['^2006'] 表示禁用 2006年的所有日期 </p>
+                <p>此外,您还可以使用  %y %M %d %H %m %s 等变量, 用法同动态日期限制 <span class="STYLE1">注意:%ld不能使用</span><br />
+                  ['....-..-01','%y-%M-%d'] 表示禁用 所有年份和所有月份的第一天和今天 <br />
+                  ['%y-%M-{%d-1}','%y-%M-{%d+1}'] 表示禁用 昨天和明天</p>
+                <p>当然,除了可以限制日期以外,您还可以限制时间<br />
+                  ['....-..-.. 10\:00\:00'] 表示禁用 每天10点 (注意 <span class="STYLE2">:</span> 需要 使用 <span class="STYLE2">\:</span> ) </p>
+                <p>不再多举例了,尽情发挥你的正则才能吧!</p>
+                <div>
+          <h4>示例4-5-1 禁用 每个月份的 5日 15日 25日</h4>
+          <p><input id="d451" type="text" class="Wdate" onFocus="WdatePicker({disabledDates:['5$']})"/><br />
+&lt;input id=&quot;d451&quot; type=&quot;text&quot; class=&quot;Wdate&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">disabledDates:</span><span class="STYLE1">['5$']</span>})&quot;/&gt;<br />
+<br />
+<span class="STYLE1">注意
+:</span><span class="STYLE2">'5$'</span> 表示以 5 结尾 注意 <span class="STYLE2">$</span> 的用法 </p>
+        </div><div>
+          <h4>示例4-5-2 禁用 所有早于2000-01-01的日期</h4>
+          <p><input id="d452" type="text" class="Wdate" onFocus="WdatePicker({disabledDates:['^19']})"/><br />
+&lt;input id=&quot;d452&quot; type=&quot;text&quot; class=&quot;Wdate&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">disabledDates:</span><span class="STYLE1">['^19']</span>})&quot;/&gt;<br />
+          <br />
+          <span class="STYLE1">注意:</span><span class="STYLE2">'^19'</span> 表示以 19 开头 注意 <span class="STYLE2">^</span> 的用法 <br />
+          当然,可以使用minDate实现类似的功能 这里主要是 在演示 ^ 的用法</p>
+        </div><div>
+          <h4>示例4-5-3 配合min/maxDate使用,可以把可选择的日期分隔成多段</h4>
+          <p>本示例本月可用日期分隔成五段 分别是: 1-3 8-10 16-24 26,27 29-月末<br />
+            <input id="d453" type="text" class="Wdate" onFocus="WdatePicker({minDate:'%y-%M-01',maxDate:'%y-%M-%ld',disabledDates:['0[4-7]$','1[1-5]$','2[58]$']})"/><br />
+&lt;input id=&quot;d453&quot; type=&quot;text&quot; class=&quot;Wdate&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">minDate:</span><span class="STYLE1">'%y-%M-01'</span>,<span class="STYLE2">maxDate:</span><span class="STYLE1">'%y-%M-%ld'</span>,<span class="STYLE2">disabledDates:</span><span class="STYLE1">['0[4-7]$','1[1-5]$','2[58]$']</span>})&quot;/&gt;</p>
+        </div><div>
+          <h4>示例4-5-4 <span class="STYLE2">min/maxDate disabledDays disabledDates 配合使用</span> 即使在要求非常苛刻的情况下也能满足需求</h4>
+          <p><input id="d454" type="text" class="Wdate" onFocus="WdatePicker({minDate:'%y-%M-01',maxDate:'%y-%M-%ld',disabledDates:['0[4-7]$','1[1-5]$','2[58]$'],disabledDays:[1,3,6]})"/><br />
+&lt;input id=&quot;d454&quot; type=&quot;text&quot; class=&quot;Wdate&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">minDate:</span><span class="STYLE1">'%y-%M-01'</span>,<span class="STYLE2">maxDate:</span><span class="STYLE1">'%y-%M-%ld'</span>,<span class="STYLE2">disabledDates:</span><span class="STYLE1">['0[4-7]$','1[1-5]$','2[58]$']</span>,<span class="STYLE2">disabledDays:</span><span class="STYLE1">[1,3,6]</span>})&quot;/&gt;</p>
+        </div><div>
+          <h4>示例4-5-5 禁用前一个小时和后一个小时内所有时间 使用 %y %M %d %H %m %s 等变量</h4>
+          <p>鼠标点击 小时输入框时,你会发现当然时间对应的前一个小时和后一个小时是灰色的<br />
+            <input id="d2a25" type="text" class="Wdate" onFocus="WdatePicker({dateFmt:'yyyy-MM-dd HH:mm:ss',disabledDates:['%y-%M-%d {%H-1}\:..\:..','%y-%M-%d {%H+1}\:..\:..']})"/>
+            <br />
+            &lt;input id=&quot;d2a25&quot; type=&quot;text&quot; class=&quot;Wdate&quot; onFocus=&quot;WdatePicker({dateFmt:'yyyy-MM-dd HH:mm:ss',<span class="STYLE2">disabledDates:</span><span class="STYLE1">['%y-%M-%d {%H-1}\:..\:..','%y-%M-%d {%H+1}\:..\:..']</span>})&quot;/&gt;          <br />
+            <br />
+            <span class="STYLE1">注意:</span>%y %M %d等详见<a href="#m242">动态变量表</a></p>
+        </div><div>
+          <h4>示例4-5-6  #F{}也是可以使用的</h4>
+          <p>本示例利用自定义函数 随机禁用0-23中的任何一个小时<br />
+          打开小时选择框,你会发现有一个小时被禁用的,而且每次禁用的小时都不同<br />
+            <input type="text" class="Wdate" id="d456" onFocus="WdatePicker({dateFmt:'HH:mm:ss',disabledDates:['#F{randomH()}']})"/>
+			<script>
+function randomH(){
+//产生一个随机的数字 0-23 
+var H = Math.round(Math.random() * 23);
+if(H<10) H='0'+H;
+//返回 '^' + 数字
+return '^'+H;
+}
+</script>
+              <br />
+&lt;script&gt;<br />
+function randomH(){<br />
+//产生一个随机的数字 0-23 <br />
+var H = Math.round(Math.random() * 23);<br />
+if(H&lt;10) H='0'+H;<br />
+//返回 '^' + 数字<br />
+return '^'+H;<br />
+}<br />
+&lt;/script&gt;<br />
+&lt;input type=&quot;text&quot; class=&quot;Wdate&quot; id=&quot;d456&quot; onFocus=&quot;WdatePicker({dateFmt:'HH:mm:ss',<span class="STYLE2">disabledDates:</span><span class="STYLE1">['#F{randomH()}']</span>})&quot;/&gt;</p>
+        </div></LI>
+        <li>有效日期<a name="m246" id="m246"></a>
+		  <p>使用无效日期可以很方便的禁用不可用的日期,但是在只需要启用少部分日期的情况下,有效日期的功能就非常适合了.<br />
+		    <span class="STYLE1">关键属性:</span> <span class="STYLE2">opposite</span> 默认为false, 为true时,无效日期变成有效日期,<b>该属性对无效天,特殊天不起作用</b> </p>
+		  <div>
+          <h4>示例4-6 只启用 每个月份的 5日 15日 25日</h4>
+          <p><input id="d46" type="text" class="Wdate" onFocus="WdatePicker({opposite:true,disabledDates:['5$']})"/><br />
+&lt;input id=&quot;d46&quot; type=&quot;text&quot; class=&quot;Wdate&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">opposite:</span><span class="STYLE1">true</span>,<span class="STYLE2">disabledDates:</span><span class="STYLE1">['5$']</span>})&quot;/&gt;<br />
+<br />
+<span class="STYLE1">注意
+:</span><span class="STYLE2">'5$'</span> 表示以 5 结尾 注意 <span class="STYLE2">$</span> 的用法 </p>
+        </div>
+		</li>
+		<li>特殊天和特殊日期<a name="m247" id="m247"></a>
+		  <p><span class="STYLE1">特殊天和特殊日期的用法跟完全无效天和无效日期完全相同,但是opposite属性对其无效</span><br />
+		    <br />
+	      <span class="STYLE1">关键属性:</span><br />
+			 <span class="STYLE2">specialDays </span>(0至6 分别代表 周日至周六) 用法同无效天 <br />
+		  <span class="STYLE2">specialDates</span>	用法同无效日期,但是对时分秒无效</p>
+		  <div>
+          <h4>示例4-7-1 高亮每周 周一 周五</h4>
+          <p><input id="d471" type="text" class="Wdate" onFocus="WdatePicker({specialDays:[1,5]})"/><br />
+&lt;input id=&quot;d471&quot; type=&quot;text&quot; class=&quot;Wdate&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">specialDays:</span><span class="STYLE1">[1,5]</span>})&quot;/&gt; </p>
+        </div>
+        <div>
+          <h4>示例4-7-2 高亮每月 1号 15号</h4>
+          <p><input id="d472" type="text" class="Wdate" onFocus="WdatePicker({specialDates:['....-..-01','....-..-15']})"/><br />
+&lt;input id=&quot;d472&quot; type=&quot;text&quot; class=&quot;Wdate&quot; onFocus=&quot;WdatePicker({<span class="STYLE2">specialDates:</span><span class="STYLE1">['....-..-01','....-..-15']</span>})&quot;/&gt; </p>
+        </div>
+		</li>
+    </oL>
+    <h3><a href="2.5.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.5.asp">5. 自定义事件</a><a name="m25" id="m25"></a></h3>
+<h3><a href="2.6.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.6.asp">6. 快速选择功能</a> <a name="m26" id="m26"></a></h3>
+    <h2><a href="3.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/3.asp">三. 配置说明</a><a name="m3" id="m3"></a></h2>
+    <h2><a href="999.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/999.asp">四. 如何使用</a><a name="m4" id="m4"></a></h2>
+    <br />
+    <br />
+  </div>
+  <div style="clear:both"></div>
+</div>
+<div class="dCenter dBody" style="padding-left:72px">
+<script type="text/javascript"><!--
+google_ad_client = "ca-pub-6343250634002651";
+/* 底部 */
+google_ad_slot = "0599809152";
+google_ad_width = 728;
+google_ad_height = 90;
+//-->
+</script>
+<script type="text/javascript">
+</script>
+</div>
+<div id="footer" class="dCenter">&copy; 2010 <a href="mailto:smallcarrot@163.com">My97</a> All Rights Reserved.&nbsp;&nbsp;&nbsp;&nbsp;<script type="text/javascript">
+var _bdhmProtocol = (("https:" == document.location.protocol) ? " https://" : " http://");
+document.write(unescape("%3Cscript src='" + _bdhmProtocol + "hm.baidu.com/h.js%3F489957c212e14340592fb2e4921b2f1d' type='text/javascript'%3E%3C/script%3E"));
+</script>&nbsp;&nbsp;&nbsp;&nbsp;浙ICP备11060275号
+</div>
+</body>
+</html>

Diferenças do arquivo suprimidas por serem muito extensas
+ 260 - 0
src/main/webapp/static/My97DatePicker/docs/demo/resource/2.5.asp-.htm


Diferenças do arquivo suprimidas por serem muito extensas
+ 260 - 0
src/main/webapp/static/My97DatePicker/docs/demo/resource/2.5.asp.htm


+ 71 - 0
src/main/webapp/static/My97DatePicker/docs/demo/resource/2.6.asp.htm

@@ -0,0 +1,71 @@
+
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
+<meta name="keywords" content="日期控件 datepicker calendar 日历控件 javascript js日历控件 带时间 自定义格式 月历控件 日期时间 日期选择" />
+<title>My97日期控件 功能演示 其他功能 My97 Datepicker Demo</title>
+<link href="../../css/base.css" tppabs="http://www.my97.net/dp/css/base.css" rel="stylesheet" type="text/css" />
+<link href="demo.css" tppabs="http://www.my97.net/dp/demo/resource/demo.css" rel="stylesheet" type="text/css" />
+</head>
+<body>
+<iframe src="../../head.asp" tppabs="http://www.my97.net/dp/head.asp" scrolling="no" frameborder="0" height="100px" width="100%"></iframe>
+<script language="JavaScript" type="text/javascript" src="../../../WdatePicker.js" tppabs="http://www.my97.net/dp/My97DatePicker/WdatePicker.js"></script>
+<div class="dCenter dBody">
+  <div id="content">
+
+    <h2>二. 功能及示例<a name="m2" id="m2"></a></h2>
+<h3>6. 快速选择功能 <a name="m26" id="m26"></a></h3>
+    <p style="margin-left:20px">此功能允许指定5个最常用的日期,可以方便用户选择,如果不指定,系统将自动生成<br />
+      相关属性:<br />
+      <span class="STYLE2">qsEnabled</span> 是否启用快速选择功能,      <span class="STYLE1">注意:如果日期格式里不包含 d(天) 这个元素时,快速选择将一直显示,不收此属性控制</span><br />
+      <span class="STYLE2">quickSel</span> 快速选择数据,可以传入5个快速选择日期,日期格式同min/maxDate<br />
+      <br />
+      <span class="STYLE1">注意:<br />
+      </span>日期格式必须与 realDateFmt  realTimeFmt  相匹配<br />
+      除了使用静态的日期值以外,还可以使用动态参数(如:%y,%M分别表示当前年和月)<br />
+    </p>
+    <div style="margin-left:20px">
+      <h4>示例6-1 传入2个静态日期</h4>
+      <p>
+        <input class="Wdate" type="text" onfocus="WdatePicker({dateFmt:'yyyy年MM月dd日',qsEnabled:true,quickSel:['2000-1-10','2000-2-20']})"/>
+        <br />
+        &lt;input class=&quot;Wdate&quot; type=&quot;text&quot; onfocus=&quot;WdatePicker({dateFmt:'yyyy年MM月dd日',<span class="STYLE2">qsEnabled:</span><span class="STYLE1">true</span>,<span class="STYLE2">quickSel:</span><span class="STYLE1">['2000-1-10','2000-2-20']</span>})&quot;/&gt;<br />
+        <br />
+        <span class="STYLE1">注意:</span>当传入的数据不足5个时,系统将自动补全</p>
+    </div>
+    <div style="margin-left:20px">
+      <h4>示例6-2 传入2个动态日期,1个静态日期</h4>
+      <p>
+        <input type="text" class="Wdate" onFocus="WdatePicker({dateFmt:'yyyy年MM月dd日',qsEnabled:true,quickSel:['2000-10-01','%y-%M-01','%y-%M-%ld']})"/>
+        <br />
+        &lt;input type=&quot;text&quot; class=&quot;Wdate&quot; onFocus=&quot;WdatePicker({dateFmt:'yyyy年MM月dd日',<span class="STYLE2">qsEnabled:</span><span class="STYLE1">true</span>,<span class="STYLE2">quickSel:</span><span class="STYLE1">['2000-10-01','%y-%M-01','%y-%M-%ld']</span>})&quot;/&gt;<br />
+        <br />
+        <span class="STYLE1">注意:</span>当传入的数据不足5个时,系统将自动补全</p>
+    </div>
+    <h2><a href="3.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/3.asp">三. 配置说明</a><a name="m3" id="m3"></a></h2>
+    <h2><a href="999.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/999.asp">四. 如何使用</a><a name="m4" id="m4"></a></h2>
+    <br />
+    <br />
+  </div>
+  <div style="clear:both"></div>
+</div>
+<div class="dCenter dBody" style="padding-left:72px">
+<script type="text/javascript"><!--
+google_ad_client = "ca-pub-6343250634002651";
+/* 底部 */
+google_ad_slot = "0599809152";
+google_ad_width = 728;
+google_ad_height = 90;
+//-->
+</script>
+<script type="text/javascript">
+</script>
+</div>
+<div id="footer" class="dCenter">&copy; 2010 <a href="mailto:smallcarrot@163.com">My97</a> All Rights Reserved.&nbsp;&nbsp;&nbsp;&nbsp;<script type="text/javascript">
+var _bdhmProtocol = (("https:" == document.location.protocol) ? " https://" : " http://");
+document.write(unescape("%3Cscript src='" + _bdhmProtocol + "hm.baidu.com/h.js%3F489957c212e14340592fb2e4921b2f1d' type='text/javascript'%3E%3C/script%3E"));
+</script>&nbsp;&nbsp;&nbsp;&nbsp;浙ICP备11060275号
+</div>
+</body>
+</html>

+ 431 - 0
src/main/webapp/static/My97DatePicker/docs/demo/resource/3.asp.htm

@@ -0,0 +1,431 @@
+
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
+<meta name="author" content="My97" /> 
+<meta name="keywords" content="日期控件 datepicker calendar 日历控件 javascript js日历控件 带时间 自定义格式 月历控件 日期时间 日期选择" /><title>My97日期控件 功能演示 配置说明 My97 Datepicker Demo</title>
+<link href="../../css/base.css" tppabs="http://www.my97.net/dp/css/base.css" rel="stylesheet" type="text/css" />
+<link href="demo.css" tppabs="http://www.my97.net/dp/demo/resource/demo.css" rel="stylesheet" type="text/css" />
+</head>
+<body>
+<iframe src="../../head.asp" tppabs="http://www.my97.net/dp/head.asp" scrolling="no" frameborder="0" height="100px" width="100%"></iframe>
+<script language="JavaScript" type="text/javascript" src="../../../WdatePicker.js" tppabs="http://www.my97.net/dp/My97DatePicker/WdatePicker.js"></script>
+<div class="dCenter dBody">
+  <div id="content">
+
+    <h2>三. 配置说明<a name="m3" id="m3"></a></h2>
+    <h3>1. 属性配置<a name="m31" id="m31"></a></h3>
+    <ol>
+      <li>属性表<a name="m311" id="m311"></a>
+        <table width="100%" border="0" cellpadding="3" cellspacing="1" bgcolor="#000000">
+          <tr>
+            <th>属性</th>
+            <th>类型</th>
+            <th>默认值</th>
+            <th>说明</th>
+          </tr>
+          <tr>
+            <td colspan="4">静态属性:只能在WdatePicker.js中配置,一般情况下,不建议您修改静态属性的值</td>
+          </tr>
+          <tr>
+            <td align="center">$wdate</td>
+            <td align="center">bool</td>
+            <td align="center">true</td>
+            <td>是否自动引入Wdate类 设置为true时,可直接在引入WdatePicker.js的页面里使用 class=&quot;Wdate&quot; <br />
+              Wdate可在skin目录下的WdatePicker.css文件中定义<br />
+              <span class="STYLE2">建议使用默认值</span></td>
+          </tr>
+          <tr>
+            <td align="center">$dpPath</td>
+            <td align="center">string</td>
+            <td align="center">''</td>
+            <td>是否显示指定程序包的绝对位置,一般情况下为空即可(程序自动创建),该属性是为防止极其少数的情况下程序创建出错而设置的<br />
+              设置方法:<br />
+              如果,程序包所在http中的地址为 http://localhost/proName/My97DatePicker/<br />
+              则 $dpPath = '/proName/My97DatePicker/';<br />
+              <span class="STYLE2">建议使用默认值</span></td>
+          </tr>
+          <tr>
+            <td align="center">$crossFrame</td>
+            <td align="center">bool</td>
+            <td align="center">true</td>
+            <td>是否跨框架,一般设置为true即可,遇到跨域错误时可以将此功能关闭</td>
+          </tr>
+          <tr>
+            <td colspan="4">可配置属性:可以在WdatePicker方法是配置</td>
+          </tr>
+          <tr>
+            <td align="center">el</td>
+            <td align="center">Element 或 String</td>
+            <td align="center">null</td>
+            <td>指定一个控件或控件的ID,必须具有value或innerHTML属性(如input,textarea,span,div,p等标签都可以),用户存储日期显示值(也就是dateFmt格式化后的值)</td>
+          </tr>
+          <tr>
+            <td align="center">vel</td>
+            <td align="center">Element 或 String</td>
+            <td align="center">null</td>
+            <td>指定一个控件或控件的ID,必须具有value属性(如input),用于存储真实值(也就是realDateFmt和realTimeFmt格式化后的值)</td>
+          </tr>
+          <tr>
+            <td align="center">doubleCalendar</td>
+            <td align="center">bool</td>
+            <td align="center">false</td>
+            <td>是否是双月模式,如果该属性为true,则弹出同时显示2个月的日期框</td>
+          </tr>
+          <tr>
+            <td align="center">enableKeyboard</td>
+            <td align="center">bool</td>
+            <td align="center">true</td>
+            <td>键盘控制开关</td>
+          </tr>
+          <tr>
+            <td align="center">enableInputMask</td>
+            <td align="center">bool</td>
+            <td align="center">true</td>
+            <td>文本框输入启用掩码开关</td>
+          </tr>
+          <tr>
+            <td align="center">autoUpdateOnChanged</td>
+            <td align="center">bool</td>
+            <td align="center">null</td>
+            <td>在修改年月日时分秒等元素时,自动更新到el,默认是关闭的(即:需要点击确定或点击日期才更新)<br />
+              为false时 不自动更新<br />
+为true时 自动更新<br />
+为null时(默认值) 如果有日元素且不隐藏确定按钮时 为false,其他情况为true</td>
+          </tr>
+          <tr>
+            <td align="center">weekMethod</td>
+            <td align="center">string</td>
+            <td align="center">ISO8601</td>
+            <td>周算法不同的地方有一些差异<br />
+常见算法有两种<br />
+1. ISO8601:规定第一个星期四为第一周,默认值<br />
+2. MSExcel:1月1日所在的周<br />
+<br />
+相关链接:<a href="javascript:if(confirm('http://en.wikipedia.org/wiki/ISO_week_date  \n\n该文件未被 Teleport Pro 下载,因为 它位于起始地址以设置的边界以外的域或路径中。  \n\n你想要从服务器打开它吗?'))window.location='http://en.wikipedia.org/wiki/ISO_week_date'" tppabs="http://en.wikipedia.org/wiki/ISO_week_date" target="_blank">http://en.wikipedia.org/wiki/ISO_week_date</a></td>
+          </tr>
+          <tr>
+            <td align="center">position</td>
+            <td align="center">object</td>
+            <td align="center">{}</td>
+            <td> 日期选择框显示位置<br />
+              <span class="STYLE2">注意:坐标单位是px,是相对当前框架坐标(不受滚动条影响),默认情况下系统根据页面大小自动选择</span><br />
+              如:<br />
+              {left:100,top:50}表示固定坐标[100,50]<br />
+              {top:50}表示横坐标自动生成,纵坐标指定为 50<br />
+              {left:100}表示纵坐标自动生成,横坐标指定为 100<br />
+              请参考示例</td>
+          </tr>
+          <tr>
+            <td align="center">lang</td>
+            <td align="center">string</td>
+            <td align="center">'auto'</td>
+            <td>当值为'auto'时 自动根据客户端浏览器的语言自动选择语言<br />
+              当值为 其他 时 从langList中选择对应的语言 <br />
+              你可以参考<a href="#m32">语言配置</a></td>
+          </tr>
+          <tr>
+            <td align="center">skin</td>
+            <td align="center">string</td>
+            <td align="center">'default'</td>
+            <td>皮肤名称 默认自带 default和whyGreen两个皮肤<br />
+              另外如果你的css够强的话,可以自己做皮肤<br />
+              你可以参考<a href="#m33">皮肤配置</a></td>
+          </tr>
+          <tr>
+            <td align="center">dateFmt</td>
+            <td align="center">string</td>
+            <td align="center">'yyyy-MM-dd'</td>
+            <td>日期显示格式<br />
+            你可以参考<a href="2.2.asp.htm#m224" tppabs="http://www.my97.net/dp/demo/resource/2.2.asp#m224">自定义格式</a></td>
+          </tr>
+          <tr>
+            <td align="center">realDateFmt</td>
+            <td align="center">string</td>
+            <td align="center">'yyyy-MM-dd'</td>
+            <td rowspan="3">计算机可识别的,真正的日期格式<br />
+              <span class="STYLE2">无效日期设置(disabledDates),最大日期(maxDate),最小日期(minDate)以及快速日期都必须与它们相匹配<br />
+              建议使用默认值</span></td>
+          </tr>
+          <tr>
+            <td align="center">realTimeFmt</td>
+            <td align="center">string</td>
+            <td align="center">'HH:mm:ss'</td>
+          </tr>
+          <tr>
+            <td align="center">realFullFmt</td>
+            <td align="center">string</td>
+            <td align="center">'%Date %Time'</td>
+          </tr>
+          <tr>
+            <td align="center">minDate</td>
+            <td align="center">string</td>
+            <td align="center">'1900-01-01 00:00:00'</td>
+            <td>最小日期(注意要与上面的real日期相匹配)</td>
+          </tr>
+          <tr>
+            <td align="center">maxDate</td>
+            <td align="center">string</td>
+            <td align="center">'2099-12-31 23:59:59'</td>
+            <td>最大日期(注意要与上面的real日期相匹配)</td>
+          </tr>
+          <tr>
+            <td align="center">startDate</td>
+            <td align="center">string</td>
+            <td align="center">''</td>
+            <td> 起始日期,既点击日期框时显示的起始日期<br />
+              为空时,使用今天作为起始日期(默认值)<br />
+              否则使用传入的日期作为起始日期(注意要与上面的real日期相匹配)<br />
+              你可以参考<a href="2.2.asp.htm#m223" tppabs="http://www.my97.net/dp/demo/resource/2.2.asp#m223">起始日期示例</a></td>
+          </tr>
+          <tr>
+            <td align="center">firstDayOfWeek</td>
+            <td align="center">int</td>
+            <td align="center">0</td>
+            <td>周的第一天 0表示星期日 1表示星期一</td>
+          </tr>
+          <tr>
+            <td align="center">isShowWeek</td>
+            <td align="center">bool</td>
+            <td align="center">false</td>
+            <td>是否显示周<br />
+              你可以参考<a href="2.1.asp.htm#m213" tppabs="http://www.my97.net/dp/demo/resource/2.1.asp#m213">周显示示例</a></td>
+          </tr>
+          <tr>
+            <td align="center">highLineWeekDay</td>
+            <td align="center">bool</td>
+            <td align="center">true</td>
+            <td>是否高亮显示 周六 周日</td>
+          </tr>
+          <tr>
+            <td align="center">isShowClear</td>
+            <td align="center">bool</td>
+            <td align="center">true</td>
+            <td>是否显示清空按钮</td>
+          </tr>
+          <tr>
+            <td align="center">isShowToday</td>
+            <td align="center">bool</td>
+            <td align="center">true</td>
+            <td>是否显示今天按钮</td>
+          </tr>
+          <tr>
+            <td align="center">isShowOthers</td>
+            <td align="center">bool</td>
+            <td align="center">true</td>
+            <td>为true时,第一行空白处显示上月的日期,末行空白处显示下月的日期,否则不显示</td>
+          </tr>
+          <tr>
+            <td align="center">readOnly</td>
+            <td align="center">bool</td>
+            <td align="center">false</td>
+            <td>是否只读</td>
+          </tr>
+          <tr>
+            <td align="center">errDealMode</td>
+            <td align="center">int</td>
+            <td align="center">0</td>
+            <td>纠错模式设置 可设置3中模式 0 - 提示 1 - 自动纠错 2 - 标记</td>
+          </tr>
+          <tr>
+            <td align="center">autoPickDate</td>
+            <td align="center">bool</td>
+            <td align="center">null</td>
+            <td><a name="autopickdate" id="autopickdate"></a>为false时 点日期的时候不自动输入,而是要通过确定才能输入<br />
+              为true时 即点击日期即可返回日期值<br />
+              为null时(推荐使用) 如果有时间置为false 否则置为true</td>
+          </tr>
+          <tr>
+            <td align="center">qsEnabled</td>
+            <td align="center">bool</td>
+            <td align="center">true</td>
+            <td>是否启用快速选择功能</td>
+          </tr>
+          <tr>
+            <td align="center">autoShowQS</td>
+            <td align="center">bool</td>
+            <td align="center">false</td>
+            <td>是否默认显示快速选择</td>
+          </tr>
+          <tr>
+            <td align="center">quickSel</td>
+            <td align="center">Array</td>
+            <td align="center">null</td>
+            <td>快速选择数据,可以传入5个快速选择日期<br />
+              注意:日期格式必须与 realDateFmt  realTimeFmt realFullFmt 相匹配<br />
+              你可以参考<a href="2.6.asp.htm#m26" tppabs="http://www.my97.net/dp/demo/resource/2.6.asp#m26">快速选择示例</a></td>
+          </tr>
+          <tr>
+            <td align="center">disabledDays</td>
+            <td align="center">Array</td>
+            <td align="center">null</td>
+            <td>可以使用此功能禁用周日至周六所对应的日期<br />
+              0至6 分别代表 周日至周六<br />
+              你可以参考<a href="2.4.asp.htm#m244" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp#m244">无效天示例</a></td>
+          </tr>
+          <tr>
+            <td align="center">disabledDates</td>
+            <td align="center">Array</td>
+            <td align="center">null</td>
+            <td>可以使用此功能禁用所指定的一个或多个日期<br />
+            你可以参考<a href="2.4.asp.htm#m245" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp#m245">无效日期示例</a></td>
+          </tr>
+          <tr>
+            <td align="center">opposite</td>
+            <td align="center">bool</td>
+            <td align="center">false</td>
+            <td>默认为false, 为true时,无效日期变成有效日期 <br />
+                <span class="STYLE1">注意:该属性对无效天特殊天不起作用</span><br />
+            你可以参考<a href="2.4.asp.htm#m246" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp#m246">有效日期示例</a></td>
+          </tr>
+          <tr>
+            <td align="center">specialDates</td>
+            <td align="center">Array</td>
+            <td align="center">null</td>
+            <td>特殊日期,对指定的日期进行高亮显示<br />
+            你可以参考<a href="2.4.asp.htm#m247" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp#m247">特殊天与特殊日期示例</a></td>
+          </tr>
+          <tr>
+            <td align="center">specialDays</td>
+            <td align="center">Array</td>
+            <td align="center">null</td>
+            <td>特殊天,使用此功能禁用周日至周六所对应的日期进行高亮显示<br />
+            0至6 分别代表 周日至周六<br />
+            你可以参考<a href="2.4.asp.htm#m247" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp#m247">特殊天与特殊日期示例</a></td>
+          </tr>
+          <tr>
+            <td align="center">onpicking</td>
+            <td align="center">function</td>
+            <td align="center">null</td>
+            <td rowspan="4">此四个参数为事件参数<br />
+            你可以参考<a href="2.5.asp.htm#m25" tppabs="http://www.my97.net/dp/demo/resource/2.5.asp#m25">自定义事件示例</a></td>
+          </tr>
+          <tr>
+            <td align="center">onpicked</td>
+            <td align="center">function</td>
+            <td align="center">null</td>
+          </tr>
+          <tr>
+            <td align="center">onclearing</td>
+            <td align="center">function</td>
+            <td align="center">null</td>
+          </tr>
+          <tr>
+            <td align="center">oncleared</td>
+            <td align="center">function</td>
+            <td align="center">null</td>
+          </tr>
+          <tr>
+            <td align="center">ychanging ychanged <br />
+Mchanging Mchanged<br />
+dchanging dchanged<br />
+Hchanging Hchanged<br />
+mchanging mchanged<br />
+schanging schanged </td>
+            <td align="center">function</td>
+            <td align="center">null</td>
+            <td><span class="STYLE1">(4.6Beta3新增)</span><br />
+              <br />
+              y M d H m s 分别表示年月日时分秒<br />
+              changing 事件发生在属性改变之前<br />
+            changed 事件发生在属性改变之后<br />
+            <br />
+            你可以参考<a href="2.5.asp-.htm#m254" tppabs="http://www.my97.net/dp/demo/resource/2.5.asp?#m254">示例5-4-1</a></td>
+          </tr>
+          
+        </table>
+      </li>
+      <li>配置全局默认值<a name="m312" id="m312"></a>
+        <p>通过配置WdatePicker.js的属性可以避免每次调用都传入配置值,为变成带来很多方便.<br />
+        在默认情况下My97为每个属性都配置了默认值,这些默认值都可以在WdatePicker.js中修改的<br />
+        你可以根据你个人的喜好更改这些值<br />
+        <br />
+        比如你比较不喜欢默认的皮肤default 而更喜欢 whyGreen 这个皮肤,<br />
+        你可以直接在WdatePicker.js把skin值改为 whyGreen<br />
+        这样,你就<span class="STYLE2">不必每次调用控件的时候都传入</span> skin:'whyGreen' 了<br />
+        你学会了吗?</p>
+      </li>
+      <li>配置单个控件<a name="m313" id="m313"></a>
+        <p>在控件里面你可以使用 onfocus 或 onclick 事件来调用WdatePicker函数来触发日期控件<br />
+        WdatePicker({})其中{}中的内容都是只对当前实例有效,你可以任意配置属性表里有的所有属性<br />
+        你可以随意的组合这些属性,达到你的需求<br />
+        My97日期控件在这方面是做得非常灵活的.</p>
+      </li>
+	  <li>多套配置快速切换<a name="m314" id="m314"></a>
+        <p>您可以设置多个WdatePicker.js文件,如
+cn_WdatePicker.js,en_WdatePicker.js,simple_WdatePicker.js等<br />
+        在不同的页面引入不同的        WdatePicker.js 达到配置快速切换的目的.<br />
+        <span class="STYLE1">注意:文件必须以 _WdatePicker.js(大小写不限制) 为后缀,形如 &lt;yourname&gt;_WdatePicker.js</span></p>
+	  </li>
+    </ol>
+    <h3>2. 语言配置<a name="m32" id="m32"></a> </h3>
+    <ol>
+      <li>语言列表<a name="m321" id="m321"></a><p>My97DatePicker目录下有个config.js(4.8以后在WdatePicker.js中),里面有段代码: <br />
+        var <span class="STYLE1">langList</span> = <br />
+        [<br />
+{<span class="STYLE2">name:</span><span class="STYLE1">'en'</span>,		<span class="STYLE2">charset:</span><span class="STYLE1">'UTF-8'</span>},<br />
+{name:'zh-cn',	charset:'gb2312'},<br />
+{name:'zh-tw',	charset:'GBK'}<br />
+];<br />
+<br />
+这就是语言列表,每个项有name和charset两个属性.<br />
+name 表示语言的名称(必须与浏览器的语言字符串命名相同),在配置的时候,<span class="STYLE2">lang属性只能是配置列表里面已有的项,否则将自动返回第一项</span><br />
+charset 表示对应语言目录下的js文件所对应的编码格式</p>
+      </li>
+      <li>语言安装说明<a name="m322" id="m322"></a>
+        <p>分两步轻松实现:<br />
+        1 将语言文件拷贝到 lang 目录<br />
+        2 打开 config.js 配置语言列表</p>
+      </li>
+    </ol>
+    <h3>3. 皮肤配置<a name="m33" id="m33"></a></h3>
+    <ol>
+      <li>皮肤列表<a name="m331" id="m331"></a>
+      <p>My97DatePicker目录下有个config.js(4.8以后在WdatePicker.js中),里面有段代码:
+      <br />
+      var <span class="STYLE1">skinList</span> = <br />
+      [<br />
+{<span class="STYLE2">name:</span><span class="STYLE1">'default'</span>,	<span class="STYLE2">charset:</span><span class="STYLE1">'gb2312'</span>},<br />
+{name:'whyGreen',	charset:'gb2312'},<br />
+{name:'blue',		charset:'gb2312'},<br />
+{name:'simple',		charset:'gb2312'} <br />
+];<br />
+<br />
+      这就是皮肤列表,每个项有name和charset两个属性.<br />
+      name 表示皮肤的名称,在配置的时候,<span class="STYLE2">skin属性只能是配置列表里面已有的项,否则将自动返回第一项</span><br />
+      charset 表示对应皮肤目录下的css文件:datepicker.css所对应的编码格式</p>
+      </li>
+      <li>皮肤安装说明<a name="m332" id="m332"></a><p>分两步轻松实现:<br />
+1 将皮肤文件包拷贝到 skin 目录<br />
+2 打开 config.js 配置皮肤列表
+        <br />
+        <br />
+        <span class="STYLE1">注意:安装过多的皮肤会影响性能,一般只安装自己使用的皮肤,3个以下比较适宜</span></p>
+      </li>
+    </ol>
+    <h2><a href="999.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/999.asp">四. 如何使用</a><a name="m4" id="m4"></a></h2>
+    <br />
+    <br />
+  </div>
+  <div style="clear:both"></div>
+</div>
+<div class="dCenter dBody" style="padding-left:72px">
+<script type="text/javascript"><!--
+google_ad_client = "ca-pub-6343250634002651";
+/* 底部 */
+google_ad_slot = "0599809152";
+google_ad_width = 728;
+google_ad_height = 90;
+//-->
+</script>
+<script type="text/javascript">
+</script>
+</div>
+<div id="footer" class="dCenter">&copy; 2010 <a href="mailto:smallcarrot@163.com">My97</a> All Rights Reserved.&nbsp;&nbsp;&nbsp;&nbsp;<script type="text/javascript">
+var _bdhmProtocol = (("https:" == document.location.protocol) ? " https://" : " http://");
+document.write(unescape("%3Cscript src='" + _bdhmProtocol + "hm.baidu.com/h.js%3F489957c212e14340592fb2e4921b2f1d' type='text/javascript'%3E%3C/script%3E"));
+</script>&nbsp;&nbsp;&nbsp;&nbsp;浙ICP备11060275号
+</div>
+</body>
+</html>

+ 177 - 0
src/main/webapp/static/My97DatePicker/docs/demo/resource/999.asp-.htm

@@ -0,0 +1,177 @@
+
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
+<meta name="keywords" content="日期控件 datepicker calendar 日历控件 javascript js日历控件 带时间 自定义格式 月历控件 日期时间 日期选择" />
+<title>My97日期控件 功能演示 常规功能 My97 Datepicker Demo</title>
+<link href="../../css/base.css" tppabs="http://www.my97.net/dp/css/base.css" rel="stylesheet" type="text/css" />
+<link href="demo.css" tppabs="http://www.my97.net/dp/demo/resource/demo.css" rel="stylesheet" type="text/css" />
+</head>
+<body>
+<iframe src="../../head.asp" tppabs="http://www.my97.net/dp/head.asp" scrolling="no" frameborder="0" height="100px" width="100%"></iframe>
+<script language="JavaScript" type="text/javascript" src="../../../WdatePicker.js" tppabs="http://www.my97.net/dp/My97DatePicker/WdatePicker.js"></script>
+<div class="dCenter dBody">
+  <div id="content">
+
+  	<h2><a href="main.asp" tppabs="http://www.my97.net/dp/demo/resource/main.asp"><strong>一. 简介</strong></a><a name="m2" id="m2"></a></h2>
+  	<h2><a href="2.1.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.1.asp"><strong>二. 功能及示例</strong></a><a name="m2" id="m2"></a></h2>
+    <h2><a href="3.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/3.asp">三. 配置说明</a><a name="m3" id="m3"></a></h2>
+    <h2>四. 如何使用<a name="m4" id="m4"></a></h2>
+    <p style="margin-left:20px">1. 在使用该日期控件的文件中加入JS库<span class="STYLE2">(仅这一个文件即可,其他文件会自动引入,请勿删除或改名)</span>, 代码如下   &lt;script language=&quot;javascript&quot; type=&quot;text/javascript&quot;   src=&quot;datepicker/WdatePicker.js&quot;&gt;&lt;/script&gt;<br />
+      注:<span class="STYLE2">src=&quot;datepicker/WdatePicker.js&quot;</span> 请根据你的实际情况改变路径<br />
+      <br />
+      2. 加上主调函数 WdatePicker<br />
+      关于 WdatePicker 的用法:<span class="STYLE2"><br />
+      <br />
+      如果您是新手,对js还不是很了解的话</span><span class="STYLE1">一定要多看看这份文档</span><br />
+      基本上每一个演示的示例下面都有相关代码,并且 <span class="STYLE2">关键属性用蓝字标出</span>,<span class="STYLE1">关键值用红字标出</span> 应该很容易看明白 <br />
+      <br />
+      <span class="STYLE2">如果您有一定的水准<br />
+      </span>希望能从头到尾把功能介绍好好看一遍,这样大部分功能你都会用了<br />
+      <br />
+      <span class="STYLE2">如果您是高手</span><br />
+      建议您通读配置说明和内置函数</p>
+    <h2>五. 内置函数和属性<a name="m5" id="m5"></a></h2>
+    <table width="100%" border="0" cellpadding="3" cellspacing="1" bgcolor="#000000">
+      <tr>
+        <th>函数名</th>
+        <th>返回值类型</th>
+        <th>作用域</th>
+        <th>参数</th>
+        <th>描述</th>
+      </tr>
+      <tr>
+        <td align="center">$dp.show</td>
+        <td align="center">void</td>
+        <td align="center">全局</td>
+        <td>无</td>
+        <td>显示日期选择框</td>
+      </tr>
+      <tr>
+        <td align="center">$dp.hide</td>
+        <td align="center">void</td>
+        <td align="center">全局</td>
+        <td>无</td>
+        <td>隐藏日期选择框</td>
+      </tr>
+      <tr>
+        <td align="center">$dp.$D</td>
+        <td align="center">String</td>
+        <td align="center">全局</td>
+        <td><span class="STYLE2">id [string]:</span> 对象的ID <br />
+          <span class="STYLE2">arg [object]:</span> 日期差量,可以设置成<br />
+          {y:[值],M:[值],d:[值],H:[值],m:[值],s:[值]}<br />
+          属性 y,M,d,H,m,s 分别代表 年月日时分秒<br />
+          {M:3,d:7} 表示 3个月零7天<br />
+          {d:1,H:1} 表示1天多1小时</td>
+        <td>将id对应的日期框中的日期字符串,加上定义的日期差量,返回使用real格式化后的日期串<br />
+          <span class="STYLE2">参考 示例 4-3-2</span></td>
+      </tr>
+      <tr>
+        <td align="center">$dp.$DV</td>
+        <td align="center">String</td>
+        <td align="center">全局</td>
+        <td><span class="STYLE2">v [string]:</span> 日期字符串<br />
+          <span class="STYLE2">arg [object]:</span> 同上例的arg </td>
+        <td>将传入的日期字符串,加上定义的日期差量,返回使用real格式化后的日期串<br />
+          <span class="STYLE2">参考 示例 4-3-3</span></td>
+      </tr>
+      <tr>
+        <td colspan="5">以下函数只在事件自定义函数中有效</td>
+      </tr>
+      <tr>
+        <td align="center">$dp.cal.getP</td>
+        <td align="center">String</td>
+        <td align="center">事件function</td>
+        <td><span class="STYLE2">p [string]:</span> 属性名称 yMdHmswWD分别代表年,月,日,时,分,秒,星期(0-6),周(1-52),星期(一-六) <br />
+          <span class="STYLE2">f [string]:</span> format 格式字符串<br />
+          设置方法参考 <span class="STYLE2">1.4 自定义格式</span></td>
+        <td>返回所指定属性被格式字符串格式化后的值[单属性],在changing,picking,clearing事件中返回<span class="STYLE1">选择前</span>的值<br />
+          <span class="STYLE2">参考 示例 1-2-2</span></td>
+      </tr>
+      <tr>
+        <td align="center">$dp.cal.getDateStr</td>
+        <td align="center">String </td>
+        <td align="center">事件function</td>
+        <td><span class="STYLE2">f [string]:</span> 格式字符串,为空时使用dateFmt<br /></td>
+        <td>返回所指定属性被格式字符串格式化后的值[整个值],在changing,picking,clearing事件中返回<span class="STYLE1">选择前</span>的值</td>
+      </tr>
+      <tr>
+        <td align="center">        $dp.cal.getNewP</td>
+        <td align="center">String</td>
+        <td align="center">事件function</td>
+        <td>用法同$dp.cal.getP</td>
+        <td>返回所指定属性被格式字符串格式化后的值[单属性],在changing,picking,clearing事件中返回<span class="STYLE1">选择后</span>的值</td>
+      </tr>
+      <tr>
+        <td align="center">        $dp.cal.getNewDateStr</td>
+        <td align="center">String</td>
+        <td align="center">事件function</td>
+        <td>用法同$dp.cal.getDateStr</td>
+        <td>返回所指定属性被格式字符串格式化后的值[整个值],在changing,picking,clearing事件中返回<span class="STYLE1">选择后</span>的值</td>
+      </tr>
+    </table>
+    <br />
+    <br />
+    <table width="100%" border="0" cellpadding="3" cellspacing="1" bgcolor="#000000">
+      <tr>
+        <th width="14%">属性名</th>
+        <th width="10%">返回值类型</th>
+        <th width="11%">作用域</th>
+        <th width="29%">参数</th>
+        <th width="36%">描述</th>
+      </tr>
+      <tr>
+        <td align="center">          $dp.cal.date</td>
+        <td align="center">object</td>
+        <td align="center">事件function</td>
+        <td>$dp.cal.date.y:返回 年<br />
+          $dp.cal.date.M:返回 月<br />
+          $dp.cal.date.d:返回 日<br />
+          $dp.cal.date.H:返回 时<br />
+          $dp.cal.date.m:返回 分<br />
+          $dp.cal.date.s:返回 秒 <br /></td>
+        <td>在changing,picking,clearing事件中返回<span class="STYLE1">选择前</span>的日期对象</td>
+      </tr>
+      <tr>
+        <td align="center">          $dp.cal.newdate</td>
+        <td align="center">object</td>
+        <td align="center">事件function</td>
+        <td>用法同$dp.cal.date</td>
+        <td>在changing,picking,clearing事件中返回<span class="STYLE1">选择后</span>的日期对象</td>
+      </tr>
+    </table>
+<h2>六. 疑难解答<a name="m6" id="m6"></a></h2>
+    <p style="margin-left:20px">任何问题,请先参考 <a href="javascript:if(confirm('http://www.my97.net/dp/support.asp  \n\n该文件未被 Teleport Pro 下载,因为 它位于起始地址以设置的边界以外的域或路径中。  \n\n你想要从服务器打开它吗?'))window.location='http://www.my97.net/dp/support.asp'" tppabs="http://www.my97.net/dp/support.asp" target="_top">技术支持</a> <br />
+      如果找不到答案,您可以直接在blog留言,或者通过下面的联系方式与我联系</p>
+    <h2>七. 联系My97<a name="m7" id="m7"></a></h2>
+    <p style="margin-left:20px"> * 如果您在使用过程中遇到问题,或者有更好的建议<br />
+      * 欢迎您访问<br />
+      * BLOG: <a href="javascript:if(confirm('http://my97.cnblogs.com/  \n\n该文件未被 Teleport Pro 下载,因为 它位于起始地址以设置的边界以外的域或路径中。  \n\n你想要从服务器打开它吗?'))window.location='http://my97.cnblogs.com/'" tppabs="http://my97.cnblogs.com/">http://my97.cnblogs.com</a><br />
+      * MAIL: support$my97.net($换成@)<br />
+      * 有问题在我blog留言或给我Email吧,<span class="STYLE1">最好先仔细看说明,很多问题都是因为没有仔细看说明导致的</span> </p>
+    <br />
+    <br />
+  </div>
+  <div style="clear:both"></div>
+</div>
+<div class="dCenter dBody" style="padding-left:72px">
+<script type="text/javascript"><!--
+google_ad_client = "ca-pub-6343250634002651";
+/* 底部 */
+google_ad_slot = "0599809152";
+google_ad_width = 728;
+google_ad_height = 90;
+//-->
+</script>
+<script type="text/javascript">
+</script>
+</div>
+<div id="footer" class="dCenter">&copy; 2010 <a href="mailto:smallcarrot@163.com">My97</a> All Rights Reserved.&nbsp;&nbsp;&nbsp;&nbsp;<script type="text/javascript">
+var _bdhmProtocol = (("https:" == document.location.protocol) ? " https://" : " http://");
+document.write(unescape("%3Cscript src='" + _bdhmProtocol + "hm.baidu.com/h.js%3F489957c212e14340592fb2e4921b2f1d' type='text/javascript'%3E%3C/script%3E"));
+</script>&nbsp;&nbsp;&nbsp;&nbsp;浙ICP备11060275号
+</div>
+</body>
+</html>

+ 177 - 0
src/main/webapp/static/My97DatePicker/docs/demo/resource/999.asp.htm

@@ -0,0 +1,177 @@
+
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
+<meta name="keywords" content="日期控件 datepicker calendar 日历控件 javascript js日历控件 带时间 自定义格式 月历控件 日期时间 日期选择" />
+<title>My97日期控件 功能演示 常规功能 My97 Datepicker Demo</title>
+<link href="../../css/base.css" tppabs="http://www.my97.net/dp/css/base.css" rel="stylesheet" type="text/css" />
+<link href="demo.css" tppabs="http://www.my97.net/dp/demo/resource/demo.css" rel="stylesheet" type="text/css" />
+</head>
+<body>
+<iframe src="../../head.asp" tppabs="http://www.my97.net/dp/head.asp" scrolling="no" frameborder="0" height="100px" width="100%"></iframe>
+<script language="JavaScript" type="text/javascript" src="../../../WdatePicker.js" tppabs="http://www.my97.net/dp/My97DatePicker/WdatePicker.js"></script>
+<div class="dCenter dBody">
+  <div id="content">
+
+  	<h2><a href="main.asp" tppabs="http://www.my97.net/dp/demo/resource/main.asp"><strong>一. 简介</strong></a><a name="m2" id="m2"></a></h2>
+  	<h2><a href="2.1.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/2.1.asp"><strong>二. 功能及示例</strong></a><a name="m2" id="m2"></a></h2>
+    <h2><a href="3.asp.htm" tppabs="http://www.my97.net/dp/demo/resource/3.asp">三. 配置说明</a><a name="m3" id="m3"></a></h2>
+    <h2>四. 如何使用<a name="m4" id="m4"></a></h2>
+    <p style="margin-left:20px">1. 在使用该日期控件的文件中加入JS库<span class="STYLE2">(仅这一个文件即可,其他文件会自动引入,请勿删除或改名)</span>, 代码如下   &lt;script language=&quot;javascript&quot; type=&quot;text/javascript&quot;   src=&quot;datepicker/WdatePicker.js&quot;&gt;&lt;/script&gt;<br />
+      注:<span class="STYLE2">src=&quot;datepicker/WdatePicker.js&quot;</span> 请根据你的实际情况改变路径<br />
+      <br />
+      2. 加上主调函数 WdatePicker<br />
+      关于 WdatePicker 的用法:<span class="STYLE2"><br />
+      <br />
+      如果您是新手,对js还不是很了解的话</span><span class="STYLE1">一定要多看看这份文档</span><br />
+      基本上每一个演示的示例下面都有相关代码,并且 <span class="STYLE2">关键属性用蓝字标出</span>,<span class="STYLE1">关键值用红字标出</span> 应该很容易看明白 <br />
+      <br />
+      <span class="STYLE2">如果您有一定的水准<br />
+      </span>希望能从头到尾把功能介绍好好看一遍,这样大部分功能你都会用了<br />
+      <br />
+      <span class="STYLE2">如果您是高手</span><br />
+      建议您通读配置说明和内置函数</p>
+    <h2>五. 内置函数和属性<a name="m5" id="m5"></a></h2>
+    <table width="100%" border="0" cellpadding="3" cellspacing="1" bgcolor="#000000">
+      <tr>
+        <th>函数名</th>
+        <th>返回值类型</th>
+        <th>作用域</th>
+        <th>参数</th>
+        <th>描述</th>
+      </tr>
+      <tr>
+        <td align="center">$dp.show</td>
+        <td align="center">void</td>
+        <td align="center">全局</td>
+        <td>无</td>
+        <td>显示日期选择框</td>
+      </tr>
+      <tr>
+        <td align="center">$dp.hide</td>
+        <td align="center">void</td>
+        <td align="center">全局</td>
+        <td>无</td>
+        <td>隐藏日期选择框</td>
+      </tr>
+      <tr>
+        <td align="center">$dp.$D</td>
+        <td align="center">String</td>
+        <td align="center">全局</td>
+        <td><span class="STYLE2">id [string]:</span> 对象的ID <br />
+          <span class="STYLE2">arg [object]:</span> 日期差量,可以设置成<br />
+          {y:[值],M:[值],d:[值],H:[值],m:[值],s:[值]}<br />
+          属性 y,M,d,H,m,s 分别代表 年月日时分秒<br />
+          {M:3,d:7} 表示 3个月零7天<br />
+          {d:1,H:1} 表示1天多1小时</td>
+        <td>将id对应的日期框中的日期字符串,加上定义的日期差量,返回使用real格式化后的日期串<br />
+          <span class="STYLE2">参考 示例 4-3-2</span></td>
+      </tr>
+      <tr>
+        <td align="center">$dp.$DV</td>
+        <td align="center">String</td>
+        <td align="center">全局</td>
+        <td><span class="STYLE2">v [string]:</span> 日期字符串<br />
+          <span class="STYLE2">arg [object]:</span> 同上例的arg </td>
+        <td>将传入的日期字符串,加上定义的日期差量,返回使用real格式化后的日期串<br />
+          <span class="STYLE2">参考 示例 4-3-3</span></td>
+      </tr>
+      <tr>
+        <td colspan="5">以下函数只在事件自定义函数中有效</td>
+      </tr>
+      <tr>
+        <td align="center">$dp.cal.getP</td>
+        <td align="center">String</td>
+        <td align="center">事件function</td>
+        <td><span class="STYLE2">p [string]:</span> 属性名称 yMdHmswWD分别代表年,月,日,时,分,秒,星期(0-6),周(1-52),星期(一-六) <br />
+          <span class="STYLE2">f [string]:</span> format 格式字符串<br />
+          设置方法参考 <span class="STYLE2">1.4 自定义格式</span></td>
+        <td>返回所指定属性被格式字符串格式化后的值[单属性],在changing,picking,clearing事件中返回<span class="STYLE1">选择前</span>的值<br />
+          <span class="STYLE2">参考 示例 1-2-2</span></td>
+      </tr>
+      <tr>
+        <td align="center">$dp.cal.getDateStr</td>
+        <td align="center">String </td>
+        <td align="center">事件function</td>
+        <td><span class="STYLE2">f [string]:</span> 格式字符串,为空时使用dateFmt<br /></td>
+        <td>返回所指定属性被格式字符串格式化后的值[整个值],在changing,picking,clearing事件中返回<span class="STYLE1">选择前</span>的值</td>
+      </tr>
+      <tr>
+        <td align="center">        $dp.cal.getNewP</td>
+        <td align="center">String</td>
+        <td align="center">事件function</td>
+        <td>用法同$dp.cal.getP</td>
+        <td>返回所指定属性被格式字符串格式化后的值[单属性],在changing,picking,clearing事件中返回<span class="STYLE1">选择后</span>的值</td>
+      </tr>
+      <tr>
+        <td align="center">        $dp.cal.getNewDateStr</td>
+        <td align="center">String</td>
+        <td align="center">事件function</td>
+        <td>用法同$dp.cal.getDateStr</td>
+        <td>返回所指定属性被格式字符串格式化后的值[整个值],在changing,picking,clearing事件中返回<span class="STYLE1">选择后</span>的值</td>
+      </tr>
+    </table>
+    <br />
+    <br />
+    <table width="100%" border="0" cellpadding="3" cellspacing="1" bgcolor="#000000">
+      <tr>
+        <th width="14%">属性名</th>
+        <th width="10%">返回值类型</th>
+        <th width="11%">作用域</th>
+        <th width="29%">参数</th>
+        <th width="36%">描述</th>
+      </tr>
+      <tr>
+        <td align="center">          $dp.cal.date</td>
+        <td align="center">object</td>
+        <td align="center">事件function</td>
+        <td>$dp.cal.date.y:返回 年<br />
+          $dp.cal.date.M:返回 月<br />
+          $dp.cal.date.d:返回 日<br />
+          $dp.cal.date.H:返回 时<br />
+          $dp.cal.date.m:返回 分<br />
+          $dp.cal.date.s:返回 秒 <br /></td>
+        <td>在changing,picking,clearing事件中返回<span class="STYLE1">选择前</span>的日期对象</td>
+      </tr>
+      <tr>
+        <td align="center">          $dp.cal.newdate</td>
+        <td align="center">object</td>
+        <td align="center">事件function</td>
+        <td>用法同$dp.cal.date</td>
+        <td>在changing,picking,clearing事件中返回<span class="STYLE1">选择后</span>的日期对象</td>
+      </tr>
+    </table>
+<h2>六. 疑难解答<a name="m6" id="m6"></a></h2>
+    <p style="margin-left:20px">任何问题,请先参考 <a href="javascript:if(confirm('http://www.my97.net/dp/support.asp  \n\n该文件未被 Teleport Pro 下载,因为 它位于起始地址以设置的边界以外的域或路径中。  \n\n你想要从服务器打开它吗?'))window.location='http://www.my97.net/dp/support.asp'" tppabs="http://www.my97.net/dp/support.asp" target="_top">技术支持</a> <br />
+      如果找不到答案,您可以直接在blog留言,或者通过下面的联系方式与我联系</p>
+    <h2>七. 联系My97<a name="m7" id="m7"></a></h2>
+    <p style="margin-left:20px"> * 如果您在使用过程中遇到问题,或者有更好的建议<br />
+      * 欢迎您访问<br />
+      * BLOG: <a href="javascript:if(confirm('http://my97.cnblogs.com/  \n\n该文件未被 Teleport Pro 下载,因为 它位于起始地址以设置的边界以外的域或路径中。  \n\n你想要从服务器打开它吗?'))window.location='http://my97.cnblogs.com/'" tppabs="http://my97.cnblogs.com/">http://my97.cnblogs.com</a><br />
+      * MAIL: support$my97.net($换成@)<br />
+      * 有问题在我blog留言或给我Email吧,<span class="STYLE1">最好先仔细看说明,很多问题都是因为没有仔细看说明导致的</span> </p>
+    <br />
+    <br />
+  </div>
+  <div style="clear:both"></div>
+</div>
+<div class="dCenter dBody" style="padding-left:72px">
+<script type="text/javascript"><!--
+google_ad_client = "ca-pub-6343250634002651";
+/* 底部 */
+google_ad_slot = "0599809152";
+google_ad_width = 728;
+google_ad_height = 90;
+//-->
+</script>
+<script type="text/javascript">
+</script>
+</div>
+<div id="footer" class="dCenter">&copy; 2010 <a href="mailto:smallcarrot@163.com">My97</a> All Rights Reserved.&nbsp;&nbsp;&nbsp;&nbsp;<script type="text/javascript">
+var _bdhmProtocol = (("https:" == document.location.protocol) ? " https://" : " http://");
+document.write(unescape("%3Cscript src='" + _bdhmProtocol + "hm.baidu.com/h.js%3F489957c212e14340592fb2e4921b2f1d' type='text/javascript'%3E%3C/script%3E"));
+</script>&nbsp;&nbsp;&nbsp;&nbsp;浙ICP备11060275号
+</div>
+</body>
+</html>

+ 61 - 0
src/main/webapp/static/My97DatePicker/docs/demo/resource/demo.css

@@ -0,0 +1,61 @@
+
+p,table {
+	font-weight:normal;
+}
+td {
+	padding:3px;
+	background-color:#ffffff;
+}
+th {
+	text-align:center;
+	padding:3px;
+	background-color:#ccc;
+}
+#content {
+	padding-left:50px;
+	padding-right:40px;
+}
+#content h2 {
+	font-size: 18px;
+	color: #1E9300;
+	padding-top:30px;
+	margin-bottom: 8px;
+}
+#content h2 a {
+	color: #1E9300;
+}
+#content h3 {
+	margin-top:24px;margin-bottom: 8px; FONT: bold 14px 宋体,tahoma,arial,sans-serif; COLOR:#0033CC;
+}
+#content h3 a {
+	color: #0033CC;
+}
+#content ul {	
+	margin-left: 20px;
+}
+#content ol {	
+	margin:16px 0px 8px 36px; FONT: bold 9pt 宋体,tahoma,arial,sans-serif;
+}
+#content ol li{	
+	margin-top:16px;
+}
+#content div {
+	margin-top:20px;
+	margin-bottom:10px;
+	border:#333 solid 1px;
+}
+
+#content div h4 {
+	font-size:9pt;
+	padding:3px;
+	background:#EEE;
+	margin-bottom:5px;
+}
+#content div p {
+	padding:5px;
+}
+
+.STYLE1 {
+	color: #FF0000;
+}
+.STYLE2 {color: #0000FF}

+ 45 - 0
src/main/webapp/static/My97DatePicker/docs/demo/resource/demo_iframe.htm

@@ -0,0 +1,45 @@
+<html>
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
+<meta name="keywords" content="日期控件 datepicker calendar 日历控件 javascript js日历控件 带时间 自定义格式 月历控件 日期时间 日期选择" />
+<title>My97 DatePicker 4.0 演示-框架1</title>
+<script language="javascript" type="text/javascript" src="../../../WdatePicker.js" tppabs="http://www.my97.net/dp/My97DatePicker/WdatePicker.js"></script>
+<style type="text/css">
+<!--
+#Layer1 {
+	position:absolute;
+	width:200px;
+	height:115px;
+	z-index:1;
+	left: 22px;
+	top: 73px;
+	background-color: #0033FF;
+}
+#Layer2 {
+	position:absolute;
+	width:200px;
+	height:115px;
+	z-index:1;
+	left: 459px;
+	top: 80px;
+}
+-->
+</style>
+</head>
+<body bgcolor="#60FFAF">
+<p>内嵌框架1:</p>
+<p>格式为:yyyy-MM-dd HH:mm<br>
+  <input type="text" class="Wdate" id="test2" style="width:200px" onFocus="WdatePicker({dateFmt:'yyyy-MM-dd HH:mm'})" />
+</p>
+  </p>
+  <select name="select">
+    <option>可以遮住DropDownList</option>
+  </select>
+<p> </p>
+  <p>&nbsp;</p>
+<p>&nbsp;</p>
+<div id="Layer2">
+ <iframe id='f22' src="demo_iframe2.htm" tppabs="http://www.my97.net/dp/demo/resource/demo_iframe2.htm" frameborder="0" width="300px" height="150px"></iframe> 
+</div>
+</body>
+</html>

+ 16 - 0
src/main/webapp/static/My97DatePicker/docs/demo/resource/demo_iframe2.htm

@@ -0,0 +1,16 @@
+<html>
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
+<meta name="keywords" content="日期控件 datepicker calendar 日历控件 javascript js日历控件 带时间 自定义格式 月历控件 日期时间 日期选择" />
+<title>My97 DatePicker 4.0 演示-框架2</title>
+<script language="javascript" type="text/javascript" src="../../../WdatePicker.js" tppabs="http://www.my97.net/dp/My97DatePicker/WdatePicker.js"></script>
+</head>
+
+<body bgcolor="#C8E3FF">
+<p>内嵌框架2:</p>
+<p>
+  <input type="text" name="test" class="Wdate" onFocus="WdatePicker({dateFmt:'yyyy年MM月dd日',skin:'whyGreen'})"/>
+</p>
+<p>内嵌框架2:</p>
+</body>
+</html>

+ 120 - 0
src/main/webapp/static/My97DatePicker/docs/demo/resource/left.htm

@@ -0,0 +1,120 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
+<meta name="keywords" content="日期控件 datepicker calendar 日历控件 javascript js日历控件 带时间 自定义格式 月历控件 日期时间 日期选择" />
+<title>My97 DatePicker 演示 - 目录导航</title>
+<base target="mainFrm" />
+<link href="../../css/base.css" tppabs="http://www.my97.net/dp/css/base.css" rel="stylesheet" type="text/css" />
+<style type="text/css">
+<!--
+a {
+	text-decoration: none;
+	color: #555;
+}
+-->
+</style>
+</head>
+<body>
+<DIV class=res-block style="text-align:left;margin:10px 5px 10px 10px">
+  <DIV class=res-block-inner>
+    <h3>My97DatePicker 演示和文档</h3>
+    <h3><a href="main.asp#m1" tppabs="http://www.my97.net/dp/demo/resource/main.asp#m1">一. 简介</a></h3>
+    <UL>
+      <LI><a href="main.asp#m11" tppabs="http://www.my97.net/dp/demo/resource/main.asp#m11">简介</a></LI>
+      <LI><a href="main.asp#m12" tppabs="http://www.my97.net/dp/demo/resource/main.asp#m12">注意事项</a></LI>
+      <LI><a href="main.asp#m13" tppabs="http://www.my97.net/dp/demo/resource/main.asp#m13">支持的浏览器</a></LI>
+    </UL>
+    <h3><a href="2.1.asp.htm#m2" tppabs="http://www.my97.net/dp/demo/resource/2.1.asp#m2">二. 功能及示例</a></h3>
+    <ul>
+      <LI><a href="2.1.asp.htm#m21" tppabs="http://www.my97.net/dp/demo/resource/2.1.asp#m21">常规功能</a>
+        <UL style="list-style-type:square">
+          <LI><a href="2.1.asp.htm#m211" tppabs="http://www.my97.net/dp/demo/resource/2.1.asp#m211">支持多种调用模式</a></LI>
+          <LI><a href="2.1.asp.htm#m212" tppabs="http://www.my97.net/dp/demo/resource/2.1.asp#m212">下拉,输入,导航选择日期</a></LI>
+          <LI><a href="2.1.asp.htm#m213" tppabs="http://www.my97.net/dp/demo/resource/2.1.asp#m213">支持周显示</a></LI>
+          <LI><a href="2.1.asp.htm#m214" tppabs="http://www.my97.net/dp/demo/resource/2.1.asp#m214">只读开关,高亮周末功能</a></LI>
+          <LI><a href="2.1.asp.htm#m215" tppabs="http://www.my97.net/dp/demo/resource/2.1.asp#m215">操作按钮自定义</a></LI>
+          <li><a href="2.1.asp.htm#m216" tppabs="http://www.my97.net/dp/demo/resource/2.1.asp#m216">自动选择显示位置</a></li>
+          <li><a href="2.1.asp.htm#m217" tppabs="http://www.my97.net/dp/demo/resource/2.1.asp#m217">自定义弹出位置</a></li>
+          <li><a href="2.1.asp.htm#m218" tppabs="http://www.my97.net/dp/demo/resource/2.1.asp#m218">自定义星期的第一天</a><font color="red">new</font></li>
+        </UL>
+      </LI>
+      <LI><a href="2.2.asp.htm#m22" tppabs="http://www.my97.net/dp/demo/resource/2.2.asp#m22">特色功能</a>
+        <UL style="list-style-type:square">
+          <LI><a href="2.2.asp.htm#m221" tppabs="http://www.my97.net/dp/demo/resource/2.2.asp#m221">平面显示</a></LI>
+          <LI><a href="2.2.asp.htm#m222" tppabs="http://www.my97.net/dp/demo/resource/2.2.asp#m222">支持多种容器</a></LI>
+          <LI><a href="2.2.asp.htm#m223" tppabs="http://www.my97.net/dp/demo/resource/2.2.asp#m223">起始日期功能</a></LI>
+          <LI><a href="2.2.asp.htm#m224" tppabs="http://www.my97.net/dp/demo/resource/2.2.asp#m224">自定义格式</a><font color="red">new</font></LI>
+          <LI><a href="2.2.asp.htm#m225" tppabs="http://www.my97.net/dp/demo/resource/2.2.asp#m225">双月日历功能</a><font color="red">new</font></LI>
+          <LI><a href="2.2.asp.htm#m226" tppabs="http://www.my97.net/dp/demo/resource/2.2.asp#m226">自动纠错功能</a></LI>
+          <LI><a href="2.2.asp.htm#m227" tppabs="http://www.my97.net/dp/demo/resource/2.2.asp#m227">跨无限级框架显示</a></LI>
+          <LI><a href="2.2.asp.htm#m228" tppabs="http://www.my97.net/dp/demo/resource/2.2.asp#m228">民国年日历和其他特殊日历</a></LI>
+          <LI><a href="2.2.asp.htm#m229" tppabs="http://www.my97.net/dp/demo/resource/2.2.asp#m229">编辑功能</a></LI>
+          <LI><a href="2.2.asp.htm#m22a" tppabs="http://www.my97.net/dp/demo/resource/2.2.asp#m22a">为编程带来方便</a></LI>
+          <LI><a href="2.2.asp.htm#m22b" tppabs="http://www.my97.net/dp/demo/resource/2.2.asp#m22b">其他属性</a></LI>
+        </UL>
+      </LI>
+      <LI><a href="2.3.asp.htm#m23" tppabs="http://www.my97.net/dp/demo/resource/2.3.asp#m23">多语言和自定义皮肤</a>
+        <UL style="list-style-type:square">
+          <LI><a href="2.3.asp.htm#m231" tppabs="http://www.my97.net/dp/demo/resource/2.3.asp#m231">多语言支持</a></LI>
+          <LI><a href="2.3.asp.htm#m232" tppabs="http://www.my97.net/dp/demo/resource/2.3.asp#m232">自定义和动态切换皮肤</a></LI>
+        </UL>
+      </LI>
+      <LI><a href="2.4.asp.htm#m24" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp#m24">日期范围限制</a>
+        <UL style="list-style-type:square">
+          <LI><a href="2.4.asp.htm#m241" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp#m241">静态限制</a></LI>
+          <LI><a href="2.4.asp.htm#m242" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp#m242">动态限制</a></LI>
+          <LI><a href="2.4.asp.htm#m243" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp#m243">脚本自定义限制</a></LI>
+          <LI><a href="2.4.asp.htm#m244" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp#m244">无效天</a></LI>
+          <LI><a href="2.4.asp.htm#m245" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp#m245">无效日期</a></LI>
+          <LI><a href="2.4.asp.htm#m246" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp#m246">有效日期</a></LI>
+          <LI><a href="2.4.asp.htm#m247" tppabs="http://www.my97.net/dp/demo/resource/2.4.asp#m247">特殊天和特殊日期<font color="red">new</font></a></LI>
+        </UL>
+      </LI>
+      <LI><a href="2.5.asp.htm#m25" tppabs="http://www.my97.net/dp/demo/resource/2.5.asp#m25">自定义事件</a></LI>
+	  <UL style="list-style-type:square"><li><a href="2.5.asp.htm#m251" tppabs="http://www.my97.net/dp/demo/resource/2.5.asp#m251">自定义事件</a></li>
+	    <li><a href="2.5.asp.htm#m252" tppabs="http://www.my97.net/dp/demo/resource/2.5.asp#m252">onpicking和onpicked事件</a></li>
+	    <li><a href="2.5.asp.htm#m253" tppabs="http://www.my97.net/dp/demo/resource/2.5.asp#m253">onclearing和oncleared事件</a></li>
+	    <li><a href="2.5.asp.htm#m254" tppabs="http://www.my97.net/dp/demo/resource/2.5.asp#m254">changing和changed事件</a></li>
+	  </ul>
+      <LI><a href="2.6.asp.htm#m26" tppabs="http://www.my97.net/dp/demo/resource/2.6.asp#m26">快速选择功能</a></LI>
+    </ul>
+    <h3><a href="3.asp.htm#m3" tppabs="http://www.my97.net/dp/demo/resource/3.asp#m3">三. 配置说明</a></h3>
+    <ul>
+      <LI><a href="3.asp.htm#m31" tppabs="http://www.my97.net/dp/demo/resource/3.asp#m31">属性配置</a>
+        <ul style="list-style-type:square">
+          <LI><a href="3.asp.htm#m311" tppabs="http://www.my97.net/dp/demo/resource/3.asp#m311">属性表</a></LI>
+          <LI><a href="3.asp.htm#m312" tppabs="http://www.my97.net/dp/demo/resource/3.asp#m312">配置全局默认值</a></LI>
+          <LI><a href="3.asp.htm#m313" tppabs="http://www.my97.net/dp/demo/resource/3.asp#m313">配置单个控件</a></LI>
+          <LI><a href="3.asp.htm#m314" tppabs="http://www.my97.net/dp/demo/resource/3.asp#m314">多套配置快速切换</a></LI>
+        </ul>
+      </LI>
+      <LI><a href="3.asp.htm#m32" tppabs="http://www.my97.net/dp/demo/resource/3.asp#m32">语言配置
+        </a>
+        <ul style="list-style-type:square">
+          <LI><a href="3.asp.htm#m321" tppabs="http://www.my97.net/dp/demo/resource/3.asp#m321">语言列表</a></LI>
+          <LI><a href="3.asp.htm#m322" tppabs="http://www.my97.net/dp/demo/resource/3.asp#m322">语言安装说明</a></LI>
+        </ul>
+      </LI>
+      <LI style="list-style-type:square"><a href="3.asp.htm#m33" tppabs="http://www.my97.net/dp/demo/resource/3.asp#m33">皮肤配置</a>
+        <ul>
+          <LI><a href="3.asp.htm#m331" tppabs="http://www.my97.net/dp/demo/resource/3.asp#m331">皮肤列表</a></LI>
+          <LI><a href="3.asp.htm#m332" tppabs="http://www.my97.net/dp/demo/resource/3.asp#m332">皮肤安装说明</a></LI>
+        </ul>
+      </LI>
+    </ul>
+    <h3><a href="999.asp.htm#m4" tppabs="http://www.my97.net/dp/demo/resource/999.asp#m4">四. 如何使用</a></h3>
+    <h3><a href="999.asp.htm#m5" tppabs="http://www.my97.net/dp/demo/resource/999.asp#m5">五. 内置函数和属性</a></h3>
+    <h3><a href="999.asp.htm#m6" tppabs="http://www.my97.net/dp/demo/resource/999.asp#m6">六. 疑难解答</a></h3>
+    <h3><a href="999.asp.htm#m7" tppabs="http://www.my97.net/dp/demo/resource/999.asp#m7">七. 联系My97</a></h3>
+	<br>
+<script type="text/javascript">
+var _bdhmProtocol = (("https:" == document.location.protocol) ? " https://" : " http://");
+document.write(unescape("%3Cscript src='" + _bdhmProtocol + "hm.baidu.com/h.js%3F489957c212e14340592fb2e4921b2f1d' type='text/javascript'%3E%3C/script%3E"));
+</script>
+
+  </DIV>
+  <DIV class=res-block-bottom></DIV>
+</DIV>
+</body>
+</html>

+ 64 - 0
src/main/webapp/static/My97DatePicker/docs/demo/resource/main.asp

@@ -0,0 +1,64 @@
+
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
+<meta name="author" content="My97" /> 
+<meta name="keywords" content="日期控件 datepicker calendar 日历控件 javascript js日历控件 带时间 自定义格式 月历控件 日期时间 日期选择" /><title>My97日期控件 功能演示 My97 Datepicker Demo</title>
+<link href="../../css/base.css" rel="stylesheet" type="text/css" />
+<link href="demo.css" rel="stylesheet" type="text/css" />
+</head>
+<body>
+<iframe src="../../head.asp" scrolling="no" frameborder="0" height="100px" width="100%"></iframe>
+<script language="JavaScript" type="text/javascript" src="../../../WdatePicker.js"></script>
+<div class="dCenter dBody">	
+  <div id="content">
+    <h2>一. 简介<a name="m1" id="m1"></a></h2>
+    <h3>1. 简介<a name="m11" id="m11"></a></h3>
+    <p>目前的版本是:4.8</p>
+    <h3>2. 注意事项<a name="m12" id="m12"></a></h3>
+    <ul>
+      <li>My97DatePicker目录是一个整体,<span class="STYLE1">不可破坏里面的目录结构</span>,也不可对里面的文件改名,可以改目录名</li>
+      <li>My97DatePicker.htm是必须文件,<span class="STYLE1">不可删除(4.8以后不存在此文件)</span></li>
+      <li>各目录及文件的用途: <br />
+        <span class="STYLE2">WdatePicker.js</span> 配置文件,<span class="STYLE1">在调用的地方仅需使用该文件</span>,可多个共存,以xx_WdatePicker.js方式命名<br />
+        <span class="STYLE2">config.js</span> 语言和皮肤配置文件,<span class="STYLE1">无需引入(4.8以后合并入WdatePicker.js)</span><br />
+        <span class="STYLE2">calendar.js</span> 日期库主文件,<span class="STYLE1">无需引入</span><br />
+        <span class="STYLE2">My97DatePicker.htm</span> 临时页面文件,不可删除<span class="STYLE1">(4.8以后不存在此文件)</span><br />
+        <span class="STYLE2">目录lang</span> 存放语言文件,你可以根据需要清理或添加语言文件<br />
+        <span class="STYLE2">目录skin </span>存放皮肤的相关文件,你可以根据需要清理或添加皮肤文件包</li>
+      <li>当WdatePicker.js里的属性:$wdate=true时,在input里加上class=&quot;Wdate&quot;就会在选择框右边出现日期图标,如果您不喜欢这个样式,可以把class=&quot;Wdate&quot;去掉,另外也可以通过修改skin目录下的WdatePicker.css文件来修改样式</li>
+    </ul>
+    <h3>3. 支持的浏览器<a name="m13" id="m13"></a></h3>
+    <p>IE 6.0+ , Firefox 2.0+ , Chrome, Opera 9.5+ , Safari 3.0+<br />
+    </p>
+    <p>&nbsp; </p>
+    <p>注意:IE 8.0是完美支持的,如果你在IE8上使用遇到问题,请与我取得联系,<span class="STYLE1">务必附上能再现你的问题的<strong>纯HTML</strong>代码包</span></p>   
+	<h2><a href="2.1.asp"><strong>二. 功能及示例</strong></a><a name="m2" id="m2"></a></h2>
+    <h2><a href="3.asp">三. 配置说明</a><a name="m3" id="m3"></a></h2>
+    <h2><a href="999.asp">四. 如何使用</a><a name="m4" id="m4"></a></h2>
+    <br />
+<br /> 
+  </div>
+  <div style="clear:both"></div>
+</div>
+<div class="dCenter dBody" style="padding-left:72px">
+<script type="text/javascript"><!--
+google_ad_client = "ca-pub-6343250634002651";
+/* 底部 */
+google_ad_slot = "0599809152";
+google_ad_width = 728;
+google_ad_height = 90;
+//-->
+</script>
+<script type="text/javascript"
+src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
+</script>
+</div>
+<div id="footer" class="dCenter">&copy; 2010 <a href="mailto:smallcarrot@163.com">My97</a> All Rights Reserved.&nbsp;&nbsp;&nbsp;&nbsp;<script type="text/javascript">
+var _bdhmProtocol = (("https:" == document.location.protocol) ? " https://" : " http://");
+document.write(unescape("%3Cscript src='" + _bdhmProtocol + "hm.baidu.com/h.js%3F489957c212e14340592fb2e4921b2f1d' type='text/javascript'%3E%3C/script%3E"));
+</script>&nbsp;&nbsp;&nbsp;&nbsp;浙ICP备11060275号
+</div>
+</body>
+</html>

BIN
src/main/webapp/static/My97DatePicker/docs/demo/resource/pic1.jpg


BIN
src/main/webapp/static/My97DatePicker/docs/demo/resource/pic2.jpg


BIN
src/main/webapp/static/My97DatePicker/docs/demo/resource/pic3.jpg


BIN
src/main/webapp/static/My97DatePicker/docs/images/block/block-body.gif


BIN
src/main/webapp/static/My97DatePicker/docs/images/block/block-bottom.gif


BIN
src/main/webapp/static/My97DatePicker/docs/images/block/block-top.gif


BIN
src/main/webapp/static/My97DatePicker/docs/images/body.jpg


BIN
src/main/webapp/static/My97DatePicker/docs/images/footer.jpg


+ 14 - 0
src/main/webapp/static/My97DatePicker/lang/en.js

@@ -0,0 +1,14 @@
+var $lang={
+errAlertMsg: "Invalid date or the date out of range,redo or not?",
+aWeekStr: ["wk", "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],
+aLongWeekStr:["wk","Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"],
+aMonStr: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"],
+aLongMonStr: ["January","February","March","April","May","June","July","August","September","October","November","December"],
+clearStr: "Clear",
+todayStr: "Today",
+okStr: "OK",
+updateStr: "OK",
+timeStr: "Time",
+quickStr: "Quick Selection",
+err_1: 'MinDate Cannot be bigger than MaxDate!'
+}

+ 14 - 0
src/main/webapp/static/My97DatePicker/lang/zh-cn.js

@@ -0,0 +1,14 @@
+var $lang={
+errAlertMsg: "\u4E0D\u5408\u6CD5\u7684\u65E5\u671F\u683C\u5F0F\u6216\u8005\u65E5\u671F\u8D85\u51FA\u9650\u5B9A\u8303\u56F4,\u9700\u8981\u64A4\u9500\u5417?",
+aWeekStr: ["\u5468","\u65E5","\u4E00","\u4E8C","\u4E09","\u56DB","\u4E94","\u516D"],
+aLongWeekStr:["\u5468","\u661F\u671F\u65E5","\u661F\u671F\u4E00","\u661F\u671F\u4E8C","\u661F\u671F\u4E09","\u661F\u671F\u56DB","\u661F\u671F\u4E94","\u661F\u671F\u516D"],
+aMonStr: ["\u4E00\u6708","\u4E8C\u6708","\u4E09\u6708","\u56DB\u6708","\u4E94\u6708","\u516D\u6708","\u4E03\u6708","\u516B\u6708","\u4E5D\u6708","\u5341\u6708","\u5341\u4E00","\u5341\u4E8C"],
+aLongMonStr: ["\u4E00\u6708","\u4E8C\u6708","\u4E09\u6708","\u56DB\u6708","\u4E94\u6708","\u516D\u6708","\u4E03\u6708","\u516B\u6708","\u4E5D\u6708","\u5341\u6708","\u5341\u4E00\u6708","\u5341\u4E8C\u6708"],
+clearStr: "\u6E05\u7A7A",
+todayStr: "\u4ECA\u5929",
+okStr: "\u786E\u5B9A",
+updateStr: "\u786E\u5B9A",
+timeStr: "\u65F6\u95F4",
+quickStr: "\u5FEB\u901F\u9009\u62E9", 
+err_1: '\u6700\u5C0F\u65E5\u671F\u4E0D\u80FD\u5927\u4E8E\u6700\u5927\u65E5\u671F!'
+}

+ 14 - 0
src/main/webapp/static/My97DatePicker/lang/zh-tw.js

@@ -0,0 +1,14 @@
+var $lang={
+errAlertMsg: "\u4E0D\u5408\u6CD5\u7684\u65E5\u671F\u683C\u5F0F\u6216\u8005\u65E5\u671F\u8D85\u51FA\u9650\u5B9A\u7BC4\u570D,\u9700\u8981\u64A4\u92B7\u55CE?",
+aWeekStr: ["\u5468","\u65E5","\u4E00","\u4E8C","\u4E09","\u56DB","\u4E94","\u516D"],
+aLongWeekStr:["\u5468","\u661F\u671F\u65E5","\u661F\u671F\u4E00","\u661F\u671F\u4E8C","\u661F\u671F\u4E09","\u661F\u671F\u56DB","\u661F\u671F\u4E94","\u661F\u671F\u516D"],
+aMonStr: ["\u4E00\u6708","\u4E8C\u6708","\u4E09\u6708","\u56DB\u6708","\u4E94\u6708","\u516D\u6708","\u4E03\u6708","\u516B\u6708","\u4E5D\u6708","\u5341\u6708","\u5341\u4E00","\u5341\u4E8C"],
+aLongMonStr: ["\u4E00\u6708","\u4E8C\u6708","\u4E09\u6708","\u56DB\u6708","\u4E94\u6708","\u516D\u6708","\u4E03\u6708","\u516B\u6708","\u4E5D\u6708","\u5341\u6708","\u5341\u4E00\u6708","\u5341\u4E8C\u6708"],
+clearStr: "\u6E05\u7A7A",
+todayStr: "\u4ECA\u5929",
+okStr: "\u78BA\u5B9A",
+updateStr: "\u78BA\u5B9A",
+timeStr: "\u6642\u9593",
+quickStr: "\u5FEB\u901F\u9078\u64C7",
+err_1: '\u6700\u5C0F\u65E5\u671F\u4E0D\u80FD\u5927\u65BC\u6700\u5927\u65E5\u671F!'
+}

+ 2 - 0
src/main/webapp/static/My97DatePicker/skin/WdatePicker.css

@@ -0,0 +1,2 @@
+.Wdate{border:#999 1px solid;height:20px;background:#fff url(datePicker.gif) no-repeat right;}
+.WdateFmtErr{font-weight:bold;color:red;}

BIN
src/main/webapp/static/My97DatePicker/skin/datePicker.gif


+ 246 - 0
src/main/webapp/static/My97DatePicker/skin/default/datepicker.css

@@ -0,0 +1,246 @@
+/* 
+ * My97 DatePicker 4.7
+ */
+
+.WdateDiv{
+	width:180px;
+	background-color:#FFFFFF;
+	border:#bbb 1px solid;
+	padding:2px;
+}
+
+.WdateDiv2{
+	width:360px;
+}
+.WdateDiv *{font-size:9pt;}
+
+.WdateDiv .NavImg a{
+	display:block;
+	cursor:pointer;
+	height:16px;
+	width:16px;
+}
+
+.WdateDiv .NavImgll a{
+	float:left;
+	background:transparent url(img.gif) no-repeat scroll 0 0;
+}
+.WdateDiv .NavImgl a{
+	float:left;
+	background:transparent url(img.gif) no-repeat scroll -16px 0;
+}
+.WdateDiv .NavImgr a{
+	float:right;
+	background:transparent url(img.gif) no-repeat scroll -32px 0;
+}
+.WdateDiv .NavImgrr a{
+	float:right;
+	background:transparent url(img.gif) no-repeat scroll -48px 0;
+}
+
+.WdateDiv #dpTitle{
+	height:24px;
+	margin-bottom:2px;
+	padding:1px;
+}
+
+.WdateDiv .yminput{
+	margin-top:2px;
+	text-align:center;
+	height:20px;
+	border:0px;
+	width:50px;
+	cursor:pointer;		
+}
+
+.WdateDiv .yminputfocus{
+	margin-top:2px;
+	text-align:center;
+	font-weight:bold;
+	height:20px;
+	color:blue;
+	border:#ccc 1px solid;
+	width:50px;
+}
+
+.WdateDiv .menuSel{
+	z-index:1;
+	position:absolute;
+	background-color:#FFFFFF;	
+	border:#ccc 1px solid;
+	display:none;
+}
+
+.WdateDiv .menu{
+	cursor:pointer;
+	background-color:#fff;
+}
+
+.WdateDiv .menuOn{
+	cursor:pointer;
+	background-color:#BEEBEE;
+}
+
+.WdateDiv .invalidMenu{
+	color:#aaa;
+}
+
+.WdateDiv .YMenu{
+	margin-top:20px;
+	
+}
+
+.WdateDiv .MMenu{
+	margin-top:20px;
+	*width:62px;
+}
+
+.WdateDiv .hhMenu{
+	margin-top:-90px; 
+	margin-left:26px;
+}
+
+.WdateDiv .mmMenu{
+	margin-top:-46px; 
+	margin-left:26px;
+}
+
+.WdateDiv .ssMenu{
+	margin-top:-24px; 
+	margin-left:26px;
+}
+
+ .WdateDiv .Wweek {
+ 	text-align:center;
+	background:#DAF3F5;
+	border-right:#BDEBEE 1px solid;
+ }
+
+.WdateDiv .MTitle{
+	background-color:#BDEBEE;
+}
+.WdateDiv .WdayTable2{
+	border-collapse:collapse;
+	border:#c5d9e8 1px solid;
+}
+.WdateDiv .WdayTable2 table{
+	border:0;
+}
+
+.WdateDiv .WdayTable{
+	line-height:20px;
+	border:#c5d9e8 1px solid;
+}
+.WdateDiv .WdayTable td{
+	text-align:center;
+}
+
+.WdateDiv .Wday{
+	cursor:pointer;
+}
+
+.WdateDiv .WdayOn{
+	cursor:pointer;
+	background-color:#C0EBEF;
+}
+
+.WdateDiv .Wwday{
+	cursor:pointer;
+	color:#FF2F2F;
+}
+
+.WdateDiv .WwdayOn{
+	cursor:pointer;
+	color:#000;
+	background-color:#C0EBEF;
+}
+.WdateDiv .Wtoday{
+	cursor:pointer;
+	color:blue;
+}
+.WdateDiv .Wselday{
+	background-color:#A9E4E9;
+}
+.WdateDiv .WspecialDay{
+	background-color:#66F4DF;
+}
+
+.WdateDiv .WotherDay{ 
+	cursor:pointer;
+	color:#6A6AFF;	
+}
+
+.WdateDiv .WotherDayOn{ 
+	cursor:pointer;
+	background-color:#C0EBEF;	
+}
+
+.WdateDiv .WinvalidDay{
+	color:#aaa;
+}
+
+.WdateDiv #dpTime{
+	float:left;
+	margin-top:3px;
+	margin-right:30px;
+}
+
+.WdateDiv #dpTime #dpTimeStr{
+	margin-left:1px;
+}
+
+.WdateDiv #dpTime input{
+	width:18px;
+	height:20px;
+	text-align:center;
+	border:#ccc 1px solid;	
+}
+
+.WdateDiv #dpTime .tB{
+	border-right:0px;
+}
+
+.WdateDiv #dpTime .tE{
+	border-left:0;
+	border-right:0;
+}
+
+.WdateDiv #dpTime .tm{
+	width:7px;
+	border-left:0;
+	border-right:0;
+}
+
+.WdateDiv #dpTime #dpTimeUp{
+	height:10px;
+	width:13px;
+	border:0px;
+	background:url(img.gif) no-repeat -32px -16px;
+}
+
+.WdateDiv #dpTime #dpTimeDown{
+	height:10px;
+	width:13px;
+	border:0px;
+    background:url(img.gif) no-repeat -48px -16px;
+}
+
+ .WdateDiv #dpQS {
+ 	float:left;
+	margin-right:3px;
+	margin-top:3px;
+	background:url(img.gif) no-repeat 0px -16px;
+	width:20px;
+	height:20px;
+	cursor:pointer;
+ }
+.WdateDiv #dpControl {
+	text-align:right;	
+}
+.WdateDiv .dpButton{ 
+	height:20px;
+	width:45px;
+	border:#ccc 1px solid;
+	margin-top:2px;
+	margin-right:1px;
+}

BIN
src/main/webapp/static/My97DatePicker/skin/default/img.gif


Diferenças do arquivo suprimidas por serem muito extensas
+ 1 - 0
src/main/webapp/static/My97DatePicker/skin/twoer/datepicker.css


BIN
src/main/webapp/static/My97DatePicker/skin/twoer/img.gif


BIN
src/main/webapp/static/My97DatePicker/skin/twoer/img.png


BIN
src/main/webapp/static/My97DatePicker/skin/whyGreen/bg.jpg


+ 256 - 0
src/main/webapp/static/My97DatePicker/skin/whyGreen/datepicker.css

@@ -0,0 +1,256 @@
+/* 
+ * My97 DatePicker 4.7 Skin:whyGreen
+ */ 
+.WdateDiv{
+	width:180px;
+	background-color:#fff;
+	border:#C5E1E4 1px solid;
+	padding:2px;
+}
+
+.WdateDiv2{
+	width:360px;
+}
+.WdateDiv *{font-size:9pt;}
+
+.WdateDiv .NavImg a{
+	cursor:pointer;
+	display:block;
+	width:16px;
+	height:16px;
+	margin-top:1px;
+}
+
+.WdateDiv .NavImgll a{
+	float:left;
+	background:url(img.gif) no-repeat;
+}
+.WdateDiv .NavImgl a{
+	float:left;
+	background:url(img.gif) no-repeat -16px 0px;
+}
+.WdateDiv .NavImgr a{
+	float:right;
+	background:url(img.gif) no-repeat -32px 0px;
+}
+.WdateDiv .NavImgrr a{
+	float:right;
+	background:url(img.gif) no-repeat -48px 0px;
+}
+
+.WdateDiv #dpTitle{
+	height:24px;
+	padding:1px;
+	border:#c5d9e8 1px solid;
+	background:url(bg.jpg);
+	margin-bottom:2px;
+}
+
+.WdateDiv .yminput{
+	margin-top:2px;
+	text-align:center;
+	border:0px;
+	height:20px;
+	width:50px;
+	color:#034c50;
+	background-color:transparent;
+	cursor:pointer;
+}
+
+.WdateDiv .yminputfocus{
+	margin-top:2px;
+	text-align:center;
+	border:#939393 1px solid;
+	font-weight:bold;
+	color:#034c50;	
+	height:20px;
+	width:50px;
+}
+
+.WdateDiv .menuSel{
+	z-index:1;
+	position:absolute;
+	background-color:#FFFFFF;
+	border:#A3C6C8 1px solid;
+	display:none;
+}
+
+.WdateDiv .menu{
+	cursor:pointer;
+	background-color:#fff;
+	color:#11777C;
+}
+
+.WdateDiv .menuOn{
+	cursor:pointer;
+	background-color:#BEEBEE;
+}
+
+.WdateDiv .invalidMenu{
+	color:#aaa;
+}
+
+.WdateDiv .YMenu{
+	margin-top:20px;
+}
+
+.WdateDiv .MMenu{
+	margin-top:20px;
+	*width:62px;
+}
+
+.WdateDiv .hhMenu{
+	margin-top:-90px; 
+	margin-left:26px;
+}
+
+.WdateDiv .mmMenu{
+	margin-top:-46px; 
+	margin-left:26px;
+}
+
+.WdateDiv .ssMenu{
+	margin-top:-24px; 
+	margin-left:26px;
+}
+
+ .WdateDiv .Wweek {
+ 	text-align:center;
+	background:#DAF3F5;
+	border-right:#BDEBEE 1px solid;
+ }
+
+.WdateDiv .MTitle{
+	color:#13777e;
+	background-color:#bdebee;
+}
+.WdateDiv .WdayTable2{
+	border-collapse:collapse;
+	border:#BEE9F0 1px solid;
+}
+.WdateDiv .WdayTable2 table{
+	border:0;
+}
+
+.WdateDiv .WdayTable{
+	line-height:20px;	
+	color:#13777e;
+	background-color:#edfbfb;
+	border:#BEE9F0 1px solid;
+}
+.WdateDiv .WdayTable td{
+	text-align:center;
+}
+
+.WdateDiv .Wday{
+	cursor:pointer;
+}
+
+.WdateDiv .WdayOn{
+	cursor:pointer;
+	background-color:#74d2d9 ;
+}
+
+.WdateDiv .Wwday{
+	cursor:pointer;
+	color:#ab1e1e;
+}
+
+.WdateDiv .WwdayOn{
+	cursor:pointer;
+	background-color:#74d2d9;
+}
+.WdateDiv .Wtoday{
+	cursor:pointer;
+	color:blue;
+}
+.WdateDiv .Wselday{
+	background-color:#A7E2E7;
+}
+.WdateDiv .WspecialDay{
+	background-color:#66F4DF;
+}
+
+.WdateDiv .WotherDay{ 
+	cursor:pointer;
+	color:#0099CC;	
+}
+
+.WdateDiv .WotherDayOn{ 
+	cursor:pointer;
+	background-color:#C0EBEF;	
+}
+
+.WdateDiv .WinvalidDay{
+	color:#aaa;
+}
+
+.WdateDiv #dpTime{
+	float:left;
+	margin-top:3px;
+	margin-right:30px;
+}
+
+.WdateDiv #dpTime #dpTimeStr{
+	margin-left:1px;
+	color:#497F7F;
+}
+
+.WdateDiv #dpTime input{
+	height:20px;
+	width:18px;
+	text-align:center;
+	color:#333;
+	border:#61CAD0 1px solid;	
+}
+
+.WdateDiv #dpTime .tB{
+	border-right:0px;
+}
+
+.WdateDiv #dpTime .tE{
+	border-left:0;
+	border-right:0;
+}
+
+.WdateDiv #dpTime .tm{
+	width:7px;
+	border-left:0;
+	border-right:0;
+}
+
+.WdateDiv #dpTime #dpTimeUp{
+	height:10px;
+	width:13px;
+	border:0px;
+	background:url(img.gif) no-repeat -32px -16px;
+}
+
+.WdateDiv #dpTime #dpTimeDown{
+	height:10px;
+	width:13px;
+	border:0px;
+	background:url(img.gif) no-repeat -48px -16px;
+}
+
+ .WdateDiv #dpQS {
+ 	float:left;
+	margin-right:3px;
+	margin-top:3px;
+	background:url(img.gif) no-repeat 0px -16px;
+	width:20px;
+	height:20px;
+	cursor:pointer;
+ }
+.WdateDiv #dpControl {
+	text-align:right;
+	margin-top:3px;
+}
+.WdateDiv .dpButton{ 
+	height:20px;
+	width:45px;
+	margin-top:2px;
+	border:#38B1B9 1px solid;
+	background-color:#CFEBEE;
+	color:#08575B;
+}

BIN
src/main/webapp/static/My97DatePicker/skin/whyGreen/img.gif


+ 165 - 0
src/main/webapp/static/mCustomScrollbar/demo/COPYING.txt

@@ -0,0 +1,165 @@
+                   GNU LESSER GENERAL PUBLIC LICENSE
+                       Version 3, 29 June 2007
+
+ Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+
+  This version of the GNU Lesser General Public License incorporates
+the terms and conditions of version 3 of the GNU General Public
+License, supplemented by the additional permissions listed below.
+
+  0. Additional Definitions.
+
+  As used herein, "this License" refers to version 3 of the GNU Lesser
+General Public License, and the "GNU GPL" refers to version 3 of the GNU
+General Public License.
+
+  "The Library" refers to a covered work governed by this License,
+other than an Application or a Combined Work as defined below.
+
+  An "Application" is any work that makes use of an interface provided
+by the Library, but which is not otherwise based on the Library.
+Defining a subclass of a class defined by the Library is deemed a mode
+of using an interface provided by the Library.
+
+  A "Combined Work" is a work produced by combining or linking an
+Application with the Library.  The particular version of the Library
+with which the Combined Work was made is also called the "Linked
+Version".
+
+  The "Minimal Corresponding Source" for a Combined Work means the
+Corresponding Source for the Combined Work, excluding any source code
+for portions of the Combined Work that, considered in isolation, are
+based on the Application, and not on the Linked Version.
+
+  The "Corresponding Application Code" for a Combined Work means the
+object code and/or source code for the Application, including any data
+and utility programs needed for reproducing the Combined Work from the
+Application, but excluding the System Libraries of the Combined Work.
+
+  1. Exception to Section 3 of the GNU GPL.
+
+  You may convey a covered work under sections 3 and 4 of this License
+without being bound by section 3 of the GNU GPL.
+
+  2. Conveying Modified Versions.
+
+  If you modify a copy of the Library, and, in your modifications, a
+facility refers to a function or data to be supplied by an Application
+that uses the facility (other than as an argument passed when the
+facility is invoked), then you may convey a copy of the modified
+version:
+
+   a) under this License, provided that you make a good faith effort to
+   ensure that, in the event an Application does not supply the
+   function or data, the facility still operates, and performs
+   whatever part of its purpose remains meaningful, or
+
+   b) under the GNU GPL, with none of the additional permissions of
+   this License applicable to that copy.
+
+  3. Object Code Incorporating Material from Library Header Files.
+
+  The object code form of an Application may incorporate material from
+a header file that is part of the Library.  You may convey such object
+code under terms of your choice, provided that, if the incorporated
+material is not limited to numerical parameters, data structure
+layouts and accessors, or small macros, inline functions and templates
+(ten or fewer lines in length), you do both of the following:
+
+   a) Give prominent notice with each copy of the object code that the
+   Library is used in it and that the Library and its use are
+   covered by this License.
+
+   b) Accompany the object code with a copy of the GNU GPL and this license
+   document.
+
+  4. Combined Works.
+
+  You may convey a Combined Work under terms of your choice that,
+taken together, effectively do not restrict modification of the
+portions of the Library contained in the Combined Work and reverse
+engineering for debugging such modifications, if you also do each of
+the following:
+
+   a) Give prominent notice with each copy of the Combined Work that
+   the Library is used in it and that the Library and its use are
+   covered by this License.
+
+   b) Accompany the Combined Work with a copy of the GNU GPL and this license
+   document.
+
+   c) For a Combined Work that displays copyright notices during
+   execution, include the copyright notice for the Library among
+   these notices, as well as a reference directing the user to the
+   copies of the GNU GPL and this license document.
+
+   d) Do one of the following:
+
+       0) Convey the Minimal Corresponding Source under the terms of this
+       License, and the Corresponding Application Code in a form
+       suitable for, and under terms that permit, the user to
+       recombine or relink the Application with a modified version of
+       the Linked Version to produce a modified Combined Work, in the
+       manner specified by section 6 of the GNU GPL for conveying
+       Corresponding Source.
+
+       1) Use a suitable shared library mechanism for linking with the
+       Library.  A suitable mechanism is one that (a) uses at run time
+       a copy of the Library already present on the user's computer
+       system, and (b) will operate properly with a modified version
+       of the Library that is interface-compatible with the Linked
+       Version.
+
+   e) Provide Installation Information, but only if you would otherwise
+   be required to provide such information under section 6 of the
+   GNU GPL, and only to the extent that such information is
+   necessary to install and execute a modified version of the
+   Combined Work produced by recombining or relinking the
+   Application with a modified version of the Linked Version. (If
+   you use option 4d0, the Installation Information must accompany
+   the Minimal Corresponding Source and Corresponding Application
+   Code. If you use option 4d1, you must provide the Installation
+   Information in the manner specified by section 6 of the GNU GPL
+   for conveying Corresponding Source.)
+
+  5. Combined Libraries.
+
+  You may place library facilities that are a work based on the
+Library side by side in a single library together with other library
+facilities that are not Applications and are not covered by this
+License, and convey such a combined library under terms of your
+choice, if you do both of the following:
+
+   a) Accompany the combined library with a copy of the same work based
+   on the Library, uncombined with any other library facilities,
+   conveyed under the terms of this License.
+
+   b) Give prominent notice with the combined library that part of it
+   is a work based on the Library, and explaining where to find the
+   accompanying uncombined form of the same work.
+
+  6. Revised Versions of the GNU Lesser General Public License.
+
+  The Free Software Foundation may publish revised and/or new versions
+of the GNU Lesser General Public License from time to time. Such new
+versions will be similar in spirit to the present version, but may
+differ in detail to address new problems or concerns.
+
+  Each version is given a distinguishing version number. If the
+Library as you received it specifies that a certain numbered version
+of the GNU Lesser General Public License "or any later version"
+applies to it, you have the option of following the terms and
+conditions either of that published version or of any later version
+published by the Free Software Foundation. If the Library as you
+received it does not specify a version number of the GNU Lesser
+General Public License, you may choose any version of the GNU Lesser
+General Public License ever published by the Free Software Foundation.
+
+  If the Library as you received it specifies that a proxy can decide
+whether future versions of the GNU Lesser General Public License shall
+apply, that proxy's public statement of acceptance of any version is
+permanent authorization for you to choose that version for the
+Library.

+ 96 - 0
src/main/webapp/static/mCustomScrollbar/demo/ajax_example.html

@@ -0,0 +1,96 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		h2{font-family:Georgia,serif; font-size:16px; font-style:italic; color:#eee;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.output{margin:20px 40px;}
+		.output a{display:inline-block; text-decoration:none; padding:3px 15px; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px; background:#000; margin:5px 20px 5px 0;}
+		code{color:#5b70ff;}
+		.content{margin:40px; width:340px; height:500px; padding:20px; overflow:auto; background:#333; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+		.loading{opacity:0.3;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>Ajax demo</h1>
+	<p class="output">
+		<a href="demo_files/ajax_content.html" rel="append-content">Append new content</a>
+		<a href="demo_files/ajax_content.html" rel="load-content">Load new content</a>
+	</p>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p><hr /></p>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("#content_1").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					}
+				});
+				//ajax demo fn
+				$("a[rel='load-content']").click(function(e){
+					e.preventDefault();
+					var $this=$(this),
+						url=$this.attr("href");
+					$this.addClass("loading");
+					$.get(url,function(data){
+						$this.removeClass("loading");
+						$("#content_1 .mCSB_container").html(data); //load new content inside .mCSB_container
+						$("#content_1").mCustomScrollbar("update"); //update scrollbar according to newly loaded content
+						$("#content_1").mCustomScrollbar("scrollTo","top",{scrollInertia:200}); //scroll to top
+					});
+				});
+				$("a[rel='append-content']").click(function(e){
+					e.preventDefault();
+					var $this=$(this),
+						url=$this.attr("href");
+					$this.addClass("loading");
+					$.get(url,function(data){
+						$this.removeClass("loading");
+						$("#content_1 .mCSB_container").append(data); //append new content inside .mCSB_container
+						$("#content_1").mCustomScrollbar("update"); //update scrollbar according to newly appended content
+						$("#content_1").mCustomScrollbar("scrollTo","h2:last",{scrollInertia:2500,scrollEasing:"easeInOutQuad"}); //scroll to appended content
+					});
+				});
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

+ 62 - 0
src/main/webapp/static/mCustomScrollbar/demo/auto_hide_scrollbar_demo.html

@@ -0,0 +1,62 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.content{margin:40px; width:260px; height:500px; padding:20px; overflow:auto; background:#333; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>Default scrollbar with scroll buttons</h1>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("#content_1").mCustomScrollbar({
+					autoHideScrollbar:true,
+					theme:"light-thin"
+				});
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

+ 105 - 0
src/main/webapp/static/mCustomScrollbar/demo/auto_scrolling_example.html

@@ -0,0 +1,105 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.output{margin:20px 40px;}
+		.output a{display:inline-block; text-decoration:none; padding:3px 15px; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px; background:#000; margin:5px 20px 5px 0;}
+		code{color:#5b70ff;}
+		.content{margin:40px; width:260px; height:500px; padding:20px; overflow:auto; background:#333; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>Auto-scrolling example</h1>
+	<p class="output">
+		<a href="#" class="auto-scrolling-toggle">Toggle auto-scrolling</a>
+	</p>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				var content=$("#content_1"),autoScrollTimer=8000,autoScrollTimerAdjust,autoScroll;
+				content.mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					},
+					callbacks:{
+						whileScrolling:function(){ autoScrollTimerAdjust=autoScrollTimer*mcs.topPct/100; },
+						onScroll:function(){ if(this.data("mCS_trigger")==="internal"){AutoScrollOff();} }
+					}
+				});
+				content.addClass("auto-scrolling-on auto-scrolling-to-bottom");
+				AutoScrollOn("bottom");
+				$(".auto-scrolling-toggle").click(function(e){
+					e.preventDefault();
+					if(content.hasClass("auto-scrolling-on")){
+						AutoScrollOff();
+					}else{
+						if(content.hasClass("auto-scrolling-to-top")){
+							AutoScrollOn("top",autoScrollTimerAdjust);
+						}else{
+							AutoScrollOn("bottom",autoScrollTimer-autoScrollTimerAdjust);
+						}
+					}
+				});
+				function AutoScrollOn(to,timer){
+					if(!timer){timer=autoScrollTimer;}
+					content.addClass("auto-scrolling-on").mCustomScrollbar("scrollTo",to,{scrollInertia:timer,scrollEasing:"easeInOutQuad"});
+					autoScroll=setTimeout(function(){
+						if(content.hasClass("auto-scrolling-to-top")){
+							AutoScrollOn("bottom",autoScrollTimer-autoScrollTimerAdjust);
+							content.removeClass("auto-scrolling-to-top").addClass("auto-scrolling-to-bottom");
+						}else{
+							AutoScrollOn("top",autoScrollTimerAdjust);
+							content.removeClass("auto-scrolling-to-bottom").addClass("auto-scrolling-to-top");
+						}
+					},timer);
+				}
+				function AutoScrollOff(){
+					clearTimeout(autoScroll);
+					content.removeClass("auto-scrolling-on").mCustomScrollbar("stop");
+				}
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

+ 131 - 0
src/main/webapp/static/mCustomScrollbar/demo/callbacks_example.html

@@ -0,0 +1,131 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.output,.info{margin:20px 40px; background:#111; width:50%; padding:0 21px 0 19px; overflow:hidden; -webkit-border-radius:5px; -moz-border-radius:5px; border-radius:5px;}
+		.output a{text-decoration:none; position:relative; display:inline-block; padding-left:19px; margin:5px 40px 5px 0;}
+		.output a.hidden{opacity:0.3;}
+		.output span{position:absolute; width:14px; height:14px; left:0; top:3px; display:none; border-radius:14px;}
+		.output span.onScrollStart{background:#b0ef0a;}
+		.output span.onTotalScrollBack{background:#f0df09;}
+		.output span.onTotalScroll{background:#f08209;}
+		.output span.onScroll{background:#0bbbee;}
+		.output span.whileScrolling{background:#930bee;}
+		.output span.hidden{visibility:hidden;}
+		.info{padding:0; background:transparent; color:#999;}
+		.info .content-position,.info .dragger-position,.info .scroll-pct{color:#eee; display:inline-block; min-width:40px; margin-right:20px;}
+		code{color:#5b70ff;}
+		.total-scroll-offset-cb{color:#f08209;}
+		.total-scroll-back-offset-cb{color:#f0df09;}
+		.content{margin:40px; width:50%; height:340px; padding:20px; overflow:auto; background:#333; -webkit-border-radius:5px; -moz-border-radius:5px; border-radius:5px;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>jQuery custom scrollbar callbacks demo</h1>
+	<p class="output">
+		<a href="#" rel="onScrollStart"><span class="onScrollStart">&nbsp;</span>onScrollStart</a>
+		<a href="#" rel="onScroll"><span class="onScroll">&nbsp;</span>onScroll</a>
+		<a href="#" rel="onTotalScroll"><span class="onTotalScroll">&nbsp;</span>onTotalScroll</a>
+		<a href="#" rel="onTotalScrollBack"><span class="onTotalScrollBack">&nbsp;</span>onTotalScrollBack</a>
+		<a href="#" rel="whileScrolling"><span class="whileScrolling">&nbsp;</span>whileScrolling</a>
+	</p>
+	<p class="info">
+		Content position: <span class="content-position"></span> Dragger position: <span class="dragger-position"></span> Scroll percentage: <span class="scroll-pct"></span><br /> 
+		<code>mcs.top</code> returns content top position (<code>mcs.left</code> for left position). <code>mcs.draggerTop</code> returns dragger top position (<code>mcs.draggerLeft</code> for left position). <code>mcs.topPct</code> returns vertical scroll percentage (<code>mcs.leftPct</code> for horizontal).<br />
+		<code>onTotalScrollOffset</code> is set to <span class="total-scroll-offset"></span> (<span class="total-scroll-offset-cb">callback</span> will fire <span class="total-scroll-offset"></span> pixels from bottom). <code>onTotalScrollBackOffset</code> is set to <span class="total-scroll-back-offset"></span> (<span class="total-scroll-back-offset-cb">callback</span> will fire <span class="total-scroll-back-offset"></span> pixels from top). 
+	</p>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>the end.</p>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("#content_1").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					},
+					callbacks:{
+						onScrollStart:function(){ OnScrollStart(); },
+						onScroll:function(){ OnScroll(); },
+						onTotalScroll:function(){ OnTotalScroll(); },
+						onTotalScrollBack:function(){ OnTotalScrollBack(); },
+						onTotalScrollOffset:40,
+						onTotalScrollBackOffset:20,
+						whileScrolling:function(){ WhileScrolling(); } 
+					}
+				});
+				function OnScrollStart(){
+					$(".output .onScrollStart").stop(true,true).css("display","inline-block").delay(500).fadeOut(500);
+				}
+				function OnScroll(){
+					$(".output .onScroll").stop(true,true).css("display","inline-block").delay(500).fadeOut(500);
+				}
+				function OnTotalScroll(){
+					$(".output .onTotalScroll").stop(true,true).css("display","inline-block").delay(500).fadeOut(500);
+				}
+				function OnTotalScrollBack(){
+					$(".output .onTotalScrollBack").stop(true,true).css("display","inline-block").delay(500).fadeOut(500);
+				}
+				function WhileScrolling(){
+					$(".output .whileScrolling").stop(true,true).css("display","inline-block").fadeOut(500);
+					$(".info .content-position").text(mcs.top);
+					$(".info .dragger-position").text(mcs.draggerTop);
+					$(".info .scroll-pct").text(mcs.topPct+"%");
+				}
+				$(".total-scroll-offset").text($("#content_1").data("onTotalScroll_Offset"));
+				$(".total-scroll-back-offset").text($("#content_1").data("onTotalScrollBack_Offset"));
+				$(".output a").click(function(e){
+					e.preventDefault();
+					var $this=$(this),
+						rel=$this.attr("rel"),
+						target=$this.parent().find("."+rel);
+					target.add($this).toggleClass("hidden");
+				});
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

Diferenças do arquivo suprimidas por serem muito extensas
+ 384 - 0
src/main/webapp/static/mCustomScrollbar/demo/complete_examples.html


+ 6 - 0
src/main/webapp/static/mCustomScrollbar/demo/demo_files/ajax_content.html

@@ -0,0 +1,6 @@
+<h2>New content</h2>
+<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+<p><hr /></p>

+ 559 - 0
src/main/webapp/static/mCustomScrollbar/demo/demo_files/jquery.mCustomScrollbar.css

@@ -0,0 +1,559 @@
+/* basic scrollbar styling */
+/* vertical scrollbar */
+.mCSB_container{
+	width:auto;
+	margin-right:30px;
+	overflow:hidden;
+}
+.mCSB_container.mCS_no_scrollbar{
+	margin-right:0;
+}
+.mCS_disabled>.mCustomScrollBox>.mCSB_container.mCS_no_scrollbar,
+.mCS_destroyed>.mCustomScrollBox>.mCSB_container.mCS_no_scrollbar{
+	margin-right:30px;
+}
+.mCustomScrollBox>.mCSB_scrollTools{
+	width:16px;
+	height:100%;
+	top:0;
+	right:0;
+}
+.mCSB_scrollTools .mCSB_draggerContainer{
+	position:absolute;
+	top:0;
+	left:0;
+	bottom:0;
+	right:0; 
+	height:auto;
+}
+.mCSB_scrollTools a+.mCSB_draggerContainer{
+	margin:20px 0;
+}
+.mCSB_scrollTools .mCSB_draggerRail{
+	width:2px;
+	height:100%;
+	margin:0 auto;
+	-webkit-border-radius:10px;
+	-moz-border-radius:10px;
+	border-radius:10px;
+}
+.mCSB_scrollTools .mCSB_dragger{
+	cursor:pointer;
+	width:100%;
+	height:30px;
+}
+.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:4px;
+	height:100%;
+	margin:0 auto;
+	-webkit-border-radius:10px;
+	-moz-border-radius:10px;
+	border-radius:10px;
+	text-align:center;
+}
+.mCSB_scrollTools .mCSB_buttonUp,
+.mCSB_scrollTools .mCSB_buttonDown{
+	display:block;
+	position:relative;
+	height:20px;
+	overflow:hidden;
+	margin:0 auto;
+	cursor:pointer;
+}
+.mCSB_scrollTools .mCSB_buttonDown{
+	top:100%;
+	margin-top:-40px;
+}
+/* horizontal scrollbar */
+.mCSB_horizontal>.mCSB_container{
+	height:auto;
+	margin-right:0;
+	margin-bottom:30px;
+	overflow:hidden;
+}
+.mCSB_horizontal>.mCSB_container.mCS_no_scrollbar{
+	margin-bottom:0;
+}
+.mCS_disabled>.mCSB_horizontal>.mCSB_container.mCS_no_scrollbar,
+.mCS_destroyed>.mCSB_horizontal>.mCSB_container.mCS_no_scrollbar{
+	margin-right:0;
+	margin-bottom:30px;
+}
+.mCSB_horizontal.mCustomScrollBox>.mCSB_scrollTools{
+	width:100%;
+	height:16px;
+	top:auto;
+	right:auto;
+	bottom:0;
+	left:0;
+	overflow:hidden;
+}
+.mCSB_horizontal>.mCSB_scrollTools a+.mCSB_draggerContainer{
+	margin:0 20px;
+}
+.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
+	width:100%;
+	height:2px;
+	margin:7px 0;
+	-webkit-border-radius:10px;
+	-moz-border-radius:10px;
+	border-radius:10px;
+}
+.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger{
+	width:30px;
+	height:100%;
+}
+.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:100%;
+	height:4px;
+	margin:6px auto;
+	-webkit-border-radius:10px;
+	-moz-border-radius:10px;
+	border-radius:10px;
+}
+.mCSB_horizontal>.mCSB_scrollTools .mCSB_buttonLeft,
+.mCSB_horizontal>.mCSB_scrollTools .mCSB_buttonRight{
+	display:block;
+	position:relative;
+	width:20px;
+	height:100%;
+	overflow:hidden;
+	margin:0 auto;
+	cursor:pointer;
+	float:left;
+}
+.mCSB_horizontal>.mCSB_scrollTools .mCSB_buttonRight{
+	margin-left:-40px;
+	float:right;
+}
+.mCustomScrollBox{
+	-ms-touch-action:none; /*MSPointer events - direct all pointer events to js*/
+}
+
+/* default scrollbar colors and backgrounds (default theme) */
+.mCustomScrollBox>.mCSB_scrollTools{
+	opacity:0.75;
+	filter:"alpha(opacity=75)"; -ms-filter:"alpha(opacity=75)"; /* old ie */
+}
+.mCustomScrollBox:hover>.mCSB_scrollTools{
+	opacity:1;
+	filter:"alpha(opacity=100)"; -ms-filter:"alpha(opacity=100)"; /* old ie */
+}
+.mCSB_scrollTools .mCSB_draggerRail{
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.4);
+	filter:"alpha(opacity=40)"; -ms-filter:"alpha(opacity=40)"; /* old ie */
+}
+.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	background:#fff; /* rgba fallback */
+	background:rgba(255,255,255,0.75);
+	filter:"alpha(opacity=75)"; -ms-filter:"alpha(opacity=75)"; /* old ie */
+}
+.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
+	background:rgba(255,255,255,0.85);
+	filter:"alpha(opacity=85)"; -ms-filter:"alpha(opacity=85)"; /* old ie */
+}
+.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:rgba(255,255,255,0.9);
+	filter:"alpha(opacity=90)"; -ms-filter:"alpha(opacity=90)"; /* old ie */
+}
+.mCSB_scrollTools .mCSB_buttonUp,
+.mCSB_scrollTools .mCSB_buttonDown,
+.mCSB_scrollTools .mCSB_buttonLeft,
+.mCSB_scrollTools .mCSB_buttonRight{
+	background-image:url(../mCSB_buttons.png);
+	background-repeat:no-repeat;
+	opacity:0.4;
+	filter:"alpha(opacity=40)"; -ms-filter:"alpha(opacity=40)"; /* old ie */
+}
+.mCSB_scrollTools .mCSB_buttonUp{
+	background-position:0 0;
+	/* 
+	sprites locations are 0 0/-16px 0/-32px 0/-48px 0 (light) and -80px 0/-96px 0/-112px 0/-128px 0 (dark) 
+	*/
+}
+.mCSB_scrollTools .mCSB_buttonDown{
+	background-position:0 -20px;
+	/* 
+	sprites locations are 0 -20px/-16px -20px/-32px -20px/-48px -20px (light) and -80px -20px/-96px -20px/-112px -20px/-128px -20px (dark) 
+	*/
+}
+.mCSB_scrollTools .mCSB_buttonLeft{
+	background-position:0 -40px;
+	/* 
+	sprites locations are 0 -40px/-20px -40px/-40px -40px/-60px -40px (light) and -80px -40px/-100px -40px/-120px -40px/-140px -40px (dark) 
+	*/
+}
+.mCSB_scrollTools .mCSB_buttonRight{
+	background-position:0 -56px;
+	/* 
+	sprites locations are 0 -56px/-20px -56px/-40px -56px/-60px -56px (light) and -80px -56px/-100px -56px/-120px -56px/-140px -56px (dark) 
+	*/
+}
+.mCSB_scrollTools .mCSB_buttonUp:hover,
+.mCSB_scrollTools .mCSB_buttonDown:hover,
+.mCSB_scrollTools .mCSB_buttonLeft:hover,
+.mCSB_scrollTools .mCSB_buttonRight:hover{
+	opacity:0.75;
+	filter:"alpha(opacity=75)"; -ms-filter:"alpha(opacity=75)"; /* old ie */
+}
+.mCSB_scrollTools .mCSB_buttonUp:active,
+.mCSB_scrollTools .mCSB_buttonDown:active,
+.mCSB_scrollTools .mCSB_buttonLeft:active,
+.mCSB_scrollTools .mCSB_buttonRight:active{
+	opacity:0.9;
+	filter:"alpha(opacity=90)"; -ms-filter:"alpha(opacity=90)"; /* old ie */
+}
+
+/*scrollbar themes*/
+/*dark (dark colored scrollbar)*/
+.mCS-dark>.mCSB_scrollTools .mCSB_draggerRail{
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.15);
+}
+.mCS-dark>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.75);
+}
+.mCS-dark>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.85);
+}
+.mCS-dark>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.mCS-dark>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.9);
+}
+.mCS-dark>.mCSB_scrollTools .mCSB_buttonUp{
+	background-position:-80px 0;
+}
+.mCS-dark>.mCSB_scrollTools .mCSB_buttonDown{
+	background-position:-80px -20px;
+}
+.mCS-dark>.mCSB_scrollTools .mCSB_buttonLeft{
+	background-position:-80px -40px;
+}
+.mCS-dark>.mCSB_scrollTools .mCSB_buttonRight{
+	background-position:-80px -56px;
+}
+/*light-2*/
+.mCS-light-2>.mCSB_scrollTools .mCSB_draggerRail{
+	width:4px;
+	background:#fff; /* rgba fallback */
+	background:rgba(255,255,255,0.1);
+	-webkit-border-radius:1px;
+	-moz-border-radius:1px;
+	border-radius:1px;
+}
+.mCS-light-2>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:4px;
+	background:#fff; /* rgba fallback */
+	background:rgba(255,255,255,0.75);
+	-webkit-border-radius:1px;
+	-moz-border-radius:1px;
+	border-radius:1px;
+}
+.mCS-light-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
+	width:100%;
+	height:4px;
+	margin:6px 0;
+}
+.mCS-light-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:100%;
+	height:4px;
+	margin:6px auto;
+}
+.mCS-light-2>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
+	background:rgba(255,255,255,0.85);
+}
+.mCS-light-2>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.mCS-light-2>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:rgba(255,255,255,0.9);
+}
+.mCS-light-2>.mCSB_scrollTools .mCSB_buttonUp{
+	background-position:-32px 0;
+}
+.mCS-light-2>.mCSB_scrollTools .mCSB_buttonDown{
+	background-position:-32px -20px;
+}
+.mCS-light-2>.mCSB_scrollTools .mCSB_buttonLeft{
+	background-position:-40px -40px;
+}
+.mCS-light-2>.mCSB_scrollTools .mCSB_buttonRight{
+	background-position:-40px -56px;
+}
+/*dark-2*/
+.mCS-dark-2>.mCSB_scrollTools .mCSB_draggerRail{
+	width:4px;
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.1);
+	-webkit-border-radius:1px;
+	-moz-border-radius:1px;
+	border-radius:1px;
+}
+.mCS-dark-2>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:4px;
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.75);
+	-webkit-border-radius:1px;
+	-moz-border-radius:1px;
+	border-radius:1px;
+}
+.mCS-dark-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
+	width:100%;
+	height:4px;
+	margin:6px 0;
+}
+.mCS-dark-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:100%;
+	height:4px;
+	margin:6px auto;
+}
+.mCS-dark-2>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.85);
+}
+.mCS-dark-2>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.mCS-dark-2>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.9);
+}
+.mCS-dark-2>.mCSB_scrollTools .mCSB_buttonUp{
+	background-position:-112px 0;
+}
+.mCS-dark-2>.mCSB_scrollTools .mCSB_buttonDown{
+	background-position:-112px -20px;
+}
+.mCS-dark-2>.mCSB_scrollTools .mCSB_buttonLeft{
+	background-position:-120px -40px;
+}
+.mCS-dark-2>.mCSB_scrollTools .mCSB_buttonRight{
+	background-position:-120px -56px;
+}
+/*light-thick*/
+.mCS-light-thick>.mCSB_scrollTools .mCSB_draggerRail{
+	width:4px;
+	background:#fff; /* rgba fallback */
+	background:rgba(255,255,255,0.1);
+	-webkit-border-radius:2px;
+	-moz-border-radius:2px;
+	border-radius:2px;
+}
+.mCS-light-thick>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:6px;
+	background:#fff; /* rgba fallback */
+	background:rgba(255,255,255,0.75);
+	-webkit-border-radius:2px;
+	-moz-border-radius:2px;
+	border-radius:2px;
+}
+.mCS-light-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
+	width:100%;
+	height:4px;
+	margin:6px 0;
+}
+.mCS-light-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:100%;
+	height:6px;
+	margin:5px auto;
+}
+.mCS-light-thick>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
+	background:rgba(255,255,255,0.85);
+}
+.mCS-light-thick>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.mCS-light-thick>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:rgba(255,255,255,0.9);
+}
+.mCS-light-thick>.mCSB_scrollTools .mCSB_buttonUp{
+	background-position:-16px 0;
+}
+.mCS-light-thick>.mCSB_scrollTools .mCSB_buttonDown{
+	background-position:-16px -20px;
+}
+.mCS-light-thick>.mCSB_scrollTools .mCSB_buttonLeft{
+	background-position:-20px -40px;
+}
+.mCS-light-thick>.mCSB_scrollTools .mCSB_buttonRight{
+	background-position:-20px -56px;
+}
+/*dark-thick*/
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_draggerRail{
+	width:4px;
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.1);
+	-webkit-border-radius:2px;
+	-moz-border-radius:2px;
+	border-radius:2px;
+}
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:6px;
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.75);
+	-webkit-border-radius:2px;
+	-moz-border-radius:2px;
+	border-radius:2px;
+}
+.mCS-dark-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
+	width:100%;
+	height:4px;
+	margin:6px 0;
+}
+.mCS-dark-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:100%;
+	height:6px;
+	margin:5px auto;
+}
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.85);
+}
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.9);
+}
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonUp{
+	background-position:-96px 0;
+}
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonDown{
+	background-position:-96px -20px;
+}
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonLeft{
+	background-position:-100px -40px;
+}
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonRight{
+	background-position:-100px -56px;
+}
+/*light-thin*/
+.mCS-light-thin>.mCSB_scrollTools .mCSB_draggerRail{
+	background:#fff; /* rgba fallback */
+	background:rgba(255,255,255,0.1);
+}
+.mCS-light-thin>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:2px;
+}
+.mCS-light-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
+	width:100%;
+}
+.mCS-light-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:100%;
+	height:2px;
+	margin:7px auto;
+}
+/*dark-thin*/
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_draggerRail{
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.15);
+}
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:2px;
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.75);
+}
+.mCS-dark-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
+	width:100%;
+}
+.mCS-dark-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:100%;
+	height:2px;
+	margin:7px auto;
+}
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.85);
+}
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.9);
+}
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonUp{
+	background-position:-80px 0;
+}
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonDown{
+	background-position:-80px -20px;
+}
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonLeft{
+	background-position:-80px -40px;
+}
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonRight{
+	background-position:-80px -56px;
+}
+
+/* custom styling */
+/* content_1 scrollbar */
+.content_1>.mCustomScrollBox>.mCSB_scrollTools{
+	height:96%;
+	top:2%;
+}
+/* content_2 scrollbar */
+.content_2 .mCSB_scrollTools .mCSB_draggerRail{
+	width:6px;
+	box-shadow:1px 1px 1px rgba(255,255,255,0.1);
+}
+.content_2 .mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	background:rgba(255,255,255,0.4);
+	filter:"alpha(opacity=40)"; -ms-filter:"alpha(opacity=40)"; /* old ie */
+}
+.content_2 .mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
+	background:rgba(255,255,255,0.5);
+	filter:"alpha(opacity=50)"; -ms-filter:"alpha(opacity=50)"; /* old ie */
+}
+.content_2 .mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.content_2 .mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:rgba(255,255,255,0.6);
+	filter:"alpha(opacity=60)"; -ms-filter:"alpha(opacity=60)"; /* old ie */
+}
+/* content_3 scrollbar */
+.content_3>.mCustomScrollBox>.mCSB_scrollTools{
+	height:94%;
+	top:3%;
+}
+.content_3 .mCSB_scrollTools .mCSB_draggerRail{
+	width:0;
+	border-right:1px dashed #09C;
+}
+.content_3 .mCSB_scrollTools .mCSB_dragger{
+	height:11px;
+}
+.content_3 .mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:11px;
+	-webkit-border-radius:11px;
+	-moz-border-radius:11px;
+	border-radius:11px;
+	background:#09C;
+}
+/* content_4 scrollbar */
+.content_4>.mCustomScrollBox>.mCSB_scrollTools{
+	height:94%;
+	top:3%;
+}
+.content_4 .mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:8px;
+	-webkit-border-radius:2px;
+	-moz-border-radius:2px;
+	border-radius:2px;
+	background:#d0b9a0;
+	-webkit-box-shadow:1px 1px 5px rgba(0,0,0,0.5);
+	-moz-box-shadow:1px 1px 5px rgba(0,0,0,0.5);
+	box-shadow:1px 1px 5px rgba(0,0,0,0.5);
+}
+.content_4 .mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar,
+.content_4 .mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:#dfcdb9;
+}
+.content_4 .mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.content_4 .mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	-webkit-box-shadow:0 0 3px rgba(0,0,0,0.5);
+	-moz-box-shadow:0 0 3px rgba(0,0,0,0.5);
+	box-shadow:0 0 3px rgba(0,0,0,0.5);
+}
+/* content_5 scrollbar */
+.content_5>.mCustomScrollBox>.mCSB_scrollTools{
+	width: 98%;
+	margin: 0 1%;
+}
+/* content_6 scrollbar */
+.content_6>.mCustomScrollBox>.mCSB_scrollTools{
+	width:88%;
+	margin: 0 6%;
+}
+/* content_8 scrollbar */
+.content_8 .mCSB_scrollTools .mCSB_draggerRail{
+	width:0px;
+	border-left:1px solid rgba(0,0,0,0.8);
+	border-right:1px solid rgba(255,255,255,0.2);
+}

BIN
src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsImg1.jpg


BIN
src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsImg2.jpg


BIN
src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb1.jpg


BIN
src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb2.jpg


BIN
src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb3.jpg


BIN
src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb4.jpg


BIN
src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb5.jpg


BIN
src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb6.jpg


BIN
src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb7.jpg


BIN
src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcsThumb8.jpg


BIN
src/main/webapp/static/mCustomScrollbar/demo/demo_files/mcs_demo_bg.jpg


+ 105 - 0
src/main/webapp/static/mCustomScrollbar/demo/disable_destroy_example.html

@@ -0,0 +1,105 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.output{margin:20px 40px;}
+		.output a{display:inline-block; text-decoration:none; padding:3px 15px; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px; background:#000; margin:5px 20px 5px 0;}
+		code{color:#5b70ff;}
+		.content{margin:40px; width:60%; height:500px; padding:20px; overflow:auto; background:#333; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+		.content input{border:none; background:#222; -webkit-border-radius:5px; -moz-border-radius:5px; border-radius:5px; width:35%; height:30px; margin:10px 10px 20px 0; padding:0 10px; color:#c96;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>disable &amp; destroy methods example</h1>
+	<p class="output">
+		<a href="#" id="disable-scrollbar">Disable scrollbar</a>
+		<a href="#" id="disable-scrollbar-no-reset">Disable scrollbar without reseting content position</a>
+		<a href="#" id="enable-scrollbar">Enable scrollbar</a>
+		<a href="#" id="destroy-scrollbar">Destroy scrollbar</a>
+		<a href="#" id="rebuild-scrollbar">Rebuild scrollbar</a>
+	</p>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+		<form><input type="text" name="tf1" value="Textfield 1" /></form>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+		<form><input type="text" name="tf2" value="Textfield 2" /></form>
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+		<p>Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+    	<p>the end.</p>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$(".content").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					}
+				});
+				/* disable */
+				$("#disable-scrollbar").click(function(e){
+					e.preventDefault();
+					$("#content_1").mCustomScrollbar("disable",true);
+				});
+				$("#disable-scrollbar-no-reset").click(function(e){
+					e.preventDefault();
+					$("#content_1").mCustomScrollbar("disable");
+				});
+				$("#enable-scrollbar").click(function(e){
+					e.preventDefault();
+					$("#content_1").mCustomScrollbar("update");
+				});
+				/* destroy */
+				$("#destroy-scrollbar").click(function(e){
+					e.preventDefault();
+					$("#content_1").mCustomScrollbar("destroy");
+				});
+				$("#rebuild-scrollbar").click(function(e){
+					e.preventDefault();
+					$("#content_1").mCustomScrollbar({
+						scrollButtons:{
+							enable:true
+						}
+					});
+				});
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

+ 71 - 0
src/main/webapp/static/mCustomScrollbar/demo/fluid_scrollbar_example.html

@@ -0,0 +1,71 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		html,body{height:100%;}
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.content{position:relative; margin:40px auto; width:100%; height:65%; padding:20px 40px; overflow:auto; background:#333; -webkit-box-sizing:border-box; -moz-box-sizing:border-box; box-sizing:border-box;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>Fluid content example</h1>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<p><strong>Resize browser to test</strong></p>
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+		<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+    	<p>the end.</p>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("#content_1").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					}
+				});
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

+ 83 - 0
src/main/webapp/static/mCustomScrollbar/demo/full_page_demo.html

@@ -0,0 +1,83 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		html,body{height:100%;}
+		body{margin:0; padding:0 20px; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px; overflow:auto;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px 40px 40px 0; color:#26beff;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px 9px 0; clear:both;}
+		.links{margin:10px 10px 10px 0;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.content{margin:40px 40px 40px 0; width:60%; height:300px; padding:20px; overflow:auto; background:#333; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+		/*body custom scrollbar style*/
+		body>.mCustomScrollBox>.mCSB_scrollTools{top:2%; height:96%;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>Default scrollbar with scroll buttons</h1>
+	<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+	<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+	<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+	<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+	<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+	<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+	<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+	<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+	<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+	<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+	<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+	<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+	<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+<p>the end.</p>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("body,.content").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					}
+				});
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

+ 114 - 0
src/main/webapp/static/mCustomScrollbar/demo/grid_and_snap_while_scrolling_example.html

@@ -0,0 +1,114 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+  <meta charset="utf-8">
+  <meta name="viewport" content="width=device-width, initial-scale=1.0">
+  <title>jQuery custom scrollbar demo</title>
+  <!-- style for demo and examples -->
+  <style>
+    body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+    a:link,a:visited,a:hover{color:inherit;}
+    h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+    p{margin:0 0 20px 0;}
+    hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+    .links{margin:10px;}
+    .links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+    .links a:hover{background:#eb3755; color:#fff;}
+    .output{margin:20px 40px;}
+    code{color:#5b70ff;}
+    a[rel='toggle-buttons-scroll-type']{display:inline-block; text-decoration:none; padding:3px 15px; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px; background:#000; margin:5px 20px 5px 0;}
+    .content{margin:40px; width:910px; height:500px; overflow:hidden;}
+    #content_1{width:910px;height:480px;}
+    .grid{table-layout:fixed;border-collapse:separate;border-style:none;border-spacing:0;width:0;}
+    .grid th {overflow: hidden;white-space: nowrap;padding: 0;text-align: center;vertical-align: middle;width: 90px;max-width: 90px;font-size: 11px;border: 1px solid #cbcbcb;border-width: 0 1px 1px 0;background-color: #f3f3f3;color: #222;}
+    .grid td {overflow: hidden;white-space: nowrap;width: 90px;max-width: 90px;height: 16px;line-height: 16px;font-size: 13px;border: 1px solid #cbcbcb;border-width: 0 1px 1px 0;text-align: right;vertical-align: middle;padding: 1px 2px;background-color: #fff;color: #000;}
+    .grid th:first-child, .grid td:first-child {width: 148px;text-align: left;background-color: #f3f3f3;color: #222;padding-left: 4px;}
+  </style>
+  <!-- Custom scrollbars CSS -->
+  <link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+  <p class="links">
+    <a href="http://manos.malihu.gr">malihu</a>
+    <a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+    <a href="complete_examples.html">Plugin demo</a>
+  </p>
+  <hr />
+  <h1>Example of snapping to a grid while scrolling</h1>
+  <!-- content block -->
+  <div class="content">
+    <table class="grid">
+      <thead>
+        <tr>
+          <th>A</th>
+          <th>B</th>
+          <th>C</th>
+          <th>D</th>
+          <th>E</th>
+          <th>F</th>
+          <th>G</th>
+          <th>H</th>
+          <th>I</th>
+        </tr>
+      </thead>
+    </table>
+    <div id="content_1">
+      <table id="grid" class="grid">
+        <thead>
+          <tr class="shim">
+            <th></th>
+            <th></th>
+            <th></th>
+            <th></th>
+            <th></th>
+            <th></th>
+            <th></th>
+            <th></th>
+            <th></th>
+          </tr>
+        </thead>
+        <tbody>
+        </tbody>
+      </table>
+    </div>
+  </div>
+  <hr />
+  <p>&nbsp;</p>
+  <!-- Google CDN jQuery with fallback to local -->
+  <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+  <script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+  <!-- custom scrollbars plugin -->
+  <script src="jquery.mCustomScrollbar.js"></script>
+  <script>
+    (function($){
+      $(window).load(function(){
+        var $grid_body = $('#grid tbody'), html;
+        for (var i = 0; i < 100; i++) {
+          var label = String.fromCharCode("A".charCodeAt(0) + (i / 26) | 0) +
+                      String.fromCharCode("A".charCodeAt(0) + (i % 26));
+          html = "<tr><td>" + label + "</td>";
+          for (var j = 0; j < 9; j++) {
+            html += "<td>" + Math.round(Math.random() * 100) + "</td>";
+          }
+          html += "</tr>";
+          $grid_body.append(html);
+        }
+
+        $("#content_1").mCustomScrollbar({
+          theme:"light",
+          scrollInertia:0,
+          mouseWheelPixels:19,
+          snapAmount:19,
+          snapOffset: 1,
+          scrollButtons:{
+            enable:true,
+            scrollType:"pixels",
+            scrollAmount:19
+          },
+        });
+
+      });
+    })(jQuery);
+  </script>
+</body>
+</html>

+ 62 - 0
src/main/webapp/static/mCustomScrollbar/demo/iframe_example.html

@@ -0,0 +1,62 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		h2{font-family:Georgia,serif; font-size:16px; font-style:italic; color:#eee;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.content{margin:40px; width:1040px; height:500px; overflow:auto;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+	<!-- fun stuff: styling the scrollbar to match iframe content -->
+	<style>
+		.mCSB_scrollTools .mCSB_draggerRail{width:6px; background:#000; -webkit-border-radius:0; -moz-border-radius:0; border-radius:0;}
+		.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:6px; background:#d03428; -webkit-border-radius:0; -moz-border-radius:0; border-radius:0;}
+		.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar,
+		.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+		.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{background:#fcea6a;}
+	</style>
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>iframe demo</h1>
+	<!-- content block -->
+	<div class="content">
+		<iframe src="http://slipsum.com/" scrolling="no" width="100%" height="1000" frameborder="0">
+			<p>Your browser does not support iframes.</p>
+		</iframe>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$(".content").mCustomScrollbar();
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

+ 85 - 0
src/main/webapp/static/mCustomScrollbar/demo/infinite_scroll_example.html

@@ -0,0 +1,85 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		h2{font-family:Georgia,serif; font-size:16px; font-style:italic; color:#eee;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.output{margin:20px 40px;}
+		.output a{display:inline-block; text-decoration:none; padding:3px 15px; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px; background:#000; margin:5px 20px 5px 0;}
+		code{color:#5b70ff;}
+		.content{position:relative; margin:40px auto; width:100%; height:400px; padding:20px 40px; overflow:auto; background:#333; -webkit-box-sizing:border-box; -moz-box-sizing:border-box; box-sizing:border-box; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px;}
+		.content p:nth-child(even){color:#9dbfc6; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+		.content#content_2{width:400px; margin:40px;}
+		.totalScrollOffsetInfo{border:2px solid #fc0; font-size:12px; padding:20px; text-align:center; margin-bottom:60px;}
+		.totalScrollOffset{height:50px; background:#fc0;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>Infinite scroll example</h1>
+	<p class="output"><a id="scroll_to_bottom" href="#">Scroll to bottom</a></p>
+	<!-- content block -->
+	<div id="content_2" class="content">
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+    	<p>the end.</p>
+		<div class="totalScrollOffsetInfo">Yellow box below indicates total scroll offset area</div>
+		<div class="totalScrollOffset"></div>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				var totalScrollOffsetH=$(".totalScrollOffset").height();
+				$("#content_2").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					},
+					callbacks:{
+						onTotalScroll:function(){
+							appendTextOnTotalScroll();
+						},
+						onTotalScrollOffset:totalScrollOffsetH
+					}
+				});
+				$("#scroll_to_bottom").click(function(e){
+					e.preventDefault();
+					$("#content_2").mCustomScrollbar("scrollTo","bottom");
+				});
+				function appendTextOnTotalScroll(){
+					var c=$("#content_2").find(".mCSB_container p:last");
+					var h="<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat. <strong>Appended text end.</strong></p>";
+					c.after(h);
+					$("#content_2").mCustomScrollbar("update");
+				}
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

+ 74 - 0
src/main/webapp/static/mCustomScrollbar/demo/init_hidden_example.html

@@ -0,0 +1,74 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		h2{font-family:Georgia,serif; font-size:16px; font-style:italic; color:#eee;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.output{margin:20px 40px;}
+		.output a{display:inline-block; text-decoration:none; padding:3px 15px; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px; background:#000; margin:5px 20px 5px 0;}
+		code{color:#5b70ff;}
+		.content{margin:40px; width:260px; height:500px; padding:20px; overflow:hidden; background:#333;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+		#content_1{display:none;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>Initially hidden content block</h1>
+	<p class="output"><a href="#" rel="show-content">show/hide</a></p>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("#content_1").mCustomScrollbar();
+				//demo fn
+				$("a[rel='show-content']").click(function(e){
+					e.preventDefault();
+					$("#content_1").fadeToggle("slow",function(){
+						var customScrollbar=$("#content_1").find(".mCSB_scrollTools");
+						customScrollbar.css({"opacity":0});
+						$("#content_1").mCustomScrollbar("update");
+						customScrollbar.animate({opacity:1},"slow");
+					});
+				});
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

Diferenças do arquivo suprimidas por serem muito extensas
+ 4 - 0
src/main/webapp/static/mCustomScrollbar/demo/jquery.mCustomScrollbar.concat.min.js


+ 474 - 0
src/main/webapp/static/mCustomScrollbar/demo/jquery.mCustomScrollbar.css

@@ -0,0 +1,474 @@
+/* basic scrollbar styling */
+/* vertical scrollbar */
+.mCSB_container{
+	width:auto;
+	margin-right:30px;
+	overflow:hidden;
+}
+.mCSB_container.mCS_no_scrollbar{
+	margin-right:0;
+}
+.mCS_disabled>.mCustomScrollBox>.mCSB_container.mCS_no_scrollbar,
+.mCS_destroyed>.mCustomScrollBox>.mCSB_container.mCS_no_scrollbar{
+	margin-right:30px;
+}
+.mCustomScrollBox>.mCSB_scrollTools{
+	width:16px;
+	height:100%;
+	top:0;
+	right:0;
+}
+.mCSB_scrollTools .mCSB_draggerContainer{
+	position:absolute;
+	top:0;
+	left:0;
+	bottom:0;
+	right:0; 
+	height:auto;
+}
+.mCSB_scrollTools a+.mCSB_draggerContainer{
+	margin:20px 0;
+}
+.mCSB_scrollTools .mCSB_draggerRail{
+	width:2px;
+	height:100%;
+	margin:0 auto;
+	-webkit-border-radius:10px;
+	-moz-border-radius:10px;
+	border-radius:10px;
+}
+.mCSB_scrollTools .mCSB_dragger{
+	cursor:pointer;
+	width:100%;
+	height:30px;
+}
+.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:4px;
+	height:100%;
+	margin:0 auto;
+	-webkit-border-radius:10px;
+	-moz-border-radius:10px;
+	border-radius:10px;
+	text-align:center;
+}
+.mCSB_scrollTools .mCSB_buttonUp,
+.mCSB_scrollTools .mCSB_buttonDown{
+	display:block;
+	position:relative;
+	height:20px;
+	overflow:hidden;
+	margin:0 auto;
+	cursor:pointer;
+}
+.mCSB_scrollTools .mCSB_buttonDown{
+	top:100%;
+	margin-top:-40px;
+}
+/* horizontal scrollbar */
+.mCSB_horizontal>.mCSB_container{
+	height:auto;
+	margin-right:0;
+	margin-bottom:30px;
+	overflow:hidden;
+}
+.mCSB_horizontal>.mCSB_container.mCS_no_scrollbar{
+	margin-bottom:0;
+}
+.mCS_disabled>.mCSB_horizontal>.mCSB_container.mCS_no_scrollbar,
+.mCS_destroyed>.mCSB_horizontal>.mCSB_container.mCS_no_scrollbar{
+	margin-right:0;
+	margin-bottom:30px;
+}
+.mCSB_horizontal.mCustomScrollBox>.mCSB_scrollTools{
+	width:100%;
+	height:16px;
+	top:auto;
+	right:auto;
+	bottom:0;
+	left:0;
+	overflow:hidden;
+}
+.mCSB_horizontal>.mCSB_scrollTools a+.mCSB_draggerContainer{
+	margin:0 20px;
+}
+.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
+	width:100%;
+	height:2px;
+	margin:7px 0;
+	-webkit-border-radius:10px;
+	-moz-border-radius:10px;
+	border-radius:10px;
+}
+.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger{
+	width:30px;
+	height:100%;
+}
+.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:100%;
+	height:4px;
+	margin:6px auto;
+	-webkit-border-radius:10px;
+	-moz-border-radius:10px;
+	border-radius:10px;
+}
+.mCSB_horizontal>.mCSB_scrollTools .mCSB_buttonLeft,
+.mCSB_horizontal>.mCSB_scrollTools .mCSB_buttonRight{
+	display:block;
+	position:relative;
+	width:20px;
+	height:100%;
+	overflow:hidden;
+	margin:0 auto;
+	cursor:pointer;
+	float:left;
+}
+.mCSB_horizontal>.mCSB_scrollTools .mCSB_buttonRight{
+	margin-left:-40px;
+	float:right;
+}
+.mCustomScrollBox{
+	-ms-touch-action:none; /*MSPointer events - direct all pointer events to js*/
+}
+
+/* default scrollbar colors and backgrounds (default theme) */
+.mCustomScrollBox>.mCSB_scrollTools{
+	opacity:0.75;
+	filter:"alpha(opacity=75)"; -ms-filter:"alpha(opacity=75)"; /* old ie */
+}
+.mCustomScrollBox:hover>.mCSB_scrollTools{
+	opacity:1;
+	filter:"alpha(opacity=100)"; -ms-filter:"alpha(opacity=100)"; /* old ie */
+}
+.mCSB_scrollTools .mCSB_draggerRail{
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.4);
+	filter:"alpha(opacity=40)"; -ms-filter:"alpha(opacity=40)"; /* old ie */
+}
+.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	background:#fff; /* rgba fallback */
+	background:rgba(255,255,255,0.75);
+	filter:"alpha(opacity=75)"; -ms-filter:"alpha(opacity=75)"; /* old ie */
+}
+.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
+	background:rgba(255,255,255,0.85);
+	filter:"alpha(opacity=85)"; -ms-filter:"alpha(opacity=85)"; /* old ie */
+}
+.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:rgba(255,255,255,0.9);
+	filter:"alpha(opacity=90)"; -ms-filter:"alpha(opacity=90)"; /* old ie */
+}
+.mCSB_scrollTools .mCSB_buttonUp,
+.mCSB_scrollTools .mCSB_buttonDown,
+.mCSB_scrollTools .mCSB_buttonLeft,
+.mCSB_scrollTools .mCSB_buttonRight{
+	background-image:url(mCSB_buttons.png);
+	background-repeat:no-repeat;
+	opacity:0.4;
+	filter:"alpha(opacity=40)"; -ms-filter:"alpha(opacity=40)"; /* old ie */
+}
+.mCSB_scrollTools .mCSB_buttonUp{
+	background-position:0 0;
+	/* 
+	sprites locations are 0 0/-16px 0/-32px 0/-48px 0 (light) and -80px 0/-96px 0/-112px 0/-128px 0 (dark) 
+	*/
+}
+.mCSB_scrollTools .mCSB_buttonDown{
+	background-position:0 -20px;
+	/* 
+	sprites locations are 0 -20px/-16px -20px/-32px -20px/-48px -20px (light) and -80px -20px/-96px -20px/-112px -20px/-128px -20px (dark) 
+	*/
+}
+.mCSB_scrollTools .mCSB_buttonLeft{
+	background-position:0 -40px;
+	/* 
+	sprites locations are 0 -40px/-20px -40px/-40px -40px/-60px -40px (light) and -80px -40px/-100px -40px/-120px -40px/-140px -40px (dark) 
+	*/
+}
+.mCSB_scrollTools .mCSB_buttonRight{
+	background-position:0 -56px;
+	/* 
+	sprites locations are 0 -56px/-20px -56px/-40px -56px/-60px -56px (light) and -80px -56px/-100px -56px/-120px -56px/-140px -56px (dark) 
+	*/
+}
+.mCSB_scrollTools .mCSB_buttonUp:hover,
+.mCSB_scrollTools .mCSB_buttonDown:hover,
+.mCSB_scrollTools .mCSB_buttonLeft:hover,
+.mCSB_scrollTools .mCSB_buttonRight:hover{
+	opacity:0.75;
+	filter:"alpha(opacity=75)"; -ms-filter:"alpha(opacity=75)"; /* old ie */
+}
+.mCSB_scrollTools .mCSB_buttonUp:active,
+.mCSB_scrollTools .mCSB_buttonDown:active,
+.mCSB_scrollTools .mCSB_buttonLeft:active,
+.mCSB_scrollTools .mCSB_buttonRight:active{
+	opacity:0.9;
+	filter:"alpha(opacity=90)"; -ms-filter:"alpha(opacity=90)"; /* old ie */
+}
+
+/*scrollbar themes*/
+/*dark (dark colored scrollbar)*/
+.mCS-dark>.mCSB_scrollTools .mCSB_draggerRail{
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.15);
+}
+.mCS-dark>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.75);
+}
+.mCS-dark>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.85);
+}
+.mCS-dark>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.mCS-dark>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.9);
+}
+.mCS-dark>.mCSB_scrollTools .mCSB_buttonUp{
+	background-position:-80px 0;
+}
+.mCS-dark>.mCSB_scrollTools .mCSB_buttonDown{
+	background-position:-80px -20px;
+}
+.mCS-dark>.mCSB_scrollTools .mCSB_buttonLeft{
+	background-position:-80px -40px;
+}
+.mCS-dark>.mCSB_scrollTools .mCSB_buttonRight{
+	background-position:-80px -56px;
+}
+/*light-2*/
+.mCS-light-2>.mCSB_scrollTools .mCSB_draggerRail{
+	width:4px;
+	background:#fff; /* rgba fallback */
+	background:rgba(255,255,255,0.1);
+	-webkit-border-radius:1px;
+	-moz-border-radius:1px;
+	border-radius:1px;
+}
+.mCS-light-2>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:4px;
+	background:#fff; /* rgba fallback */
+	background:rgba(255,255,255,0.75);
+	-webkit-border-radius:1px;
+	-moz-border-radius:1px;
+	border-radius:1px;
+}
+.mCS-light-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
+	width:100%;
+	height:4px;
+	margin:6px 0;
+}
+.mCS-light-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:100%;
+	height:4px;
+	margin:6px auto;
+}
+.mCS-light-2>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
+	background:rgba(255,255,255,0.85);
+}
+.mCS-light-2>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.mCS-light-2>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:rgba(255,255,255,0.9);
+}
+.mCS-light-2>.mCSB_scrollTools .mCSB_buttonUp{
+	background-position:-32px 0;
+}
+.mCS-light-2>.mCSB_scrollTools .mCSB_buttonDown{
+	background-position:-32px -20px;
+}
+.mCS-light-2>.mCSB_scrollTools .mCSB_buttonLeft{
+	background-position:-40px -40px;
+}
+.mCS-light-2>.mCSB_scrollTools .mCSB_buttonRight{
+	background-position:-40px -56px;
+}
+/*dark-2*/
+.mCS-dark-2>.mCSB_scrollTools .mCSB_draggerRail{
+	width:4px;
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.1);
+	-webkit-border-radius:1px;
+	-moz-border-radius:1px;
+	border-radius:1px;
+}
+.mCS-dark-2>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:4px;
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.75);
+	-webkit-border-radius:1px;
+	-moz-border-radius:1px;
+	border-radius:1px;
+}
+.mCS-dark-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
+	width:100%;
+	height:4px;
+	margin:6px 0;
+}
+.mCS-dark-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:100%;
+	height:4px;
+	margin:6px auto;
+}
+.mCS-dark-2>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.85);
+}
+.mCS-dark-2>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.mCS-dark-2>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.9);
+}
+.mCS-dark-2>.mCSB_scrollTools .mCSB_buttonUp{
+	background-position:-112px 0;
+}
+.mCS-dark-2>.mCSB_scrollTools .mCSB_buttonDown{
+	background-position:-112px -20px;
+}
+.mCS-dark-2>.mCSB_scrollTools .mCSB_buttonLeft{
+	background-position:-120px -40px;
+}
+.mCS-dark-2>.mCSB_scrollTools .mCSB_buttonRight{
+	background-position:-120px -56px;
+}
+/*light-thick*/
+.mCS-light-thick>.mCSB_scrollTools .mCSB_draggerRail{
+	width:4px;
+	background:#fff; /* rgba fallback */
+	background:rgba(255,255,255,0.1);
+	-webkit-border-radius:2px;
+	-moz-border-radius:2px;
+	border-radius:2px;
+}
+.mCS-light-thick>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:6px;
+	background:#fff; /* rgba fallback */
+	background:rgba(255,255,255,0.75);
+	-webkit-border-radius:2px;
+	-moz-border-radius:2px;
+	border-radius:2px;
+}
+.mCS-light-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
+	width:100%;
+	height:4px;
+	margin:6px 0;
+}
+.mCS-light-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:100%;
+	height:6px;
+	margin:5px auto;
+}
+.mCS-light-thick>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
+	background:rgba(255,255,255,0.85);
+}
+.mCS-light-thick>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.mCS-light-thick>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:rgba(255,255,255,0.9);
+}
+.mCS-light-thick>.mCSB_scrollTools .mCSB_buttonUp{
+	background-position:-16px 0;
+}
+.mCS-light-thick>.mCSB_scrollTools .mCSB_buttonDown{
+	background-position:-16px -20px;
+}
+.mCS-light-thick>.mCSB_scrollTools .mCSB_buttonLeft{
+	background-position:-20px -40px;
+}
+.mCS-light-thick>.mCSB_scrollTools .mCSB_buttonRight{
+	background-position:-20px -56px;
+}
+/*dark-thick*/
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_draggerRail{
+	width:4px;
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.1);
+	-webkit-border-radius:2px;
+	-moz-border-radius:2px;
+	border-radius:2px;
+}
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:6px;
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.75);
+	-webkit-border-radius:2px;
+	-moz-border-radius:2px;
+	border-radius:2px;
+}
+.mCS-dark-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
+	width:100%;
+	height:4px;
+	margin:6px 0;
+}
+.mCS-dark-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:100%;
+	height:6px;
+	margin:5px auto;
+}
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.85);
+}
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.9);
+}
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonUp{
+	background-position:-96px 0;
+}
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonDown{
+	background-position:-96px -20px;
+}
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonLeft{
+	background-position:-100px -40px;
+}
+.mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonRight{
+	background-position:-100px -56px;
+}
+/*light-thin*/
+.mCS-light-thin>.mCSB_scrollTools .mCSB_draggerRail{
+	background:#fff; /* rgba fallback */
+	background:rgba(255,255,255,0.1);
+}
+.mCS-light-thin>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:2px;
+}
+.mCS-light-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
+	width:100%;
+}
+.mCS-light-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:100%;
+	height:2px;
+	margin:7px auto;
+}
+/*dark-thin*/
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_draggerRail{
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.15);
+}
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:2px;
+	background:#000; /* rgba fallback */
+	background:rgba(0,0,0,0.75);
+}
+.mCS-dark-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
+	width:100%;
+}
+.mCS-dark-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
+	width:100%;
+	height:2px;
+	margin:7px auto;
+}
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.85);
+}
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
+	background:rgba(0,0,0,0.9);
+}
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonUp{
+	background-position:-80px 0;
+}
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonDown{
+	background-position:-80px -20px;
+}
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonLeft{
+	background-position:-80px -40px;
+}
+.mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonRight{
+	background-position:-80px -56px;
+}

+ 969 - 0
src/main/webapp/static/mCustomScrollbar/demo/jquery.mCustomScrollbar.js

@@ -0,0 +1,969 @@
+/*
+== malihu jquery custom scrollbars plugin == 
+version: 2.8.3 
+author: malihu (http://manos.malihu.gr) 
+plugin home: http://manos.malihu.gr/jquery-custom-content-scroller 
+*/
+
+/*
+Copyright 2010-2013 Manos Malihutsakis 
+
+This program is free software: you can redistribute it and/or modify 
+it under the terms of the GNU Lesser General Public License as published by 
+the Free Software Foundation, either version 3 of the License, or 
+any later version. 
+
+This program is distributed in the hope that it will be useful, 
+but WITHOUT ANY WARRANTY; without even the implied warranty of 
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
+GNU Lesser General Public License for more details. 
+
+You should have received a copy of the GNU Lesser General Public License 
+along with this program.  If not, see http://www.gnu.org/licenses/lgpl.html. 
+*/
+(function($){
+	/*plugin script*/
+	var methods={
+		init:function(options){
+			var defaults={ 
+				set_width:false, /*optional element width: boolean, pixels, percentage*/
+				set_height:false, /*optional element height: boolean, pixels, percentage*/
+				horizontalScroll:false, /*scroll horizontally: boolean*/
+				scrollInertia:950, /*scrolling inertia: integer (milliseconds)*/
+				mouseWheel:true, /*mousewheel support: boolean*/
+				mouseWheelPixels:"auto", /*mousewheel pixels amount: integer, "auto"*/
+				autoDraggerLength:true, /*auto-adjust scrollbar dragger length: boolean*/
+				autoHideScrollbar:false, /*auto-hide scrollbar when idle*/
+				alwaysShowScrollbar:false, /*always show scrollbar even when there's nothing to scroll (disables autoHideScrollbar): boolean*/
+				snapAmount:null, /* optional element always snaps to a multiple of this number in pixels */
+				snapOffset:0, /* when snapping, snap with this number in pixels as an offset */
+				scrollButtons:{ /*scroll buttons*/
+					enable:false, /*scroll buttons support: boolean*/
+					scrollType:"continuous", /*scroll buttons scrolling type: "continuous", "pixels"*/
+					scrollSpeed:"auto", /*scroll buttons continuous scrolling speed: integer, "auto"*/
+					scrollAmount:40 /*scroll buttons pixels scroll amount: integer (pixels)*/
+				},
+				advanced:{
+					updateOnBrowserResize:true, /*update scrollbars on browser resize (for layouts based on percentages): boolean*/
+					updateOnContentResize:false, /*auto-update scrollbars on content resize (for dynamic content): boolean*/
+					autoExpandHorizontalScroll:false, /*auto-expand width for horizontal scrolling: boolean*/
+					autoScrollOnFocus:true, /*auto-scroll on focused elements: boolean*/
+					normalizeMouseWheelDelta:false /*normalize mouse-wheel delta (-1/1)*/
+				},
+				contentTouchScroll:true, /*scrolling by touch-swipe content: boolean*/
+				callbacks:{
+					onScrollStart:function(){}, /*user custom callback function on scroll start event*/
+					onScroll:function(){}, /*user custom callback function on scroll event*/
+					onTotalScroll:function(){}, /*user custom callback function on scroll end reached event*/
+					onTotalScrollBack:function(){}, /*user custom callback function on scroll begin reached event*/
+					onTotalScrollOffset:0, /*scroll end reached offset: integer (pixels)*/
+					onTotalScrollBackOffset:0, /*scroll begin reached offset: integer (pixels)*/
+					whileScrolling:function(){} /*user custom callback function on scrolling event*/
+				},
+				theme:"light" /*"light", "dark", "light-2", "dark-2", "light-thick", "dark-thick", "light-thin", "dark-thin"*/
+			},
+			options=$.extend(true,defaults,options);
+			return this.each(function(){
+				var $this=$(this);
+				/*set element width/height, create markup for custom scrollbars, add classes*/
+				if(options.set_width){
+					$this.css("width",options.set_width);
+				}
+				if(options.set_height){
+					$this.css("height",options.set_height);
+				}
+				if(!$(document).data("mCustomScrollbar-index")){
+					$(document).data("mCustomScrollbar-index","1");
+				}else{
+					var mCustomScrollbarIndex=parseInt($(document).data("mCustomScrollbar-index"));
+					$(document).data("mCustomScrollbar-index",mCustomScrollbarIndex+1);
+				}
+				$this.wrapInner("<div class='mCustomScrollBox"+" mCS-"+options.theme+"' id='mCSB_"+$(document).data("mCustomScrollbar-index")+"' style='position:relative; height:100%; overflow:hidden; max-width:100%;' />").addClass("mCustomScrollbar _mCS_"+$(document).data("mCustomScrollbar-index"));
+				var mCustomScrollBox=$this.children(".mCustomScrollBox");
+				if(options.horizontalScroll){
+					mCustomScrollBox.addClass("mCSB_horizontal").wrapInner("<div class='mCSB_h_wrapper' style='position:relative; left:0; width:999999px;' />");
+					var mCSB_h_wrapper=mCustomScrollBox.children(".mCSB_h_wrapper");
+					mCSB_h_wrapper.wrapInner("<div class='mCSB_container' style='position:absolute; left:0;' />").children(".mCSB_container").css({"width":mCSB_h_wrapper.children().outerWidth(),"position":"relative"}).unwrap();
+				}else{
+					mCustomScrollBox.wrapInner("<div class='mCSB_container' style='position:relative; top:0;' />");
+				}
+				var mCSB_container=mCustomScrollBox.children(".mCSB_container");
+				if($.support.touch){
+					mCSB_container.addClass("mCS_touch");
+				}
+				mCSB_container.after("<div class='mCSB_scrollTools' style='position:absolute;'><div class='mCSB_draggerContainer'><div class='mCSB_dragger' style='position:absolute;' oncontextmenu='return false;'><div class='mCSB_dragger_bar' style='position:relative;'></div></div><div class='mCSB_draggerRail'></div></div></div>");
+				var mCSB_scrollTools=mCustomScrollBox.children(".mCSB_scrollTools"),
+					mCSB_draggerContainer=mCSB_scrollTools.children(".mCSB_draggerContainer"),
+					mCSB_dragger=mCSB_draggerContainer.children(".mCSB_dragger");
+				if(options.horizontalScroll){
+					mCSB_dragger.data("minDraggerWidth",mCSB_dragger.width());
+				}else{
+					mCSB_dragger.data("minDraggerHeight",mCSB_dragger.height());
+				}
+				if(options.scrollButtons.enable){
+					if(options.horizontalScroll){
+						mCSB_scrollTools.prepend("<a class='mCSB_buttonLeft' oncontextmenu='return false;'></a>").append("<a class='mCSB_buttonRight' oncontextmenu='return false;'></a>");
+					}else{
+						mCSB_scrollTools.prepend("<a class='mCSB_buttonUp' oncontextmenu='return false;'></a>").append("<a class='mCSB_buttonDown' oncontextmenu='return false;'></a>");
+					}
+				}
+				/*mCustomScrollBox scrollTop and scrollLeft is always 0 to prevent browser focus scrolling*/
+				mCustomScrollBox.bind("scroll",function(){
+					if(!$this.is(".mCS_disabled")){ /*native focus scrolling for disabled scrollbars*/
+						mCustomScrollBox.scrollTop(0).scrollLeft(0);
+					}
+				});
+				/*store options, global vars/states, intervals*/
+				$this.data({
+					/*init state*/
+					"mCS_Init":true,
+					/*instance index*/
+					"mCustomScrollbarIndex":$(document).data("mCustomScrollbar-index"),
+					/*option parameters*/
+					"horizontalScroll":options.horizontalScroll,
+					"scrollInertia":options.scrollInertia,
+					"scrollEasing":"mcsEaseOut",
+					"mouseWheel":options.mouseWheel,
+					"mouseWheelPixels":options.mouseWheelPixels,
+					"autoDraggerLength":options.autoDraggerLength,
+					"autoHideScrollbar":options.autoHideScrollbar,
+					"alwaysShowScrollbar":options.alwaysShowScrollbar,
+					"snapAmount":options.snapAmount,
+					"snapOffset":options.snapOffset,
+					"scrollButtons_enable":options.scrollButtons.enable,
+					"scrollButtons_scrollType":options.scrollButtons.scrollType,
+					"scrollButtons_scrollSpeed":options.scrollButtons.scrollSpeed,
+					"scrollButtons_scrollAmount":options.scrollButtons.scrollAmount,
+					"autoExpandHorizontalScroll":options.advanced.autoExpandHorizontalScroll,
+					"autoScrollOnFocus":options.advanced.autoScrollOnFocus,
+					"normalizeMouseWheelDelta":options.advanced.normalizeMouseWheelDelta,
+					"contentTouchScroll":options.contentTouchScroll,
+					"onScrollStart_Callback":options.callbacks.onScrollStart,
+					"onScroll_Callback":options.callbacks.onScroll,
+					"onTotalScroll_Callback":options.callbacks.onTotalScroll,
+					"onTotalScrollBack_Callback":options.callbacks.onTotalScrollBack,
+					"onTotalScroll_Offset":options.callbacks.onTotalScrollOffset,
+					"onTotalScrollBack_Offset":options.callbacks.onTotalScrollBackOffset,
+					"whileScrolling_Callback":options.callbacks.whileScrolling,
+					/*events binding state*/
+					"bindEvent_scrollbar_drag":false,
+					"bindEvent_content_touch":false,
+					"bindEvent_scrollbar_click":false,
+					"bindEvent_mousewheel":false,
+					"bindEvent_buttonsContinuous_y":false,
+					"bindEvent_buttonsContinuous_x":false,
+					"bindEvent_buttonsPixels_y":false,
+					"bindEvent_buttonsPixels_x":false,
+					"bindEvent_focusin":false,
+					"bindEvent_autoHideScrollbar":false,
+					/*buttons intervals*/
+					"mCSB_buttonScrollRight":false,
+					"mCSB_buttonScrollLeft":false,
+					"mCSB_buttonScrollDown":false,
+					"mCSB_buttonScrollUp":false
+				});
+				/*max-width/max-height*/
+				if(options.horizontalScroll){
+					if($this.css("max-width")!=="none"){
+						if(!options.advanced.updateOnContentResize){ /*needs updateOnContentResize*/
+							options.advanced.updateOnContentResize=true;
+						}
+					}
+				}else{
+					if($this.css("max-height")!=="none"){
+						var percentage=false,maxHeight=parseInt($this.css("max-height"));
+						if($this.css("max-height").indexOf("%")>=0){
+							percentage=maxHeight,
+							maxHeight=$this.parent().height()*percentage/100;
+						}
+						$this.css("overflow","hidden");
+						mCustomScrollBox.css("max-height",maxHeight);
+					}
+				}
+				$this.mCustomScrollbar("update");
+				/*window resize fn (for layouts based on percentages)*/
+				if(options.advanced.updateOnBrowserResize){
+					var mCSB_resizeTimeout,currWinWidth=$(window).width(),currWinHeight=$(window).height();
+					$(window).bind("resize."+$this.data("mCustomScrollbarIndex"),function(){
+						if(mCSB_resizeTimeout){
+							clearTimeout(mCSB_resizeTimeout);
+						}
+						mCSB_resizeTimeout=setTimeout(function(){
+							if(!$this.is(".mCS_disabled") && !$this.is(".mCS_destroyed")){
+								var winWidth=$(window).width(),winHeight=$(window).height();
+								if(currWinWidth!==winWidth || currWinHeight!==winHeight){ /*ie8 fix*/
+									if($this.css("max-height")!=="none" && percentage){
+										mCustomScrollBox.css("max-height",$this.parent().height()*percentage/100);
+									}
+									$this.mCustomScrollbar("update");
+									currWinWidth=winWidth; currWinHeight=winHeight;
+								}
+							}
+						},150);
+					});
+				}
+				/*content resize fn (for dynamically generated content)*/
+				if(options.advanced.updateOnContentResize){
+					var mCSB_onContentResize;
+					if(options.horizontalScroll){
+						var mCSB_containerOldSize=mCSB_container.outerWidth();
+					}else{
+						var mCSB_containerOldSize=mCSB_container.outerHeight();
+					}
+					mCSB_onContentResize=setInterval(function(){
+						if(options.horizontalScroll){
+							if(options.advanced.autoExpandHorizontalScroll){
+								mCSB_container.css({"position":"absolute","width":"auto"}).wrap("<div class='mCSB_h_wrapper' style='position:relative; left:0; width:999999px;' />").css({"width":mCSB_container.outerWidth(),"position":"relative"}).unwrap();
+							}
+							var mCSB_containerNewSize=mCSB_container.outerWidth();
+						}else{
+							var mCSB_containerNewSize=mCSB_container.outerHeight();
+						}
+						if(mCSB_containerNewSize!=mCSB_containerOldSize){
+							$this.mCustomScrollbar("update");
+							mCSB_containerOldSize=mCSB_containerNewSize;
+						}
+					},300);
+				}
+			});
+		},
+		update:function(){
+			var $this=$(this),
+				mCustomScrollBox=$this.children(".mCustomScrollBox"),
+				mCSB_container=mCustomScrollBox.children(".mCSB_container");
+			mCSB_container.removeClass("mCS_no_scrollbar");
+			$this.removeClass("mCS_disabled mCS_destroyed");
+			mCustomScrollBox.scrollTop(0).scrollLeft(0); /*reset scrollTop/scrollLeft to prevent browser focus scrolling*/
+			var mCSB_scrollTools=mCustomScrollBox.children(".mCSB_scrollTools"),
+				mCSB_draggerContainer=mCSB_scrollTools.children(".mCSB_draggerContainer"),
+				mCSB_dragger=mCSB_draggerContainer.children(".mCSB_dragger");
+			if($this.data("horizontalScroll")){
+				var mCSB_buttonLeft=mCSB_scrollTools.children(".mCSB_buttonLeft"),
+					mCSB_buttonRight=mCSB_scrollTools.children(".mCSB_buttonRight"),
+					mCustomScrollBoxW=mCustomScrollBox.width();
+				if($this.data("autoExpandHorizontalScroll")){
+					mCSB_container.css({"position":"absolute","width":"auto"}).wrap("<div class='mCSB_h_wrapper' style='position:relative; left:0; width:999999px;' />").css({"width":mCSB_container.outerWidth(),"position":"relative"}).unwrap();
+				}
+				var mCSB_containerW=mCSB_container.outerWidth();
+			}else{
+				var mCSB_buttonUp=mCSB_scrollTools.children(".mCSB_buttonUp"),
+					mCSB_buttonDown=mCSB_scrollTools.children(".mCSB_buttonDown"),
+					mCustomScrollBoxH=mCustomScrollBox.height(),
+					mCSB_containerH=mCSB_container.outerHeight();
+			}
+			if(mCSB_containerH>mCustomScrollBoxH && !$this.data("horizontalScroll")){ /*content needs vertical scrolling*/
+				mCSB_scrollTools.css("display","block");
+				var mCSB_draggerContainerH=mCSB_draggerContainer.height();
+				/*auto adjust scrollbar dragger length analogous to content*/
+				if($this.data("autoDraggerLength")){
+					var draggerH=Math.round(mCustomScrollBoxH/mCSB_containerH*mCSB_draggerContainerH),
+						minDraggerH=mCSB_dragger.data("minDraggerHeight");
+					if(draggerH<=minDraggerH){ /*min dragger height*/
+						mCSB_dragger.css({"height":minDraggerH});
+					}else if(draggerH>=mCSB_draggerContainerH-10){ /*max dragger height*/
+						var mCSB_draggerContainerMaxH=mCSB_draggerContainerH-10;
+						mCSB_dragger.css({"height":mCSB_draggerContainerMaxH});
+					}else{
+						mCSB_dragger.css({"height":draggerH});
+					}
+					mCSB_dragger.children(".mCSB_dragger_bar").css({"line-height":mCSB_dragger.height()+"px"});
+				}
+				var mCSB_draggerH=mCSB_dragger.height(),
+				/*calculate and store scroll amount, add scrolling*/
+					scrollAmount=(mCSB_containerH-mCustomScrollBoxH)/(mCSB_draggerContainerH-mCSB_draggerH);
+				$this.data("scrollAmount",scrollAmount).mCustomScrollbar("scrolling",mCustomScrollBox,mCSB_container,mCSB_draggerContainer,mCSB_dragger,mCSB_buttonUp,mCSB_buttonDown,mCSB_buttonLeft,mCSB_buttonRight);
+				/*scroll*/
+				var mCSB_containerP=Math.abs(mCSB_container.position().top);
+				$this.mCustomScrollbar("scrollTo",mCSB_containerP,{scrollInertia:0,trigger:"internal"});
+			}else if(mCSB_containerW>mCustomScrollBoxW && $this.data("horizontalScroll")){ /*content needs horizontal scrolling*/
+				mCSB_scrollTools.css("display","block");
+				var mCSB_draggerContainerW=mCSB_draggerContainer.width();
+				/*auto adjust scrollbar dragger length analogous to content*/
+				if($this.data("autoDraggerLength")){
+					var draggerW=Math.round(mCustomScrollBoxW/mCSB_containerW*mCSB_draggerContainerW),
+						minDraggerW=mCSB_dragger.data("minDraggerWidth");
+					if(draggerW<=minDraggerW){ /*min dragger height*/
+						mCSB_dragger.css({"width":minDraggerW});
+					}else if(draggerW>=mCSB_draggerContainerW-10){ /*max dragger height*/
+						var mCSB_draggerContainerMaxW=mCSB_draggerContainerW-10;
+						mCSB_dragger.css({"width":mCSB_draggerContainerMaxW});
+					}else{
+						mCSB_dragger.css({"width":draggerW});
+					}
+				}
+				var mCSB_draggerW=mCSB_dragger.width(),
+				/*calculate and store scroll amount, add scrolling*/
+					scrollAmount=(mCSB_containerW-mCustomScrollBoxW)/(mCSB_draggerContainerW-mCSB_draggerW);
+				$this.data("scrollAmount",scrollAmount).mCustomScrollbar("scrolling",mCustomScrollBox,mCSB_container,mCSB_draggerContainer,mCSB_dragger,mCSB_buttonUp,mCSB_buttonDown,mCSB_buttonLeft,mCSB_buttonRight);
+				/*scroll*/
+				var mCSB_containerP=Math.abs(mCSB_container.position().left);
+				$this.mCustomScrollbar("scrollTo",mCSB_containerP,{scrollInertia:0,trigger:"internal"});
+			}else{ /*content does not need scrolling*/
+				/*unbind events, reset content position, hide scrollbars, remove classes*/
+				mCustomScrollBox.unbind("mousewheel focusin");
+				if($this.data("horizontalScroll")){
+					mCSB_dragger.add(mCSB_container).css("left",0);
+				}else{
+					mCSB_dragger.add(mCSB_container).css("top",0);
+				}
+				if ($this.data("alwaysShowScrollbar")) {
+					if(!$this.data("horizontalScroll")){ /*vertical scrolling*/
+						mCSB_dragger.css({"height":mCSB_draggerContainer.height()});
+					}else if($this.data("horizontalScroll")){ /*horizontal scrolling*/
+						mCSB_dragger.css({"width":mCSB_draggerContainer.width()});
+					}
+				} else {
+					mCSB_scrollTools.css("display","none");
+					mCSB_container.addClass("mCS_no_scrollbar");
+				}
+				$this.data({"bindEvent_mousewheel":false,"bindEvent_focusin":false});
+			}
+		},
+		scrolling:function(mCustomScrollBox,mCSB_container,mCSB_draggerContainer,mCSB_dragger,mCSB_buttonUp,mCSB_buttonDown,mCSB_buttonLeft,mCSB_buttonRight){
+			var $this=$(this);
+			/*scrollbar drag scrolling*/
+			if(!$this.data("bindEvent_scrollbar_drag")){
+				var mCSB_draggerDragY,mCSB_draggerDragX,
+					mCSB_dragger_downEvent,mCSB_dragger_moveEvent,mCSB_dragger_upEvent;
+				if($.support.pointer){ /*pointer*/
+					mCSB_dragger_downEvent="pointerdown";
+					mCSB_dragger_moveEvent="pointermove";
+					mCSB_dragger_upEvent="pointerup";
+				}else if($.support.msPointer){ /*MSPointer*/
+					mCSB_dragger_downEvent="MSPointerDown";
+					mCSB_dragger_moveEvent="MSPointerMove";
+					mCSB_dragger_upEvent="MSPointerUp";
+				}
+				if($.support.pointer || $.support.msPointer){ /*pointer, MSPointer*/
+					mCSB_dragger.bind(mCSB_dragger_downEvent,function(e){
+						e.preventDefault();
+						$this.data({"on_drag":true}); mCSB_dragger.addClass("mCSB_dragger_onDrag");
+						var elem=$(this),
+							elemOffset=elem.offset(),
+							x=e.originalEvent.pageX-elemOffset.left,
+							y=e.originalEvent.pageY-elemOffset.top;
+						if(x<elem.width() && x>0 && y<elem.height() && y>0){
+							mCSB_draggerDragY=y;
+							mCSB_draggerDragX=x;
+						}
+					});
+					$(document).bind(mCSB_dragger_moveEvent+"."+$this.data("mCustomScrollbarIndex"),function(e){
+						e.preventDefault();
+						if($this.data("on_drag")){
+							var elem=mCSB_dragger,
+								elemOffset=elem.offset(),
+								x=e.originalEvent.pageX-elemOffset.left,
+								y=e.originalEvent.pageY-elemOffset.top;
+							scrollbarDrag(mCSB_draggerDragY,mCSB_draggerDragX,y,x);
+						}
+					}).bind(mCSB_dragger_upEvent+"."+$this.data("mCustomScrollbarIndex"),function(e){
+						$this.data({"on_drag":false}); mCSB_dragger.removeClass("mCSB_dragger_onDrag");
+					});
+				}else{ /*mouse/touch*/
+					mCSB_dragger.bind("mousedown touchstart",function(e){
+						e.preventDefault(); e.stopImmediatePropagation();
+						var	elem=$(this),elemOffset=elem.offset(),x,y;
+						if(e.type==="touchstart"){
+							var touch=e.originalEvent.touches[0] || e.originalEvent.changedTouches[0];
+							x=touch.pageX-elemOffset.left; y=touch.pageY-elemOffset.top;
+						}else{
+							$this.data({"on_drag":true}); mCSB_dragger.addClass("mCSB_dragger_onDrag");
+							x=e.pageX-elemOffset.left; y=e.pageY-elemOffset.top;
+						}
+						if(x<elem.width() && x>0 && y<elem.height() && y>0){
+							mCSB_draggerDragY=y; mCSB_draggerDragX=x;
+						}
+					}).bind("touchmove",function(e){
+						e.preventDefault(); e.stopImmediatePropagation();
+						var touch=e.originalEvent.touches[0] || e.originalEvent.changedTouches[0],
+							elem=$(this),
+							elemOffset=elem.offset(),
+							x=touch.pageX-elemOffset.left,
+							y=touch.pageY-elemOffset.top;
+						scrollbarDrag(mCSB_draggerDragY,mCSB_draggerDragX,y,x);
+					});
+					$(document).bind("mousemove."+$this.data("mCustomScrollbarIndex"),function(e){
+						if($this.data("on_drag")){
+							var elem=mCSB_dragger,
+								elemOffset=elem.offset(),
+								x=e.pageX-elemOffset.left,
+								y=e.pageY-elemOffset.top;
+							scrollbarDrag(mCSB_draggerDragY,mCSB_draggerDragX,y,x);
+						}
+					}).bind("mouseup."+$this.data("mCustomScrollbarIndex"),function(e){
+						$this.data({"on_drag":false}); mCSB_dragger.removeClass("mCSB_dragger_onDrag");
+					});
+				}
+				$this.data({"bindEvent_scrollbar_drag":true});
+			}
+			function scrollbarDrag(mCSB_draggerDragY,mCSB_draggerDragX,y,x){
+				if($this.data("horizontalScroll")){
+					$this.mCustomScrollbar("scrollTo",(mCSB_dragger.position().left-(mCSB_draggerDragX))+x,{moveDragger:true,trigger:"internal"});
+				}else{
+					$this.mCustomScrollbar("scrollTo",(mCSB_dragger.position().top-(mCSB_draggerDragY))+y,{moveDragger:true,trigger:"internal"});
+				}
+			}
+			/*content touch-drag*/
+			if($.support.touch && $this.data("contentTouchScroll")){
+				if(!$this.data("bindEvent_content_touch")){
+					var touch,
+						elem,elemOffset,y,x,mCSB_containerTouchY,mCSB_containerTouchX;
+					mCSB_container.bind("touchstart",function(e){
+						e.stopImmediatePropagation();
+						touch=e.originalEvent.touches[0] || e.originalEvent.changedTouches[0];
+						elem=$(this);
+						elemOffset=elem.offset();
+						x=touch.pageX-elemOffset.left;
+						y=touch.pageY-elemOffset.top;
+						mCSB_containerTouchY=y;
+						mCSB_containerTouchX=x;
+					});
+					mCSB_container.bind("touchmove",function(e){
+						e.preventDefault(); e.stopImmediatePropagation();
+						touch=e.originalEvent.touches[0] || e.originalEvent.changedTouches[0];
+						elem=$(this).parent();
+						elemOffset=elem.offset();
+						x=touch.pageX-elemOffset.left;
+						y=touch.pageY-elemOffset.top;
+						if($this.data("horizontalScroll")){
+							$this.mCustomScrollbar("scrollTo",mCSB_containerTouchX-x,{trigger:"internal"});
+						}else{
+							$this.mCustomScrollbar("scrollTo",mCSB_containerTouchY-y,{trigger:"internal"});
+						}
+					});
+				}
+			}
+			/*dragger rail click scrolling*/
+			if(!$this.data("bindEvent_scrollbar_click")){
+				mCSB_draggerContainer.bind("click",function(e){
+					var scrollToPos=(e.pageY-mCSB_draggerContainer.offset().top)*$this.data("scrollAmount"),target=$(e.target);
+					if($this.data("horizontalScroll")){
+						scrollToPos=(e.pageX-mCSB_draggerContainer.offset().left)*$this.data("scrollAmount");
+					}
+					if(target.hasClass("mCSB_draggerContainer") || target.hasClass("mCSB_draggerRail")){
+						$this.mCustomScrollbar("scrollTo",scrollToPos,{trigger:"internal",scrollEasing:"draggerRailEase"});
+					}
+				});
+				$this.data({"bindEvent_scrollbar_click":true});
+			}
+			/*mousewheel scrolling*/
+			if($this.data("mouseWheel")){
+				if(!$this.data("bindEvent_mousewheel")){
+					mCustomScrollBox.bind("mousewheel",function(e,delta){
+						var scrollTo,mouseWheelPixels=$this.data("mouseWheelPixels"),absPos=Math.abs(mCSB_container.position().top),
+							draggerPos=mCSB_dragger.position().top,limit=mCSB_draggerContainer.height()-mCSB_dragger.height();
+						if($this.data("normalizeMouseWheelDelta")){
+							if(delta<0){delta=-1;}else{delta=1;}
+						}
+						if(mouseWheelPixels==="auto"){
+							mouseWheelPixels=100+Math.round($this.data("scrollAmount")/2);
+						}
+						if($this.data("horizontalScroll")){
+							draggerPos=mCSB_dragger.position().left; 
+							limit=mCSB_draggerContainer.width()-mCSB_dragger.width();
+							absPos=Math.abs(mCSB_container.position().left);
+						}
+						if((delta>0 && draggerPos!==0) || (delta<0 && draggerPos!==limit)){e.preventDefault(); e.stopImmediatePropagation();}
+						scrollTo=absPos-(delta*mouseWheelPixels);
+						$this.mCustomScrollbar("scrollTo",scrollTo,{trigger:"internal"});
+					});
+					$this.data({"bindEvent_mousewheel":true});
+				}
+			}
+			/*buttons scrolling*/
+			if($this.data("scrollButtons_enable")){
+				if($this.data("scrollButtons_scrollType")==="pixels"){ /*scroll by pixels*/
+					if($this.data("horizontalScroll")){
+						mCSB_buttonRight.add(mCSB_buttonLeft).unbind("mousedown touchstart MSPointerDown pointerdown mouseup MSPointerUp pointerup mouseout MSPointerOut pointerout touchend",mCSB_buttonRight_stop,mCSB_buttonLeft_stop);
+						$this.data({"bindEvent_buttonsContinuous_x":false});
+						if(!$this.data("bindEvent_buttonsPixels_x")){
+							/*scroll right*/
+							mCSB_buttonRight.bind("click",function(e){
+								e.preventDefault();
+								PixelsScrollTo(Math.abs(mCSB_container.position().left)+$this.data("scrollButtons_scrollAmount"));
+							});
+							/*scroll left*/
+							mCSB_buttonLeft.bind("click",function(e){
+								e.preventDefault();
+								PixelsScrollTo(Math.abs(mCSB_container.position().left)-$this.data("scrollButtons_scrollAmount"));
+							});
+							$this.data({"bindEvent_buttonsPixels_x":true});
+						}
+					}else{
+						mCSB_buttonDown.add(mCSB_buttonUp).unbind("mousedown touchstart MSPointerDown pointerdown mouseup MSPointerUp pointerup mouseout MSPointerOut pointerout touchend",mCSB_buttonRight_stop,mCSB_buttonLeft_stop);
+						$this.data({"bindEvent_buttonsContinuous_y":false});
+						if(!$this.data("bindEvent_buttonsPixels_y")){
+							/*scroll down*/
+							mCSB_buttonDown.bind("click",function(e){
+								e.preventDefault();
+								PixelsScrollTo(Math.abs(mCSB_container.position().top)+$this.data("scrollButtons_scrollAmount"));
+							});
+							/*scroll up*/
+							mCSB_buttonUp.bind("click",function(e){
+								e.preventDefault();
+								PixelsScrollTo(Math.abs(mCSB_container.position().top)-$this.data("scrollButtons_scrollAmount"));
+							});
+							$this.data({"bindEvent_buttonsPixels_y":true});
+						}
+					}
+					function PixelsScrollTo(to){
+						if(!mCSB_dragger.data("preventAction")){
+							mCSB_dragger.data("preventAction",true);
+							$this.mCustomScrollbar("scrollTo",to,{trigger:"internal"});
+						}
+					}
+				}else{ /*continuous scrolling*/
+					if($this.data("horizontalScroll")){
+						mCSB_buttonRight.add(mCSB_buttonLeft).unbind("click");
+						$this.data({"bindEvent_buttonsPixels_x":false});
+						if(!$this.data("bindEvent_buttonsContinuous_x")){
+							/*scroll right*/
+							mCSB_buttonRight.bind("mousedown touchstart MSPointerDown pointerdown",function(e){
+								e.preventDefault();
+								var scrollButtonsSpeed=ScrollButtonsSpeed();
+								$this.data({"mCSB_buttonScrollRight":setInterval(function(){
+									$this.mCustomScrollbar("scrollTo",Math.abs(mCSB_container.position().left)+scrollButtonsSpeed,{trigger:"internal",scrollEasing:"easeOutCirc"});
+								},17)});
+							});
+							var mCSB_buttonRight_stop=function(e){
+								e.preventDefault(); clearInterval($this.data("mCSB_buttonScrollRight"));
+							}
+							mCSB_buttonRight.bind("mouseup touchend MSPointerUp pointerup mouseout MSPointerOut pointerout",mCSB_buttonRight_stop);
+							/*scroll left*/
+							mCSB_buttonLeft.bind("mousedown touchstart MSPointerDown pointerdown",function(e){
+								e.preventDefault();
+								var scrollButtonsSpeed=ScrollButtonsSpeed();
+								$this.data({"mCSB_buttonScrollLeft":setInterval(function(){
+									$this.mCustomScrollbar("scrollTo",Math.abs(mCSB_container.position().left)-scrollButtonsSpeed,{trigger:"internal",scrollEasing:"easeOutCirc"});
+								},17)});
+							});	
+							var mCSB_buttonLeft_stop=function(e){
+								e.preventDefault(); clearInterval($this.data("mCSB_buttonScrollLeft"));
+							}
+							mCSB_buttonLeft.bind("mouseup touchend MSPointerUp pointerup mouseout MSPointerOut pointerout",mCSB_buttonLeft_stop);
+							$this.data({"bindEvent_buttonsContinuous_x":true});
+						}
+					}else{
+						mCSB_buttonDown.add(mCSB_buttonUp).unbind("click");
+						$this.data({"bindEvent_buttonsPixels_y":false});
+						if(!$this.data("bindEvent_buttonsContinuous_y")){
+							/*scroll down*/
+							mCSB_buttonDown.bind("mousedown touchstart MSPointerDown pointerdown",function(e){
+								e.preventDefault();
+								var scrollButtonsSpeed=ScrollButtonsSpeed();
+								$this.data({"mCSB_buttonScrollDown":setInterval(function(){
+									$this.mCustomScrollbar("scrollTo",Math.abs(mCSB_container.position().top)+scrollButtonsSpeed,{trigger:"internal",scrollEasing:"easeOutCirc"});
+								},17)});
+							});
+							var mCSB_buttonDown_stop=function(e){
+								e.preventDefault(); clearInterval($this.data("mCSB_buttonScrollDown"));
+							}
+							mCSB_buttonDown.bind("mouseup touchend MSPointerUp pointerup mouseout MSPointerOut pointerout",mCSB_buttonDown_stop);
+							/*scroll up*/
+							mCSB_buttonUp.bind("mousedown touchstart MSPointerDown pointerdown",function(e){
+								e.preventDefault();
+								var scrollButtonsSpeed=ScrollButtonsSpeed();
+								$this.data({"mCSB_buttonScrollUp":setInterval(function(){
+									$this.mCustomScrollbar("scrollTo",Math.abs(mCSB_container.position().top)-scrollButtonsSpeed,{trigger:"internal",scrollEasing:"easeOutCirc"});
+								},17)});
+							});	
+							var mCSB_buttonUp_stop=function(e){
+								e.preventDefault(); clearInterval($this.data("mCSB_buttonScrollUp"));
+							}
+							mCSB_buttonUp.bind("mouseup touchend MSPointerUp pointerup mouseout MSPointerOut pointerout",mCSB_buttonUp_stop);
+							$this.data({"bindEvent_buttonsContinuous_y":true});
+						}
+					}
+					function ScrollButtonsSpeed(){
+						var speed=$this.data("scrollButtons_scrollSpeed");
+						if($this.data("scrollButtons_scrollSpeed")==="auto"){
+							speed=Math.round(($this.data("scrollInertia")+100)/40);
+						}
+						return speed;
+					}
+				}
+			}
+			/*scrolling on element focus (e.g. via TAB key)*/
+			if($this.data("autoScrollOnFocus")){
+				if(!$this.data("bindEvent_focusin")){
+					mCustomScrollBox.bind("focusin",function(){
+						mCustomScrollBox.scrollTop(0).scrollLeft(0);
+						var focusedElem=$(document.activeElement);
+						if(focusedElem.is("input,textarea,select,button,a[tabindex],area,object")){
+							var mCSB_containerPos=mCSB_container.position().top,
+								focusedElemPos=focusedElem.position().top,
+								visibleLimit=mCustomScrollBox.height()-focusedElem.outerHeight();
+							if($this.data("horizontalScroll")){
+								mCSB_containerPos=mCSB_container.position().left;
+								focusedElemPos=focusedElem.position().left;
+								visibleLimit=mCustomScrollBox.width()-focusedElem.outerWidth();
+							}
+							if(mCSB_containerPos+focusedElemPos<0 || mCSB_containerPos+focusedElemPos>visibleLimit){
+								$this.mCustomScrollbar("scrollTo",focusedElemPos,{trigger:"internal"});
+							}
+						}
+					});
+					$this.data({"bindEvent_focusin":true});
+				}
+			}
+			/*auto-hide scrollbar*/
+			if($this.data("autoHideScrollbar") && !$this.data("alwaysShowScrollbar")){
+				if(!$this.data("bindEvent_autoHideScrollbar")){
+					mCustomScrollBox.bind("mouseenter",function(e){
+						mCustomScrollBox.addClass("mCS-mouse-over");
+						functions.showScrollbar.call(mCustomScrollBox.children(".mCSB_scrollTools"));
+					}).bind("mouseleave touchend",function(e){
+						mCustomScrollBox.removeClass("mCS-mouse-over");
+						if(e.type==="mouseleave"){functions.hideScrollbar.call(mCustomScrollBox.children(".mCSB_scrollTools"));}
+					});
+					$this.data({"bindEvent_autoHideScrollbar":true});
+				}
+			}
+		},
+		scrollTo:function(scrollTo,options){
+			var $this=$(this),
+				defaults={
+					moveDragger:false,
+					trigger:"external",
+					callbacks:true,
+					scrollInertia:$this.data("scrollInertia"),
+					scrollEasing:$this.data("scrollEasing")
+				},
+				options=$.extend(defaults,options),
+				draggerScrollTo,
+				mCustomScrollBox=$this.children(".mCustomScrollBox"),
+				mCSB_container=mCustomScrollBox.children(".mCSB_container"),
+				mCSB_scrollTools=mCustomScrollBox.children(".mCSB_scrollTools"),
+				mCSB_draggerContainer=mCSB_scrollTools.children(".mCSB_draggerContainer"),
+				mCSB_dragger=mCSB_draggerContainer.children(".mCSB_dragger"),
+				contentSpeed=draggerSpeed=options.scrollInertia,
+				scrollBeginning,scrollBeginningOffset,totalScroll,totalScrollOffset;
+			if(!mCSB_container.hasClass("mCS_no_scrollbar")){
+				$this.data({"mCS_trigger":options.trigger});
+				if($this.data("mCS_Init")){options.callbacks=false;}
+				if(scrollTo || scrollTo===0){
+					if(typeof(scrollTo)==="number"){ /*if integer, scroll by number of pixels*/
+						if(options.moveDragger){ /*scroll dragger*/
+							draggerScrollTo=scrollTo;
+							if($this.data("horizontalScroll")){
+								scrollTo=mCSB_dragger.position().left*$this.data("scrollAmount");
+							}else{
+								scrollTo=mCSB_dragger.position().top*$this.data("scrollAmount");
+							}
+							draggerSpeed=0;
+						}else{ /*scroll content by default*/
+							draggerScrollTo=scrollTo/$this.data("scrollAmount");
+						}
+					}else if(typeof(scrollTo)==="string"){ /*if string, scroll by element position*/
+						var target;
+						if(scrollTo==="top"){ /*scroll to top*/
+							target=0;
+						}else if(scrollTo==="bottom" && !$this.data("horizontalScroll")){ /*scroll to bottom*/
+							target=mCSB_container.outerHeight()-mCustomScrollBox.height();
+						}else if(scrollTo==="left"){ /*scroll to left*/
+							target=0;
+						}else if(scrollTo==="right" && $this.data("horizontalScroll")){ /*scroll to right*/
+							target=mCSB_container.outerWidth()-mCustomScrollBox.width();
+						}else if(scrollTo==="first"){ /*scroll to first element position*/
+							target=$this.find(".mCSB_container").find(":first");
+						}else if(scrollTo==="last"){ /*scroll to last element position*/
+							target=$this.find(".mCSB_container").find(":last");
+						}else{ /*scroll to element position*/
+							target=$this.find(scrollTo);
+						}
+						if(target.length===1){ /*if such unique element exists, scroll to it*/
+							if($this.data("horizontalScroll")){
+								scrollTo=target.position().left;
+							}else{
+								scrollTo=target.position().top;
+							}
+							draggerScrollTo=scrollTo/$this.data("scrollAmount");
+						}else{
+							draggerScrollTo=scrollTo=target;
+						}
+					}
+					/*scroll to*/
+					if($this.data("horizontalScroll")){
+						if($this.data("onTotalScrollBack_Offset")){ /*scroll beginning offset*/
+							scrollBeginningOffset=-$this.data("onTotalScrollBack_Offset");
+						}
+						if($this.data("onTotalScroll_Offset")){ /*total scroll offset*/
+							totalScrollOffset=mCustomScrollBox.width()-mCSB_container.outerWidth()+$this.data("onTotalScroll_Offset");
+						}
+						if(draggerScrollTo<0){ /*scroll start position*/
+							draggerScrollTo=scrollTo=0; clearInterval($this.data("mCSB_buttonScrollLeft"));
+							if(!scrollBeginningOffset){scrollBeginning=true;}
+						}else if(draggerScrollTo>=mCSB_draggerContainer.width()-mCSB_dragger.width()){ /*scroll end position*/
+							draggerScrollTo=mCSB_draggerContainer.width()-mCSB_dragger.width();
+							scrollTo=mCustomScrollBox.width()-mCSB_container.outerWidth(); clearInterval($this.data("mCSB_buttonScrollRight"));
+							if(!totalScrollOffset){totalScroll=true;}
+						}else{scrollTo=-scrollTo;}
+						var snapAmount = $this.data("snapAmount");
+						if (snapAmount) {
+							scrollTo = Math.round(scrollTo / snapAmount) * snapAmount - $this.data("snapOffset");
+						}
+						/*scrolling animation*/
+						functions.mTweenAxis.call(this,mCSB_dragger[0],"left",Math.round(draggerScrollTo),draggerSpeed,options.scrollEasing);
+						functions.mTweenAxis.call(this,mCSB_container[0],"left",Math.round(scrollTo),contentSpeed,options.scrollEasing,{
+							onStart:function(){
+								if(options.callbacks && !$this.data("mCS_tweenRunning")){callbacks("onScrollStart");}
+								if($this.data("autoHideScrollbar") && !$this.data("alwaysShowScrollbar")){functions.showScrollbar.call(mCSB_scrollTools);}
+							},
+							onUpdate:function(){
+								if(options.callbacks){callbacks("whileScrolling");}
+							},
+							onComplete:function(){
+								if(options.callbacks){
+									callbacks("onScroll");
+									if(scrollBeginning || (scrollBeginningOffset && mCSB_container.position().left>=scrollBeginningOffset)){callbacks("onTotalScrollBack");}
+									if(totalScroll || (totalScrollOffset && mCSB_container.position().left<=totalScrollOffset)){callbacks("onTotalScroll");}
+								}
+								mCSB_dragger.data("preventAction",false); $this.data("mCS_tweenRunning",false);
+								if($this.data("autoHideScrollbar") && !$this.data("alwaysShowScrollbar")){if(!mCustomScrollBox.hasClass("mCS-mouse-over")){functions.hideScrollbar.call(mCSB_scrollTools);}}
+							}
+						});
+					}else{
+						if($this.data("onTotalScrollBack_Offset")){ /*scroll beginning offset*/
+							scrollBeginningOffset=-$this.data("onTotalScrollBack_Offset");
+						}
+						if($this.data("onTotalScroll_Offset")){ /*total scroll offset*/
+							totalScrollOffset=mCustomScrollBox.height()-mCSB_container.outerHeight()+$this.data("onTotalScroll_Offset");
+						}
+						if(draggerScrollTo<0){ /*scroll start position*/
+							draggerScrollTo=scrollTo=0; clearInterval($this.data("mCSB_buttonScrollUp"));
+							if(!scrollBeginningOffset){scrollBeginning=true;}
+						}else if(draggerScrollTo>=mCSB_draggerContainer.height()-mCSB_dragger.height()){ /*scroll end position*/
+							draggerScrollTo=mCSB_draggerContainer.height()-mCSB_dragger.height();
+							scrollTo=mCustomScrollBox.height()-mCSB_container.outerHeight(); clearInterval($this.data("mCSB_buttonScrollDown"));
+							if(!totalScrollOffset){totalScroll=true;}
+						}else{scrollTo=-scrollTo;}
+						var snapAmount = $this.data("snapAmount");
+						if (snapAmount) {
+							scrollTo = Math.round(scrollTo / snapAmount) * snapAmount - $this.data("snapOffset");
+						}
+						/*scrolling animation*/
+						functions.mTweenAxis.call(this,mCSB_dragger[0],"top",Math.round(draggerScrollTo),draggerSpeed,options.scrollEasing);
+						functions.mTweenAxis.call(this,mCSB_container[0],"top",Math.round(scrollTo),contentSpeed,options.scrollEasing,{
+							onStart:function(){
+								if(options.callbacks && !$this.data("mCS_tweenRunning")){callbacks("onScrollStart");}
+								if($this.data("autoHideScrollbar") && !$this.data("alwaysShowScrollbar")){functions.showScrollbar.call(mCSB_scrollTools);}
+							},
+							onUpdate:function(){
+								if(options.callbacks){callbacks("whileScrolling");}
+							},
+							onComplete:function(){
+								if(options.callbacks){
+									callbacks("onScroll");
+									if(scrollBeginning || (scrollBeginningOffset && mCSB_container.position().top>=scrollBeginningOffset)){callbacks("onTotalScrollBack");}
+									if(totalScroll || (totalScrollOffset && mCSB_container.position().top<=totalScrollOffset)){callbacks("onTotalScroll");}
+								}
+								mCSB_dragger.data("preventAction",false); $this.data("mCS_tweenRunning",false);
+								if($this.data("autoHideScrollbar") && !$this.data("alwaysShowScrollbar")){if(!mCustomScrollBox.hasClass("mCS-mouse-over")){functions.hideScrollbar.call(mCSB_scrollTools);}}
+							}
+						});
+					}
+					if($this.data("mCS_Init")){$this.data({"mCS_Init":false});}
+				}
+			}
+			/*callbacks*/
+			function callbacks(cb){
+				if ($this.data("mCustomScrollbarIndex")) {
+					this.mcs = {
+						top: mCSB_container.position().top, left: mCSB_container.position().left,
+						draggerTop: mCSB_dragger.position().top, draggerLeft: mCSB_dragger.position().left,
+						topPct: Math.round((100 * Math.abs(mCSB_container.position().top)) / Math.abs(mCSB_container.outerHeight() - mCustomScrollBox.height())),
+						leftPct: Math.round((100 * Math.abs(mCSB_container.position().left)) / Math.abs(mCSB_container.outerWidth() - mCustomScrollBox.width()))
+					};
+					switch (cb) {
+						/*start scrolling callback*/
+						case "onScrollStart":
+							$this.data("mCS_tweenRunning", true).data("onScrollStart_Callback").call($this, this.mcs);
+							break;
+						case "whileScrolling":
+							$this.data("whileScrolling_Callback").call($this, this.mcs);
+							break;
+						case "onScroll":
+							$this.data("onScroll_Callback").call($this, this.mcs);
+							break;
+						case "onTotalScrollBack":
+							$this.data("onTotalScrollBack_Callback").call($this, this.mcs);
+							break;
+						case "onTotalScroll":
+							$this.data("onTotalScroll_Callback").call($this, this.mcs);
+							break;
+					}
+				}
+			}
+		},
+		stop:function(){
+			var $this=$(this),
+				mCSB_container=$this.children().children(".mCSB_container"),
+				mCSB_dragger=$this.children().children().children().children(".mCSB_dragger");
+			functions.mTweenAxisStop.call(this,mCSB_container[0]);
+			functions.mTweenAxisStop.call(this,mCSB_dragger[0]);
+		},
+		disable:function(resetScroll){
+			var $this=$(this),
+				mCustomScrollBox=$this.children(".mCustomScrollBox"),
+				mCSB_container=mCustomScrollBox.children(".mCSB_container"),
+				mCSB_scrollTools=mCustomScrollBox.children(".mCSB_scrollTools"),
+				mCSB_dragger=mCSB_scrollTools.children().children(".mCSB_dragger");
+			mCustomScrollBox.unbind("mousewheel focusin mouseenter mouseleave touchend");
+			mCSB_container.unbind("touchstart touchmove")
+			if(resetScroll){
+				if($this.data("horizontalScroll")){
+					mCSB_dragger.add(mCSB_container).css("left",0);
+				}else{
+					mCSB_dragger.add(mCSB_container).css("top",0);
+				}
+			}
+			mCSB_scrollTools.css("display","none");
+			mCSB_container.addClass("mCS_no_scrollbar");
+			$this.data({"bindEvent_mousewheel":false,"bindEvent_focusin":false,"bindEvent_content_touch":false,"bindEvent_autoHideScrollbar":false}).addClass("mCS_disabled");
+		},
+		destroy:function(){
+			var $this=$(this);
+			$this.removeClass("mCustomScrollbar _mCS_"+$this.data("mCustomScrollbarIndex")).addClass("mCS_destroyed").children().children(".mCSB_container").unwrap().children().unwrap().siblings(".mCSB_scrollTools").remove();
+			$(document).unbind("mousemove."+$this.data("mCustomScrollbarIndex")+" mouseup."+$this.data("mCustomScrollbarIndex")+" MSPointerMove."+$this.data("mCustomScrollbarIndex")+" MSPointerUp."+$this.data("mCustomScrollbarIndex"));
+			$(window).unbind("resize."+$this.data("mCustomScrollbarIndex"));
+		}
+	},
+	functions={
+		/*hide/show scrollbar*/
+		showScrollbar:function(){
+			this.stop().animate({opacity:1},"fast");
+		},
+		hideScrollbar:function(){
+			this.stop().animate({opacity:0},"fast");
+		},
+		/*js animation tween*/
+		mTweenAxis:function(el,prop,to,duration,easing,callbacks){
+			var callbacks=callbacks || {},
+				onStart=callbacks.onStart || function(){},onUpdate=callbacks.onUpdate || function(){},onComplete=callbacks.onComplete || function(){};
+			var startTime=_getTime(),_delay,progress=0,from=el.offsetTop,elStyle=el.style;
+			if(prop==="left"){from=el.offsetLeft;}
+			var diff=to-from;
+			_cancelTween();
+			_startTween();
+			function _getTime(){
+				if(window.performance && window.performance.now){
+					return window.performance.now();
+				}else{
+					if(window.performance && window.performance.webkitNow){
+						return window.performance.webkitNow();
+					}else{
+						if(Date.now){return Date.now();}else{return new Date().getTime();}
+					}
+				}
+			}
+			function _step(){
+				if(!progress){onStart.call();}
+				progress=_getTime()-startTime;
+				_tween();
+				if(progress>=el._time){
+					el._time=(progress>el._time) ? progress+_delay-(progress- el._time) : progress+_delay-1;
+					if(el._time<progress+1){el._time=progress+1;}
+				}
+				if(el._time<duration){el._id=_request(_step);}else{onComplete.call();}
+			}
+			function _tween(){
+				if(duration>0){
+					el.currVal=_ease(el._time,from,diff,duration,easing);
+					elStyle[prop]=Math.round(el.currVal)+"px";
+				}else{
+					elStyle[prop]=to+"px";
+				}
+				onUpdate.call();
+			}
+			function _startTween(){
+				_delay=1000/60;
+				el._time=progress+_delay;
+				_request=(!window.requestAnimationFrame) ? function(f){_tween(); return setTimeout(f,0.01);} : window.requestAnimationFrame;
+				el._id=_request(_step);
+			}
+			function _cancelTween(){
+				if(el._id==null){return;}
+				if(!window.requestAnimationFrame){clearTimeout(el._id);
+				}else{window.cancelAnimationFrame(el._id);}
+				el._id=null;
+			}
+			function _ease(t,b,c,d,type){
+				switch(type){
+					case "linear":
+						return c*t/d + b;
+						break;
+					case "easeOutQuad":
+						t /= d; return -c * t*(t-2) + b;
+						break;
+					case "easeInOutQuad":
+						t /= d/2;
+						if (t < 1) return c/2*t*t + b;
+						t--;
+						return -c/2 * (t*(t-2) - 1) + b;
+						break;
+					case "easeOutCubic":
+						t /= d; t--; return c*(t*t*t + 1) + b;
+						break;
+					case "easeOutQuart":
+						t /= d; t--; return -c * (t*t*t*t - 1) + b;
+						break;
+					case "easeOutQuint":
+						t /= d; t--; return c*(t*t*t*t*t + 1) + b;
+						break;
+					case "easeOutCirc":
+						t /= d; t--; return c * Math.sqrt(1 - t*t) + b;
+						break;
+					case "easeOutSine":
+						return c * Math.sin(t/d * (Math.PI/2)) + b;
+						break;
+					case "easeOutExpo":
+						return c * ( -Math.pow( 2, -10 * t/d ) + 1 ) + b;
+						break;
+					case "mcsEaseOut":
+						var ts=(t/=d)*t,tc=ts*t;
+						return b+c*(0.499999999999997*tc*ts + -2.5*ts*ts + 5.5*tc + -6.5*ts + 4*t);
+						break;
+					case "draggerRailEase":
+						t /= d/2;
+						if (t < 1) return c/2*t*t*t + b;
+						t -= 2;
+						return c/2*(t*t*t + 2) + b;
+						break;
+				}
+			}
+		},
+		/*stop js animation tweens*/
+		mTweenAxisStop:function(el){
+			if(el._id==null){return;}
+			if(!window.requestAnimationFrame){clearTimeout(el._id);
+			}else{window.cancelAnimationFrame(el._id);}
+			el._id=null;
+		},
+		/*detect requestAnimationFrame and polyfill*/
+		rafPolyfill:function(){
+			var pfx=["ms","moz","webkit","o"],i=pfx.length;
+			while(--i > -1 && !window.requestAnimationFrame){
+				window.requestAnimationFrame=window[pfx[i]+"RequestAnimationFrame"];
+				window.cancelAnimationFrame=window[pfx[i]+"CancelAnimationFrame"] || window[pfx[i]+"CancelRequestAnimationFrame"];
+			}
+		}
+	}
+	/*detect features*/
+	functions.rafPolyfill.call(); /*requestAnimationFrame*/
+	$.support.touch=!!('ontouchstart' in window); /*touch*/
+	$.support.pointer=window.navigator.pointerEnabled; /*pointer support*/
+	$.support.msPointer=window.navigator.msPointerEnabled; /*MSPointer support*/
+	/*plugin dependencies*/
+	var _dlp=("https:"==document.location.protocol) ? "https:" : "http:";
+	$.event.special.mousewheel || document.write('<script src="'+_dlp+'//cdnjs.cloudflare.com/ajax/libs/jquery-mousewheel/3.0.6/jquery.mousewheel.min.js"><\/script>');
+	/*plugin fn*/
+	$.fn.mCustomScrollbar=function(method){
+		if(methods[method]){
+			return methods[method].apply(this,Array.prototype.slice.call(arguments,1));
+		}else if(typeof method==="object" || !method){
+			return methods.init.apply(this,arguments);
+		}else{
+			$.error("Method "+method+" does not exist");
+		}
+	};
+})(jQuery);

+ 131 - 0
src/main/webapp/static/mCustomScrollbar/demo/jquery_ui_sortable_example.html

@@ -0,0 +1,131 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		h2{font-family:Georgia,serif; font-size:16px; font-style:italic; color:#eee;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.content{margin:40px; width:260px; height:500px; padding:20px; overflow:auto; background:#333; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+		#sortable{margin:0 0 20px 0; padding:0; list-style-type:none;}
+		#sortable li{background:#444; padding:5px 10px; margin:5px 0; border-radius:3px;}
+		#sortable li:active{background:#cc3300;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>jQuery ui sortable example</h1>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+		<p><strong>Sortable list</strong></p>
+		<ul id="sortable">
+			<li>Item 1</li>
+			<li>Item 2</li>
+			<li>Item 3</li>
+			<li>Item 4</li>
+			<li>Item 5</li>
+			<li>Item 6</li>
+			<li>Item 7</li>
+			<li>Item 8</li>
+			<li>Item 9</li>
+			<li>Item 10</li>
+			<li>Item 11</li>
+			<li>Item 12</li>
+			<li>Item 13</li>
+			<li>Item 14</li>
+			<li>Item 15</li>
+			<li>Item 16</li>
+			<li>Item 17</li>
+			<li>Item 18</li>
+			<li>Item 19</li>
+			<li>Item 20</li>
+			<li>Item 21</li>
+			<li>Item 22</li>
+			<li>Item 23</li>
+			<li>Item 24</li>
+			<li>Item 25</li>
+			<li>Item 26</li>
+			<li>Item 27</li>
+			<li>Item 28</li>
+			<li>Item 29</li>
+			<li>Item 30</li>
+		</ul>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- Google CDN jQuery ui -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.10.0/jquery-ui.min.js"></script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("#content_1").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					}
+				});
+				$("#sortable").sortable({
+					scroll:false,
+					axis:"y",
+					opacity:0.5,
+					change:function(event,ui){
+						var p=ui.position.top,
+							h=ui.helper.outerHeight(true),
+							s=ui.placeholder.position().top,
+							elem=$("#content_1 .mCustomScrollBox")[0],
+							elemHeight=$("#content_1 .mCustomScrollBox").height();
+							pos=findPos(elem),
+							mouseCoordsY=event.pageY-pos[0];
+						if(mouseCoordsY<h || mouseCoordsY>elemHeight-h){
+							$("#content_1").mCustomScrollbar("scrollTo",p-(elemHeight/2));
+						}
+					}
+				});
+				function findPos(obj){
+					var curleft=curtop=0;
+					if (obj.offsetParent){
+						curleft=obj.offsetLeft
+						curtop=obj.offsetTop
+						while(obj=obj.offsetParent){
+							curleft+=obj.offsetLeft
+							curtop+=obj.offsetTop
+						}
+					}
+					return [curtop,curleft];
+				}
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

Diferenças do arquivo suprimidas por serem muito extensas
+ 5 - 0
src/main/webapp/static/mCustomScrollbar/demo/js/minified/jquery-1.9.1.min.js


Diferenças do arquivo suprimidas por serem muito extensas
+ 1 - 0
src/main/webapp/static/mCustomScrollbar/demo/js/minified/jquery.mCustomScrollbar.min.js


Diferenças do arquivo suprimidas por serem muito extensas
+ 12 - 0
src/main/webapp/static/mCustomScrollbar/demo/js/minified/jquery.mousewheel.min.js


Diferenças do arquivo suprimidas por serem muito extensas
+ 9597 - 0
src/main/webapp/static/mCustomScrollbar/demo/js/uncompressed/jquery-1.9.1.js


+ 969 - 0
src/main/webapp/static/mCustomScrollbar/demo/js/uncompressed/jquery.mCustomScrollbar.js

@@ -0,0 +1,969 @@
+/*
+== malihu jquery custom scrollbars plugin == 
+version: 2.8.3 
+author: malihu (http://manos.malihu.gr) 
+plugin home: http://manos.malihu.gr/jquery-custom-content-scroller 
+*/
+
+/*
+Copyright 2010-2013 Manos Malihutsakis 
+
+This program is free software: you can redistribute it and/or modify 
+it under the terms of the GNU Lesser General Public License as published by 
+the Free Software Foundation, either version 3 of the License, or 
+any later version. 
+
+This program is distributed in the hope that it will be useful, 
+but WITHOUT ANY WARRANTY; without even the implied warranty of 
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
+GNU Lesser General Public License for more details. 
+
+You should have received a copy of the GNU Lesser General Public License 
+along with this program.  If not, see http://www.gnu.org/licenses/lgpl.html. 
+*/
+(function($){
+	/*plugin script*/
+	var methods={
+		init:function(options){
+			var defaults={ 
+				set_width:false, /*optional element width: boolean, pixels, percentage*/
+				set_height:false, /*optional element height: boolean, pixels, percentage*/
+				horizontalScroll:false, /*scroll horizontally: boolean*/
+				scrollInertia:950, /*scrolling inertia: integer (milliseconds)*/
+				mouseWheel:true, /*mousewheel support: boolean*/
+				mouseWheelPixels:"auto", /*mousewheel pixels amount: integer, "auto"*/
+				autoDraggerLength:true, /*auto-adjust scrollbar dragger length: boolean*/
+				autoHideScrollbar:false, /*auto-hide scrollbar when idle*/
+				alwaysShowScrollbar:false, /*always show scrollbar even when there's nothing to scroll (disables autoHideScrollbar): boolean*/
+				snapAmount:null, /* optional element always snaps to a multiple of this number in pixels */
+				snapOffset:0, /* when snapping, snap with this number in pixels as an offset */
+				scrollButtons:{ /*scroll buttons*/
+					enable:false, /*scroll buttons support: boolean*/
+					scrollType:"continuous", /*scroll buttons scrolling type: "continuous", "pixels"*/
+					scrollSpeed:"auto", /*scroll buttons continuous scrolling speed: integer, "auto"*/
+					scrollAmount:40 /*scroll buttons pixels scroll amount: integer (pixels)*/
+				},
+				advanced:{
+					updateOnBrowserResize:true, /*update scrollbars on browser resize (for layouts based on percentages): boolean*/
+					updateOnContentResize:false, /*auto-update scrollbars on content resize (for dynamic content): boolean*/
+					autoExpandHorizontalScroll:false, /*auto-expand width for horizontal scrolling: boolean*/
+					autoScrollOnFocus:true, /*auto-scroll on focused elements: boolean*/
+					normalizeMouseWheelDelta:false /*normalize mouse-wheel delta (-1/1)*/
+				},
+				contentTouchScroll:true, /*scrolling by touch-swipe content: boolean*/
+				callbacks:{
+					onScrollStart:function(){}, /*user custom callback function on scroll start event*/
+					onScroll:function(){}, /*user custom callback function on scroll event*/
+					onTotalScroll:function(){}, /*user custom callback function on scroll end reached event*/
+					onTotalScrollBack:function(){}, /*user custom callback function on scroll begin reached event*/
+					onTotalScrollOffset:0, /*scroll end reached offset: integer (pixels)*/
+					onTotalScrollBackOffset:0, /*scroll begin reached offset: integer (pixels)*/
+					whileScrolling:function(){} /*user custom callback function on scrolling event*/
+				},
+				theme:"light" /*"light", "dark", "light-2", "dark-2", "light-thick", "dark-thick", "light-thin", "dark-thin"*/
+			},
+			options=$.extend(true,defaults,options);
+			return this.each(function(){
+				var $this=$(this);
+				/*set element width/height, create markup for custom scrollbars, add classes*/
+				if(options.set_width){
+					$this.css("width",options.set_width);
+				}
+				if(options.set_height){
+					$this.css("height",options.set_height);
+				}
+				if(!$(document).data("mCustomScrollbar-index")){
+					$(document).data("mCustomScrollbar-index","1");
+				}else{
+					var mCustomScrollbarIndex=parseInt($(document).data("mCustomScrollbar-index"));
+					$(document).data("mCustomScrollbar-index",mCustomScrollbarIndex+1);
+				}
+				$this.wrapInner("<div class='mCustomScrollBox"+" mCS-"+options.theme+"' id='mCSB_"+$(document).data("mCustomScrollbar-index")+"' style='position:relative; height:100%; overflow:hidden; max-width:100%;' />").addClass("mCustomScrollbar _mCS_"+$(document).data("mCustomScrollbar-index"));
+				var mCustomScrollBox=$this.children(".mCustomScrollBox");
+				if(options.horizontalScroll){
+					mCustomScrollBox.addClass("mCSB_horizontal").wrapInner("<div class='mCSB_h_wrapper' style='position:relative; left:0; width:999999px;' />");
+					var mCSB_h_wrapper=mCustomScrollBox.children(".mCSB_h_wrapper");
+					mCSB_h_wrapper.wrapInner("<div class='mCSB_container' style='position:absolute; left:0;' />").children(".mCSB_container").css({"width":mCSB_h_wrapper.children().outerWidth(),"position":"relative"}).unwrap();
+				}else{
+					mCustomScrollBox.wrapInner("<div class='mCSB_container' style='position:relative; top:0;' />");
+				}
+				var mCSB_container=mCustomScrollBox.children(".mCSB_container");
+				if($.support.touch){
+					mCSB_container.addClass("mCS_touch");
+				}
+				mCSB_container.after("<div class='mCSB_scrollTools' style='position:absolute;'><div class='mCSB_draggerContainer'><div class='mCSB_dragger' style='position:absolute;' oncontextmenu='return false;'><div class='mCSB_dragger_bar' style='position:relative;'></div></div><div class='mCSB_draggerRail'></div></div></div>");
+				var mCSB_scrollTools=mCustomScrollBox.children(".mCSB_scrollTools"),
+					mCSB_draggerContainer=mCSB_scrollTools.children(".mCSB_draggerContainer"),
+					mCSB_dragger=mCSB_draggerContainer.children(".mCSB_dragger");
+				if(options.horizontalScroll){
+					mCSB_dragger.data("minDraggerWidth",mCSB_dragger.width());
+				}else{
+					mCSB_dragger.data("minDraggerHeight",mCSB_dragger.height());
+				}
+				if(options.scrollButtons.enable){
+					if(options.horizontalScroll){
+						mCSB_scrollTools.prepend("<a class='mCSB_buttonLeft' oncontextmenu='return false;'></a>").append("<a class='mCSB_buttonRight' oncontextmenu='return false;'></a>");
+					}else{
+						mCSB_scrollTools.prepend("<a class='mCSB_buttonUp' oncontextmenu='return false;'></a>").append("<a class='mCSB_buttonDown' oncontextmenu='return false;'></a>");
+					}
+				}
+				/*mCustomScrollBox scrollTop and scrollLeft is always 0 to prevent browser focus scrolling*/
+				mCustomScrollBox.bind("scroll",function(){
+					if(!$this.is(".mCS_disabled")){ /*native focus scrolling for disabled scrollbars*/
+						mCustomScrollBox.scrollTop(0).scrollLeft(0);
+					}
+				});
+				/*store options, global vars/states, intervals*/
+				$this.data({
+					/*init state*/
+					"mCS_Init":true,
+					/*instance index*/
+					"mCustomScrollbarIndex":$(document).data("mCustomScrollbar-index"),
+					/*option parameters*/
+					"horizontalScroll":options.horizontalScroll,
+					"scrollInertia":options.scrollInertia,
+					"scrollEasing":"mcsEaseOut",
+					"mouseWheel":options.mouseWheel,
+					"mouseWheelPixels":options.mouseWheelPixels,
+					"autoDraggerLength":options.autoDraggerLength,
+					"autoHideScrollbar":options.autoHideScrollbar,
+					"alwaysShowScrollbar":options.alwaysShowScrollbar,
+					"snapAmount":options.snapAmount,
+					"snapOffset":options.snapOffset,
+					"scrollButtons_enable":options.scrollButtons.enable,
+					"scrollButtons_scrollType":options.scrollButtons.scrollType,
+					"scrollButtons_scrollSpeed":options.scrollButtons.scrollSpeed,
+					"scrollButtons_scrollAmount":options.scrollButtons.scrollAmount,
+					"autoExpandHorizontalScroll":options.advanced.autoExpandHorizontalScroll,
+					"autoScrollOnFocus":options.advanced.autoScrollOnFocus,
+					"normalizeMouseWheelDelta":options.advanced.normalizeMouseWheelDelta,
+					"contentTouchScroll":options.contentTouchScroll,
+					"onScrollStart_Callback":options.callbacks.onScrollStart,
+					"onScroll_Callback":options.callbacks.onScroll,
+					"onTotalScroll_Callback":options.callbacks.onTotalScroll,
+					"onTotalScrollBack_Callback":options.callbacks.onTotalScrollBack,
+					"onTotalScroll_Offset":options.callbacks.onTotalScrollOffset,
+					"onTotalScrollBack_Offset":options.callbacks.onTotalScrollBackOffset,
+					"whileScrolling_Callback":options.callbacks.whileScrolling,
+					/*events binding state*/
+					"bindEvent_scrollbar_drag":false,
+					"bindEvent_content_touch":false,
+					"bindEvent_scrollbar_click":false,
+					"bindEvent_mousewheel":false,
+					"bindEvent_buttonsContinuous_y":false,
+					"bindEvent_buttonsContinuous_x":false,
+					"bindEvent_buttonsPixels_y":false,
+					"bindEvent_buttonsPixels_x":false,
+					"bindEvent_focusin":false,
+					"bindEvent_autoHideScrollbar":false,
+					/*buttons intervals*/
+					"mCSB_buttonScrollRight":false,
+					"mCSB_buttonScrollLeft":false,
+					"mCSB_buttonScrollDown":false,
+					"mCSB_buttonScrollUp":false
+				});
+				/*max-width/max-height*/
+				if(options.horizontalScroll){
+					if($this.css("max-width")!=="none"){
+						if(!options.advanced.updateOnContentResize){ /*needs updateOnContentResize*/
+							options.advanced.updateOnContentResize=true;
+						}
+					}
+				}else{
+					if($this.css("max-height")!=="none"){
+						var percentage=false,maxHeight=parseInt($this.css("max-height"));
+						if($this.css("max-height").indexOf("%")>=0){
+							percentage=maxHeight,
+							maxHeight=$this.parent().height()*percentage/100;
+						}
+						$this.css("overflow","hidden");
+						mCustomScrollBox.css("max-height",maxHeight);
+					}
+				}
+				$this.mCustomScrollbar("update");
+				/*window resize fn (for layouts based on percentages)*/
+				if(options.advanced.updateOnBrowserResize){
+					var mCSB_resizeTimeout,currWinWidth=$(window).width(),currWinHeight=$(window).height();
+					$(window).bind("resize."+$this.data("mCustomScrollbarIndex"),function(){
+						if(mCSB_resizeTimeout){
+							clearTimeout(mCSB_resizeTimeout);
+						}
+						mCSB_resizeTimeout=setTimeout(function(){
+							if(!$this.is(".mCS_disabled") && !$this.is(".mCS_destroyed")){
+								var winWidth=$(window).width(),winHeight=$(window).height();
+								if(currWinWidth!==winWidth || currWinHeight!==winHeight){ /*ie8 fix*/
+									if($this.css("max-height")!=="none" && percentage){
+										mCustomScrollBox.css("max-height",$this.parent().height()*percentage/100);
+									}
+									$this.mCustomScrollbar("update");
+									currWinWidth=winWidth; currWinHeight=winHeight;
+								}
+							}
+						},150);
+					});
+				}
+				/*content resize fn (for dynamically generated content)*/
+				if(options.advanced.updateOnContentResize){
+					var mCSB_onContentResize;
+					if(options.horizontalScroll){
+						var mCSB_containerOldSize=mCSB_container.outerWidth();
+					}else{
+						var mCSB_containerOldSize=mCSB_container.outerHeight();
+					}
+					mCSB_onContentResize=setInterval(function(){
+						if(options.horizontalScroll){
+							if(options.advanced.autoExpandHorizontalScroll){
+								mCSB_container.css({"position":"absolute","width":"auto"}).wrap("<div class='mCSB_h_wrapper' style='position:relative; left:0; width:999999px;' />").css({"width":mCSB_container.outerWidth(),"position":"relative"}).unwrap();
+							}
+							var mCSB_containerNewSize=mCSB_container.outerWidth();
+						}else{
+							var mCSB_containerNewSize=mCSB_container.outerHeight();
+						}
+						if(mCSB_containerNewSize!=mCSB_containerOldSize){
+							$this.mCustomScrollbar("update");
+							mCSB_containerOldSize=mCSB_containerNewSize;
+						}
+					},300);
+				}
+			});
+		},
+		update:function(){
+			var $this=$(this),
+				mCustomScrollBox=$this.children(".mCustomScrollBox"),
+				mCSB_container=mCustomScrollBox.children(".mCSB_container");
+			mCSB_container.removeClass("mCS_no_scrollbar");
+			$this.removeClass("mCS_disabled mCS_destroyed");
+			mCustomScrollBox.scrollTop(0).scrollLeft(0); /*reset scrollTop/scrollLeft to prevent browser focus scrolling*/
+			var mCSB_scrollTools=mCustomScrollBox.children(".mCSB_scrollTools"),
+				mCSB_draggerContainer=mCSB_scrollTools.children(".mCSB_draggerContainer"),
+				mCSB_dragger=mCSB_draggerContainer.children(".mCSB_dragger");
+			if($this.data("horizontalScroll")){
+				var mCSB_buttonLeft=mCSB_scrollTools.children(".mCSB_buttonLeft"),
+					mCSB_buttonRight=mCSB_scrollTools.children(".mCSB_buttonRight"),
+					mCustomScrollBoxW=mCustomScrollBox.width();
+				if($this.data("autoExpandHorizontalScroll")){
+					mCSB_container.css({"position":"absolute","width":"auto"}).wrap("<div class='mCSB_h_wrapper' style='position:relative; left:0; width:999999px;' />").css({"width":mCSB_container.outerWidth(),"position":"relative"}).unwrap();
+				}
+				var mCSB_containerW=mCSB_container.outerWidth();
+			}else{
+				var mCSB_buttonUp=mCSB_scrollTools.children(".mCSB_buttonUp"),
+					mCSB_buttonDown=mCSB_scrollTools.children(".mCSB_buttonDown"),
+					mCustomScrollBoxH=mCustomScrollBox.height(),
+					mCSB_containerH=mCSB_container.outerHeight();
+			}
+			if(mCSB_containerH>mCustomScrollBoxH && !$this.data("horizontalScroll")){ /*content needs vertical scrolling*/
+				mCSB_scrollTools.css("display","block");
+				var mCSB_draggerContainerH=mCSB_draggerContainer.height();
+				/*auto adjust scrollbar dragger length analogous to content*/
+				if($this.data("autoDraggerLength")){
+					var draggerH=Math.round(mCustomScrollBoxH/mCSB_containerH*mCSB_draggerContainerH),
+						minDraggerH=mCSB_dragger.data("minDraggerHeight");
+					if(draggerH<=minDraggerH){ /*min dragger height*/
+						mCSB_dragger.css({"height":minDraggerH});
+					}else if(draggerH>=mCSB_draggerContainerH-10){ /*max dragger height*/
+						var mCSB_draggerContainerMaxH=mCSB_draggerContainerH-10;
+						mCSB_dragger.css({"height":mCSB_draggerContainerMaxH});
+					}else{
+						mCSB_dragger.css({"height":draggerH});
+					}
+					mCSB_dragger.children(".mCSB_dragger_bar").css({"line-height":mCSB_dragger.height()+"px"});
+				}
+				var mCSB_draggerH=mCSB_dragger.height(),
+				/*calculate and store scroll amount, add scrolling*/
+					scrollAmount=(mCSB_containerH-mCustomScrollBoxH)/(mCSB_draggerContainerH-mCSB_draggerH);
+				$this.data("scrollAmount",scrollAmount).mCustomScrollbar("scrolling",mCustomScrollBox,mCSB_container,mCSB_draggerContainer,mCSB_dragger,mCSB_buttonUp,mCSB_buttonDown,mCSB_buttonLeft,mCSB_buttonRight);
+				/*scroll*/
+				var mCSB_containerP=Math.abs(mCSB_container.position().top);
+				$this.mCustomScrollbar("scrollTo",mCSB_containerP,{scrollInertia:0,trigger:"internal"});
+			}else if(mCSB_containerW>mCustomScrollBoxW && $this.data("horizontalScroll")){ /*content needs horizontal scrolling*/
+				mCSB_scrollTools.css("display","block");
+				var mCSB_draggerContainerW=mCSB_draggerContainer.width();
+				/*auto adjust scrollbar dragger length analogous to content*/
+				if($this.data("autoDraggerLength")){
+					var draggerW=Math.round(mCustomScrollBoxW/mCSB_containerW*mCSB_draggerContainerW),
+						minDraggerW=mCSB_dragger.data("minDraggerWidth");
+					if(draggerW<=minDraggerW){ /*min dragger height*/
+						mCSB_dragger.css({"width":minDraggerW});
+					}else if(draggerW>=mCSB_draggerContainerW-10){ /*max dragger height*/
+						var mCSB_draggerContainerMaxW=mCSB_draggerContainerW-10;
+						mCSB_dragger.css({"width":mCSB_draggerContainerMaxW});
+					}else{
+						mCSB_dragger.css({"width":draggerW});
+					}
+				}
+				var mCSB_draggerW=mCSB_dragger.width(),
+				/*calculate and store scroll amount, add scrolling*/
+					scrollAmount=(mCSB_containerW-mCustomScrollBoxW)/(mCSB_draggerContainerW-mCSB_draggerW);
+				$this.data("scrollAmount",scrollAmount).mCustomScrollbar("scrolling",mCustomScrollBox,mCSB_container,mCSB_draggerContainer,mCSB_dragger,mCSB_buttonUp,mCSB_buttonDown,mCSB_buttonLeft,mCSB_buttonRight);
+				/*scroll*/
+				var mCSB_containerP=Math.abs(mCSB_container.position().left);
+				$this.mCustomScrollbar("scrollTo",mCSB_containerP,{scrollInertia:0,trigger:"internal"});
+			}else{ /*content does not need scrolling*/
+				/*unbind events, reset content position, hide scrollbars, remove classes*/
+				mCustomScrollBox.unbind("mousewheel focusin");
+				if($this.data("horizontalScroll")){
+					mCSB_dragger.add(mCSB_container).css("left",0);
+				}else{
+					mCSB_dragger.add(mCSB_container).css("top",0);
+				}
+				if ($this.data("alwaysShowScrollbar")) {
+					if(!$this.data("horizontalScroll")){ /*vertical scrolling*/
+						mCSB_dragger.css({"height":mCSB_draggerContainer.height()});
+					}else if($this.data("horizontalScroll")){ /*horizontal scrolling*/
+						mCSB_dragger.css({"width":mCSB_draggerContainer.width()});
+					}
+				} else {
+					mCSB_scrollTools.css("display","none");
+					mCSB_container.addClass("mCS_no_scrollbar");
+				}
+				$this.data({"bindEvent_mousewheel":false,"bindEvent_focusin":false});
+			}
+		},
+		scrolling:function(mCustomScrollBox,mCSB_container,mCSB_draggerContainer,mCSB_dragger,mCSB_buttonUp,mCSB_buttonDown,mCSB_buttonLeft,mCSB_buttonRight){
+			var $this=$(this);
+			/*scrollbar drag scrolling*/
+			if(!$this.data("bindEvent_scrollbar_drag")){
+				var mCSB_draggerDragY,mCSB_draggerDragX,
+					mCSB_dragger_downEvent,mCSB_dragger_moveEvent,mCSB_dragger_upEvent;
+				if($.support.pointer){ /*pointer*/
+					mCSB_dragger_downEvent="pointerdown";
+					mCSB_dragger_moveEvent="pointermove";
+					mCSB_dragger_upEvent="pointerup";
+				}else if($.support.msPointer){ /*MSPointer*/
+					mCSB_dragger_downEvent="MSPointerDown";
+					mCSB_dragger_moveEvent="MSPointerMove";
+					mCSB_dragger_upEvent="MSPointerUp";
+				}
+				if($.support.pointer || $.support.msPointer){ /*pointer, MSPointer*/
+					mCSB_dragger.bind(mCSB_dragger_downEvent,function(e){
+						e.preventDefault();
+						$this.data({"on_drag":true}); mCSB_dragger.addClass("mCSB_dragger_onDrag");
+						var elem=$(this),
+							elemOffset=elem.offset(),
+							x=e.originalEvent.pageX-elemOffset.left,
+							y=e.originalEvent.pageY-elemOffset.top;
+						if(x<elem.width() && x>0 && y<elem.height() && y>0){
+							mCSB_draggerDragY=y;
+							mCSB_draggerDragX=x;
+						}
+					});
+					$(document).bind(mCSB_dragger_moveEvent+"."+$this.data("mCustomScrollbarIndex"),function(e){
+						e.preventDefault();
+						if($this.data("on_drag")){
+							var elem=mCSB_dragger,
+								elemOffset=elem.offset(),
+								x=e.originalEvent.pageX-elemOffset.left,
+								y=e.originalEvent.pageY-elemOffset.top;
+							scrollbarDrag(mCSB_draggerDragY,mCSB_draggerDragX,y,x);
+						}
+					}).bind(mCSB_dragger_upEvent+"."+$this.data("mCustomScrollbarIndex"),function(e){
+						$this.data({"on_drag":false}); mCSB_dragger.removeClass("mCSB_dragger_onDrag");
+					});
+				}else{ /*mouse/touch*/
+					mCSB_dragger.bind("mousedown touchstart",function(e){
+						e.preventDefault(); e.stopImmediatePropagation();
+						var	elem=$(this),elemOffset=elem.offset(),x,y;
+						if(e.type==="touchstart"){
+							var touch=e.originalEvent.touches[0] || e.originalEvent.changedTouches[0];
+							x=touch.pageX-elemOffset.left; y=touch.pageY-elemOffset.top;
+						}else{
+							$this.data({"on_drag":true}); mCSB_dragger.addClass("mCSB_dragger_onDrag");
+							x=e.pageX-elemOffset.left; y=e.pageY-elemOffset.top;
+						}
+						if(x<elem.width() && x>0 && y<elem.height() && y>0){
+							mCSB_draggerDragY=y; mCSB_draggerDragX=x;
+						}
+					}).bind("touchmove",function(e){
+						e.preventDefault(); e.stopImmediatePropagation();
+						var touch=e.originalEvent.touches[0] || e.originalEvent.changedTouches[0],
+							elem=$(this),
+							elemOffset=elem.offset(),
+							x=touch.pageX-elemOffset.left,
+							y=touch.pageY-elemOffset.top;
+						scrollbarDrag(mCSB_draggerDragY,mCSB_draggerDragX,y,x);
+					});
+					$(document).bind("mousemove."+$this.data("mCustomScrollbarIndex"),function(e){
+						if($this.data("on_drag")){
+							var elem=mCSB_dragger,
+								elemOffset=elem.offset(),
+								x=e.pageX-elemOffset.left,
+								y=e.pageY-elemOffset.top;
+							scrollbarDrag(mCSB_draggerDragY,mCSB_draggerDragX,y,x);
+						}
+					}).bind("mouseup."+$this.data("mCustomScrollbarIndex"),function(e){
+						$this.data({"on_drag":false}); mCSB_dragger.removeClass("mCSB_dragger_onDrag");
+					});
+				}
+				$this.data({"bindEvent_scrollbar_drag":true});
+			}
+			function scrollbarDrag(mCSB_draggerDragY,mCSB_draggerDragX,y,x){
+				if($this.data("horizontalScroll")){
+					$this.mCustomScrollbar("scrollTo",(mCSB_dragger.position().left-(mCSB_draggerDragX))+x,{moveDragger:true,trigger:"internal"});
+				}else{
+					$this.mCustomScrollbar("scrollTo",(mCSB_dragger.position().top-(mCSB_draggerDragY))+y,{moveDragger:true,trigger:"internal"});
+				}
+			}
+			/*content touch-drag*/
+			if($.support.touch && $this.data("contentTouchScroll")){
+				if(!$this.data("bindEvent_content_touch")){
+					var touch,
+						elem,elemOffset,y,x,mCSB_containerTouchY,mCSB_containerTouchX;
+					mCSB_container.bind("touchstart",function(e){
+						e.stopImmediatePropagation();
+						touch=e.originalEvent.touches[0] || e.originalEvent.changedTouches[0];
+						elem=$(this);
+						elemOffset=elem.offset();
+						x=touch.pageX-elemOffset.left;
+						y=touch.pageY-elemOffset.top;
+						mCSB_containerTouchY=y;
+						mCSB_containerTouchX=x;
+					});
+					mCSB_container.bind("touchmove",function(e){
+						e.preventDefault(); e.stopImmediatePropagation();
+						touch=e.originalEvent.touches[0] || e.originalEvent.changedTouches[0];
+						elem=$(this).parent();
+						elemOffset=elem.offset();
+						x=touch.pageX-elemOffset.left;
+						y=touch.pageY-elemOffset.top;
+						if($this.data("horizontalScroll")){
+							$this.mCustomScrollbar("scrollTo",mCSB_containerTouchX-x,{trigger:"internal"});
+						}else{
+							$this.mCustomScrollbar("scrollTo",mCSB_containerTouchY-y,{trigger:"internal"});
+						}
+					});
+				}
+			}
+			/*dragger rail click scrolling*/
+			if(!$this.data("bindEvent_scrollbar_click")){
+				mCSB_draggerContainer.bind("click",function(e){
+					var scrollToPos=(e.pageY-mCSB_draggerContainer.offset().top)*$this.data("scrollAmount"),target=$(e.target);
+					if($this.data("horizontalScroll")){
+						scrollToPos=(e.pageX-mCSB_draggerContainer.offset().left)*$this.data("scrollAmount");
+					}
+					if(target.hasClass("mCSB_draggerContainer") || target.hasClass("mCSB_draggerRail")){
+						$this.mCustomScrollbar("scrollTo",scrollToPos,{trigger:"internal",scrollEasing:"draggerRailEase"});
+					}
+				});
+				$this.data({"bindEvent_scrollbar_click":true});
+			}
+			/*mousewheel scrolling*/
+			if($this.data("mouseWheel")){
+				if(!$this.data("bindEvent_mousewheel")){
+					mCustomScrollBox.bind("mousewheel",function(e,delta){
+						var scrollTo,mouseWheelPixels=$this.data("mouseWheelPixels"),absPos=Math.abs(mCSB_container.position().top),
+							draggerPos=mCSB_dragger.position().top,limit=mCSB_draggerContainer.height()-mCSB_dragger.height();
+						if($this.data("normalizeMouseWheelDelta")){
+							if(delta<0){delta=-1;}else{delta=1;}
+						}
+						if(mouseWheelPixels==="auto"){
+							mouseWheelPixels=100+Math.round($this.data("scrollAmount")/2);
+						}
+						if($this.data("horizontalScroll")){
+							draggerPos=mCSB_dragger.position().left; 
+							limit=mCSB_draggerContainer.width()-mCSB_dragger.width();
+							absPos=Math.abs(mCSB_container.position().left);
+						}
+						if((delta>0 && draggerPos!==0) || (delta<0 && draggerPos!==limit)){e.preventDefault(); e.stopImmediatePropagation();}
+						scrollTo=absPos-(delta*mouseWheelPixels);
+						$this.mCustomScrollbar("scrollTo",scrollTo,{trigger:"internal"});
+					});
+					$this.data({"bindEvent_mousewheel":true});
+				}
+			}
+			/*buttons scrolling*/
+			if($this.data("scrollButtons_enable")){
+				if($this.data("scrollButtons_scrollType")==="pixels"){ /*scroll by pixels*/
+					if($this.data("horizontalScroll")){
+						mCSB_buttonRight.add(mCSB_buttonLeft).unbind("mousedown touchstart MSPointerDown pointerdown mouseup MSPointerUp pointerup mouseout MSPointerOut pointerout touchend",mCSB_buttonRight_stop,mCSB_buttonLeft_stop);
+						$this.data({"bindEvent_buttonsContinuous_x":false});
+						if(!$this.data("bindEvent_buttonsPixels_x")){
+							/*scroll right*/
+							mCSB_buttonRight.bind("click",function(e){
+								e.preventDefault();
+								PixelsScrollTo(Math.abs(mCSB_container.position().left)+$this.data("scrollButtons_scrollAmount"));
+							});
+							/*scroll left*/
+							mCSB_buttonLeft.bind("click",function(e){
+								e.preventDefault();
+								PixelsScrollTo(Math.abs(mCSB_container.position().left)-$this.data("scrollButtons_scrollAmount"));
+							});
+							$this.data({"bindEvent_buttonsPixels_x":true});
+						}
+					}else{
+						mCSB_buttonDown.add(mCSB_buttonUp).unbind("mousedown touchstart MSPointerDown pointerdown mouseup MSPointerUp pointerup mouseout MSPointerOut pointerout touchend",mCSB_buttonRight_stop,mCSB_buttonLeft_stop);
+						$this.data({"bindEvent_buttonsContinuous_y":false});
+						if(!$this.data("bindEvent_buttonsPixels_y")){
+							/*scroll down*/
+							mCSB_buttonDown.bind("click",function(e){
+								e.preventDefault();
+								PixelsScrollTo(Math.abs(mCSB_container.position().top)+$this.data("scrollButtons_scrollAmount"));
+							});
+							/*scroll up*/
+							mCSB_buttonUp.bind("click",function(e){
+								e.preventDefault();
+								PixelsScrollTo(Math.abs(mCSB_container.position().top)-$this.data("scrollButtons_scrollAmount"));
+							});
+							$this.data({"bindEvent_buttonsPixels_y":true});
+						}
+					}
+					function PixelsScrollTo(to){
+						if(!mCSB_dragger.data("preventAction")){
+							mCSB_dragger.data("preventAction",true);
+							$this.mCustomScrollbar("scrollTo",to,{trigger:"internal"});
+						}
+					}
+				}else{ /*continuous scrolling*/
+					if($this.data("horizontalScroll")){
+						mCSB_buttonRight.add(mCSB_buttonLeft).unbind("click");
+						$this.data({"bindEvent_buttonsPixels_x":false});
+						if(!$this.data("bindEvent_buttonsContinuous_x")){
+							/*scroll right*/
+							mCSB_buttonRight.bind("mousedown touchstart MSPointerDown pointerdown",function(e){
+								e.preventDefault();
+								var scrollButtonsSpeed=ScrollButtonsSpeed();
+								$this.data({"mCSB_buttonScrollRight":setInterval(function(){
+									$this.mCustomScrollbar("scrollTo",Math.abs(mCSB_container.position().left)+scrollButtonsSpeed,{trigger:"internal",scrollEasing:"easeOutCirc"});
+								},17)});
+							});
+							var mCSB_buttonRight_stop=function(e){
+								e.preventDefault(); clearInterval($this.data("mCSB_buttonScrollRight"));
+							}
+							mCSB_buttonRight.bind("mouseup touchend MSPointerUp pointerup mouseout MSPointerOut pointerout",mCSB_buttonRight_stop);
+							/*scroll left*/
+							mCSB_buttonLeft.bind("mousedown touchstart MSPointerDown pointerdown",function(e){
+								e.preventDefault();
+								var scrollButtonsSpeed=ScrollButtonsSpeed();
+								$this.data({"mCSB_buttonScrollLeft":setInterval(function(){
+									$this.mCustomScrollbar("scrollTo",Math.abs(mCSB_container.position().left)-scrollButtonsSpeed,{trigger:"internal",scrollEasing:"easeOutCirc"});
+								},17)});
+							});	
+							var mCSB_buttonLeft_stop=function(e){
+								e.preventDefault(); clearInterval($this.data("mCSB_buttonScrollLeft"));
+							}
+							mCSB_buttonLeft.bind("mouseup touchend MSPointerUp pointerup mouseout MSPointerOut pointerout",mCSB_buttonLeft_stop);
+							$this.data({"bindEvent_buttonsContinuous_x":true});
+						}
+					}else{
+						mCSB_buttonDown.add(mCSB_buttonUp).unbind("click");
+						$this.data({"bindEvent_buttonsPixels_y":false});
+						if(!$this.data("bindEvent_buttonsContinuous_y")){
+							/*scroll down*/
+							mCSB_buttonDown.bind("mousedown touchstart MSPointerDown pointerdown",function(e){
+								e.preventDefault();
+								var scrollButtonsSpeed=ScrollButtonsSpeed();
+								$this.data({"mCSB_buttonScrollDown":setInterval(function(){
+									$this.mCustomScrollbar("scrollTo",Math.abs(mCSB_container.position().top)+scrollButtonsSpeed,{trigger:"internal",scrollEasing:"easeOutCirc"});
+								},17)});
+							});
+							var mCSB_buttonDown_stop=function(e){
+								e.preventDefault(); clearInterval($this.data("mCSB_buttonScrollDown"));
+							}
+							mCSB_buttonDown.bind("mouseup touchend MSPointerUp pointerup mouseout MSPointerOut pointerout",mCSB_buttonDown_stop);
+							/*scroll up*/
+							mCSB_buttonUp.bind("mousedown touchstart MSPointerDown pointerdown",function(e){
+								e.preventDefault();
+								var scrollButtonsSpeed=ScrollButtonsSpeed();
+								$this.data({"mCSB_buttonScrollUp":setInterval(function(){
+									$this.mCustomScrollbar("scrollTo",Math.abs(mCSB_container.position().top)-scrollButtonsSpeed,{trigger:"internal",scrollEasing:"easeOutCirc"});
+								},17)});
+							});	
+							var mCSB_buttonUp_stop=function(e){
+								e.preventDefault(); clearInterval($this.data("mCSB_buttonScrollUp"));
+							}
+							mCSB_buttonUp.bind("mouseup touchend MSPointerUp pointerup mouseout MSPointerOut pointerout",mCSB_buttonUp_stop);
+							$this.data({"bindEvent_buttonsContinuous_y":true});
+						}
+					}
+					function ScrollButtonsSpeed(){
+						var speed=$this.data("scrollButtons_scrollSpeed");
+						if($this.data("scrollButtons_scrollSpeed")==="auto"){
+							speed=Math.round(($this.data("scrollInertia")+100)/40);
+						}
+						return speed;
+					}
+				}
+			}
+			/*scrolling on element focus (e.g. via TAB key)*/
+			if($this.data("autoScrollOnFocus")){
+				if(!$this.data("bindEvent_focusin")){
+					mCustomScrollBox.bind("focusin",function(){
+						mCustomScrollBox.scrollTop(0).scrollLeft(0);
+						var focusedElem=$(document.activeElement);
+						if(focusedElem.is("input,textarea,select,button,a[tabindex],area,object")){
+							var mCSB_containerPos=mCSB_container.position().top,
+								focusedElemPos=focusedElem.position().top,
+								visibleLimit=mCustomScrollBox.height()-focusedElem.outerHeight();
+							if($this.data("horizontalScroll")){
+								mCSB_containerPos=mCSB_container.position().left;
+								focusedElemPos=focusedElem.position().left;
+								visibleLimit=mCustomScrollBox.width()-focusedElem.outerWidth();
+							}
+							if(mCSB_containerPos+focusedElemPos<0 || mCSB_containerPos+focusedElemPos>visibleLimit){
+								$this.mCustomScrollbar("scrollTo",focusedElemPos,{trigger:"internal"});
+							}
+						}
+					});
+					$this.data({"bindEvent_focusin":true});
+				}
+			}
+			/*auto-hide scrollbar*/
+			if($this.data("autoHideScrollbar") && !$this.data("alwaysShowScrollbar")){
+				if(!$this.data("bindEvent_autoHideScrollbar")){
+					mCustomScrollBox.bind("mouseenter",function(e){
+						mCustomScrollBox.addClass("mCS-mouse-over");
+						functions.showScrollbar.call(mCustomScrollBox.children(".mCSB_scrollTools"));
+					}).bind("mouseleave touchend",function(e){
+						mCustomScrollBox.removeClass("mCS-mouse-over");
+						if(e.type==="mouseleave"){functions.hideScrollbar.call(mCustomScrollBox.children(".mCSB_scrollTools"));}
+					});
+					$this.data({"bindEvent_autoHideScrollbar":true});
+				}
+			}
+		},
+		scrollTo:function(scrollTo,options){
+			var $this=$(this),
+				defaults={
+					moveDragger:false,
+					trigger:"external",
+					callbacks:true,
+					scrollInertia:$this.data("scrollInertia"),
+					scrollEasing:$this.data("scrollEasing")
+				},
+				options=$.extend(defaults,options),
+				draggerScrollTo,
+				mCustomScrollBox=$this.children(".mCustomScrollBox"),
+				mCSB_container=mCustomScrollBox.children(".mCSB_container"),
+				mCSB_scrollTools=mCustomScrollBox.children(".mCSB_scrollTools"),
+				mCSB_draggerContainer=mCSB_scrollTools.children(".mCSB_draggerContainer"),
+				mCSB_dragger=mCSB_draggerContainer.children(".mCSB_dragger"),
+				contentSpeed=draggerSpeed=options.scrollInertia,
+				scrollBeginning,scrollBeginningOffset,totalScroll,totalScrollOffset;
+			if(!mCSB_container.hasClass("mCS_no_scrollbar")){
+				$this.data({"mCS_trigger":options.trigger});
+				if($this.data("mCS_Init")){options.callbacks=false;}
+				if(scrollTo || scrollTo===0){
+					if(typeof(scrollTo)==="number"){ /*if integer, scroll by number of pixels*/
+						if(options.moveDragger){ /*scroll dragger*/
+							draggerScrollTo=scrollTo;
+							if($this.data("horizontalScroll")){
+								scrollTo=mCSB_dragger.position().left*$this.data("scrollAmount");
+							}else{
+								scrollTo=mCSB_dragger.position().top*$this.data("scrollAmount");
+							}
+							draggerSpeed=0;
+						}else{ /*scroll content by default*/
+							draggerScrollTo=scrollTo/$this.data("scrollAmount");
+						}
+					}else if(typeof(scrollTo)==="string"){ /*if string, scroll by element position*/
+						var target;
+						if(scrollTo==="top"){ /*scroll to top*/
+							target=0;
+						}else if(scrollTo==="bottom" && !$this.data("horizontalScroll")){ /*scroll to bottom*/
+							target=mCSB_container.outerHeight()-mCustomScrollBox.height();
+						}else if(scrollTo==="left"){ /*scroll to left*/
+							target=0;
+						}else if(scrollTo==="right" && $this.data("horizontalScroll")){ /*scroll to right*/
+							target=mCSB_container.outerWidth()-mCustomScrollBox.width();
+						}else if(scrollTo==="first"){ /*scroll to first element position*/
+							target=$this.find(".mCSB_container").find(":first");
+						}else if(scrollTo==="last"){ /*scroll to last element position*/
+							target=$this.find(".mCSB_container").find(":last");
+						}else{ /*scroll to element position*/
+							target=$this.find(scrollTo);
+						}
+						if(target.length===1){ /*if such unique element exists, scroll to it*/
+							if($this.data("horizontalScroll")){
+								scrollTo=target.position().left;
+							}else{
+								scrollTo=target.position().top;
+							}
+							draggerScrollTo=scrollTo/$this.data("scrollAmount");
+						}else{
+							draggerScrollTo=scrollTo=target;
+						}
+					}
+					/*scroll to*/
+					if($this.data("horizontalScroll")){
+						if($this.data("onTotalScrollBack_Offset")){ /*scroll beginning offset*/
+							scrollBeginningOffset=-$this.data("onTotalScrollBack_Offset");
+						}
+						if($this.data("onTotalScroll_Offset")){ /*total scroll offset*/
+							totalScrollOffset=mCustomScrollBox.width()-mCSB_container.outerWidth()+$this.data("onTotalScroll_Offset");
+						}
+						if(draggerScrollTo<0){ /*scroll start position*/
+							draggerScrollTo=scrollTo=0; clearInterval($this.data("mCSB_buttonScrollLeft"));
+							if(!scrollBeginningOffset){scrollBeginning=true;}
+						}else if(draggerScrollTo>=mCSB_draggerContainer.width()-mCSB_dragger.width()){ /*scroll end position*/
+							draggerScrollTo=mCSB_draggerContainer.width()-mCSB_dragger.width();
+							scrollTo=mCustomScrollBox.width()-mCSB_container.outerWidth(); clearInterval($this.data("mCSB_buttonScrollRight"));
+							if(!totalScrollOffset){totalScroll=true;}
+						}else{scrollTo=-scrollTo;}
+						var snapAmount = $this.data("snapAmount");
+						if (snapAmount) {
+							scrollTo = Math.round(scrollTo / snapAmount) * snapAmount - $this.data("snapOffset");
+						}
+						/*scrolling animation*/
+						functions.mTweenAxis.call(this,mCSB_dragger[0],"left",Math.round(draggerScrollTo),draggerSpeed,options.scrollEasing);
+						functions.mTweenAxis.call(this,mCSB_container[0],"left",Math.round(scrollTo),contentSpeed,options.scrollEasing,{
+							onStart:function(){
+								if(options.callbacks && !$this.data("mCS_tweenRunning")){callbacks("onScrollStart");}
+								if($this.data("autoHideScrollbar") && !$this.data("alwaysShowScrollbar")){functions.showScrollbar.call(mCSB_scrollTools);}
+							},
+							onUpdate:function(){
+								if(options.callbacks){callbacks("whileScrolling");}
+							},
+							onComplete:function(){
+								if(options.callbacks){
+									callbacks("onScroll");
+									if(scrollBeginning || (scrollBeginningOffset && mCSB_container.position().left>=scrollBeginningOffset)){callbacks("onTotalScrollBack");}
+									if(totalScroll || (totalScrollOffset && mCSB_container.position().left<=totalScrollOffset)){callbacks("onTotalScroll");}
+								}
+								mCSB_dragger.data("preventAction",false); $this.data("mCS_tweenRunning",false);
+								if($this.data("autoHideScrollbar") && !$this.data("alwaysShowScrollbar")){if(!mCustomScrollBox.hasClass("mCS-mouse-over")){functions.hideScrollbar.call(mCSB_scrollTools);}}
+							}
+						});
+					}else{
+						if($this.data("onTotalScrollBack_Offset")){ /*scroll beginning offset*/
+							scrollBeginningOffset=-$this.data("onTotalScrollBack_Offset");
+						}
+						if($this.data("onTotalScroll_Offset")){ /*total scroll offset*/
+							totalScrollOffset=mCustomScrollBox.height()-mCSB_container.outerHeight()+$this.data("onTotalScroll_Offset");
+						}
+						if(draggerScrollTo<0){ /*scroll start position*/
+							draggerScrollTo=scrollTo=0; clearInterval($this.data("mCSB_buttonScrollUp"));
+							if(!scrollBeginningOffset){scrollBeginning=true;}
+						}else if(draggerScrollTo>=mCSB_draggerContainer.height()-mCSB_dragger.height()){ /*scroll end position*/
+							draggerScrollTo=mCSB_draggerContainer.height()-mCSB_dragger.height();
+							scrollTo=mCustomScrollBox.height()-mCSB_container.outerHeight(); clearInterval($this.data("mCSB_buttonScrollDown"));
+							if(!totalScrollOffset){totalScroll=true;}
+						}else{scrollTo=-scrollTo;}
+						var snapAmount = $this.data("snapAmount");
+						if (snapAmount) {
+							scrollTo = Math.round(scrollTo / snapAmount) * snapAmount - $this.data("snapOffset");
+						}
+						/*scrolling animation*/
+						functions.mTweenAxis.call(this,mCSB_dragger[0],"top",Math.round(draggerScrollTo),draggerSpeed,options.scrollEasing);
+						functions.mTweenAxis.call(this,mCSB_container[0],"top",Math.round(scrollTo),contentSpeed,options.scrollEasing,{
+							onStart:function(){
+								if(options.callbacks && !$this.data("mCS_tweenRunning")){callbacks("onScrollStart");}
+								if($this.data("autoHideScrollbar") && !$this.data("alwaysShowScrollbar")){functions.showScrollbar.call(mCSB_scrollTools);}
+							},
+							onUpdate:function(){
+								if(options.callbacks){callbacks("whileScrolling");}
+							},
+							onComplete:function(){
+								if(options.callbacks){
+									callbacks("onScroll");
+									if(scrollBeginning || (scrollBeginningOffset && mCSB_container.position().top>=scrollBeginningOffset)){callbacks("onTotalScrollBack");}
+									if(totalScroll || (totalScrollOffset && mCSB_container.position().top<=totalScrollOffset)){callbacks("onTotalScroll");}
+								}
+								mCSB_dragger.data("preventAction",false); $this.data("mCS_tweenRunning",false);
+								if($this.data("autoHideScrollbar") && !$this.data("alwaysShowScrollbar")){if(!mCustomScrollBox.hasClass("mCS-mouse-over")){functions.hideScrollbar.call(mCSB_scrollTools);}}
+							}
+						});
+					}
+					if($this.data("mCS_Init")){$this.data({"mCS_Init":false});}
+				}
+			}
+			/*callbacks*/
+			function callbacks(cb){
+				if ($this.data("mCustomScrollbarIndex")) {
+					this.mcs = {
+						top: mCSB_container.position().top, left: mCSB_container.position().left,
+						draggerTop: mCSB_dragger.position().top, draggerLeft: mCSB_dragger.position().left,
+						topPct: Math.round((100 * Math.abs(mCSB_container.position().top)) / Math.abs(mCSB_container.outerHeight() - mCustomScrollBox.height())),
+						leftPct: Math.round((100 * Math.abs(mCSB_container.position().left)) / Math.abs(mCSB_container.outerWidth() - mCustomScrollBox.width()))
+					};
+					switch (cb) {
+						/*start scrolling callback*/
+						case "onScrollStart":
+							$this.data("mCS_tweenRunning", true).data("onScrollStart_Callback").call($this, this.mcs);
+							break;
+						case "whileScrolling":
+							$this.data("whileScrolling_Callback").call($this, this.mcs);
+							break;
+						case "onScroll":
+							$this.data("onScroll_Callback").call($this, this.mcs);
+							break;
+						case "onTotalScrollBack":
+							$this.data("onTotalScrollBack_Callback").call($this, this.mcs);
+							break;
+						case "onTotalScroll":
+							$this.data("onTotalScroll_Callback").call($this, this.mcs);
+							break;
+					}
+				}
+			}
+		},
+		stop:function(){
+			var $this=$(this),
+				mCSB_container=$this.children().children(".mCSB_container"),
+				mCSB_dragger=$this.children().children().children().children(".mCSB_dragger");
+			functions.mTweenAxisStop.call(this,mCSB_container[0]);
+			functions.mTweenAxisStop.call(this,mCSB_dragger[0]);
+		},
+		disable:function(resetScroll){
+			var $this=$(this),
+				mCustomScrollBox=$this.children(".mCustomScrollBox"),
+				mCSB_container=mCustomScrollBox.children(".mCSB_container"),
+				mCSB_scrollTools=mCustomScrollBox.children(".mCSB_scrollTools"),
+				mCSB_dragger=mCSB_scrollTools.children().children(".mCSB_dragger");
+			mCustomScrollBox.unbind("mousewheel focusin mouseenter mouseleave touchend");
+			mCSB_container.unbind("touchstart touchmove")
+			if(resetScroll){
+				if($this.data("horizontalScroll")){
+					mCSB_dragger.add(mCSB_container).css("left",0);
+				}else{
+					mCSB_dragger.add(mCSB_container).css("top",0);
+				}
+			}
+			mCSB_scrollTools.css("display","none");
+			mCSB_container.addClass("mCS_no_scrollbar");
+			$this.data({"bindEvent_mousewheel":false,"bindEvent_focusin":false,"bindEvent_content_touch":false,"bindEvent_autoHideScrollbar":false}).addClass("mCS_disabled");
+		},
+		destroy:function(){
+			var $this=$(this);
+			$this.removeClass("mCustomScrollbar _mCS_"+$this.data("mCustomScrollbarIndex")).addClass("mCS_destroyed").children().children(".mCSB_container").unwrap().children().unwrap().siblings(".mCSB_scrollTools").remove();
+			$(document).unbind("mousemove."+$this.data("mCustomScrollbarIndex")+" mouseup."+$this.data("mCustomScrollbarIndex")+" MSPointerMove."+$this.data("mCustomScrollbarIndex")+" MSPointerUp."+$this.data("mCustomScrollbarIndex"));
+			$(window).unbind("resize."+$this.data("mCustomScrollbarIndex"));
+		}
+	},
+	functions={
+		/*hide/show scrollbar*/
+		showScrollbar:function(){
+			this.stop().animate({opacity:1},"fast");
+		},
+		hideScrollbar:function(){
+			this.stop().animate({opacity:0},"fast");
+		},
+		/*js animation tween*/
+		mTweenAxis:function(el,prop,to,duration,easing,callbacks){
+			var callbacks=callbacks || {},
+				onStart=callbacks.onStart || function(){},onUpdate=callbacks.onUpdate || function(){},onComplete=callbacks.onComplete || function(){};
+			var startTime=_getTime(),_delay,progress=0,from=el.offsetTop,elStyle=el.style;
+			if(prop==="left"){from=el.offsetLeft;}
+			var diff=to-from;
+			_cancelTween();
+			_startTween();
+			function _getTime(){
+				if(window.performance && window.performance.now){
+					return window.performance.now();
+				}else{
+					if(window.performance && window.performance.webkitNow){
+						return window.performance.webkitNow();
+					}else{
+						if(Date.now){return Date.now();}else{return new Date().getTime();}
+					}
+				}
+			}
+			function _step(){
+				if(!progress){onStart.call();}
+				progress=_getTime()-startTime;
+				_tween();
+				if(progress>=el._time){
+					el._time=(progress>el._time) ? progress+_delay-(progress- el._time) : progress+_delay-1;
+					if(el._time<progress+1){el._time=progress+1;}
+				}
+				if(el._time<duration){el._id=_request(_step);}else{onComplete.call();}
+			}
+			function _tween(){
+				if(duration>0){
+					el.currVal=_ease(el._time,from,diff,duration,easing);
+					elStyle[prop]=Math.round(el.currVal)+"px";
+				}else{
+					elStyle[prop]=to+"px";
+				}
+				onUpdate.call();
+			}
+			function _startTween(){
+				_delay=1000/60;
+				el._time=progress+_delay;
+				_request=(!window.requestAnimationFrame) ? function(f){_tween(); return setTimeout(f,0.01);} : window.requestAnimationFrame;
+				el._id=_request(_step);
+			}
+			function _cancelTween(){
+				if(el._id==null){return;}
+				if(!window.requestAnimationFrame){clearTimeout(el._id);
+				}else{window.cancelAnimationFrame(el._id);}
+				el._id=null;
+			}
+			function _ease(t,b,c,d,type){
+				switch(type){
+					case "linear":
+						return c*t/d + b;
+						break;
+					case "easeOutQuad":
+						t /= d; return -c * t*(t-2) + b;
+						break;
+					case "easeInOutQuad":
+						t /= d/2;
+						if (t < 1) return c/2*t*t + b;
+						t--;
+						return -c/2 * (t*(t-2) - 1) + b;
+						break;
+					case "easeOutCubic":
+						t /= d; t--; return c*(t*t*t + 1) + b;
+						break;
+					case "easeOutQuart":
+						t /= d; t--; return -c * (t*t*t*t - 1) + b;
+						break;
+					case "easeOutQuint":
+						t /= d; t--; return c*(t*t*t*t*t + 1) + b;
+						break;
+					case "easeOutCirc":
+						t /= d; t--; return c * Math.sqrt(1 - t*t) + b;
+						break;
+					case "easeOutSine":
+						return c * Math.sin(t/d * (Math.PI/2)) + b;
+						break;
+					case "easeOutExpo":
+						return c * ( -Math.pow( 2, -10 * t/d ) + 1 ) + b;
+						break;
+					case "mcsEaseOut":
+						var ts=(t/=d)*t,tc=ts*t;
+						return b+c*(0.499999999999997*tc*ts + -2.5*ts*ts + 5.5*tc + -6.5*ts + 4*t);
+						break;
+					case "draggerRailEase":
+						t /= d/2;
+						if (t < 1) return c/2*t*t*t + b;
+						t -= 2;
+						return c/2*(t*t*t + 2) + b;
+						break;
+				}
+			}
+		},
+		/*stop js animation tweens*/
+		mTweenAxisStop:function(el){
+			if(el._id==null){return;}
+			if(!window.requestAnimationFrame){clearTimeout(el._id);
+			}else{window.cancelAnimationFrame(el._id);}
+			el._id=null;
+		},
+		/*detect requestAnimationFrame and polyfill*/
+		rafPolyfill:function(){
+			var pfx=["ms","moz","webkit","o"],i=pfx.length;
+			while(--i > -1 && !window.requestAnimationFrame){
+				window.requestAnimationFrame=window[pfx[i]+"RequestAnimationFrame"];
+				window.cancelAnimationFrame=window[pfx[i]+"CancelAnimationFrame"] || window[pfx[i]+"CancelRequestAnimationFrame"];
+			}
+		}
+	}
+	/*detect features*/
+	functions.rafPolyfill.call(); /*requestAnimationFrame*/
+	$.support.touch=!!('ontouchstart' in window); /*touch*/
+	$.support.pointer=window.navigator.pointerEnabled; /*pointer support*/
+	$.support.msPointer=window.navigator.msPointerEnabled; /*MSPointer support*/
+	/*plugin dependencies*/
+	var _dlp=("https:"==document.location.protocol) ? "https:" : "http:";
+	$.event.special.mousewheel || document.write('<script src="'+_dlp+'//cdnjs.cloudflare.com/ajax/libs/jquery-mousewheel/3.0.6/jquery.mousewheel.min.js"><\/script>');
+	/*plugin fn*/
+	$.fn.mCustomScrollbar=function(method){
+		if(methods[method]){
+			return methods[method].apply(this,Array.prototype.slice.call(arguments,1));
+		}else if(typeof method==="object" || !method){
+			return methods.init.apply(this,arguments);
+		}else{
+			$.error("Method "+method+" does not exist");
+		}
+	};
+})(jQuery);

+ 84 - 0
src/main/webapp/static/mCustomScrollbar/demo/js/uncompressed/jquery.mousewheel.js

@@ -0,0 +1,84 @@
+/*! Copyright (c) 2011 Brandon Aaron (http://brandonaaron.net)
+ * Licensed under the MIT License (LICENSE.txt).
+ *
+ * Thanks to: http://adomas.org/javascript-mouse-wheel/ for some pointers.
+ * Thanks to: Mathias Bank(http://www.mathias-bank.de) for a scope bug fix.
+ * Thanks to: Seamus Leahy for adding deltaX and deltaY
+ *
+ * Version: 3.0.6
+ * 
+ * Requires: 1.2.2+
+ */
+
+(function($) {
+
+var types = ['DOMMouseScroll', 'mousewheel'];
+
+if ($.event.fixHooks) {
+    for ( var i=types.length; i; ) {
+        $.event.fixHooks[ types[--i] ] = $.event.mouseHooks;
+    }
+}
+
+$.event.special.mousewheel = {
+    setup: function() {
+        if ( this.addEventListener ) {
+            for ( var i=types.length; i; ) {
+                this.addEventListener( types[--i], handler, false );
+            }
+        } else {
+            this.onmousewheel = handler;
+        }
+    },
+    
+    teardown: function() {
+        if ( this.removeEventListener ) {
+            for ( var i=types.length; i; ) {
+                this.removeEventListener( types[--i], handler, false );
+            }
+        } else {
+            this.onmousewheel = null;
+        }
+    }
+};
+
+$.fn.extend({
+    mousewheel: function(fn) {
+        return fn ? this.bind("mousewheel", fn) : this.trigger("mousewheel");
+    },
+    
+    unmousewheel: function(fn) {
+        return this.unbind("mousewheel", fn);
+    }
+});
+
+
+function handler(event) {
+    var orgEvent = event || window.event, args = [].slice.call( arguments, 1 ), delta = 0, returnValue = true, deltaX = 0, deltaY = 0;
+    event = $.event.fix(orgEvent);
+    event.type = "mousewheel";
+    
+    // Old school scrollwheel delta
+    if ( orgEvent.wheelDelta ) { delta = orgEvent.wheelDelta/120; }
+    if ( orgEvent.detail     ) { delta = -orgEvent.detail/3; }
+    
+    // New school multidimensional scroll (touchpads) deltas
+    deltaY = delta;
+    
+    // Gecko
+    if ( orgEvent.axis !== undefined && orgEvent.axis === orgEvent.HORIZONTAL_AXIS ) {
+        deltaY = 0;
+        deltaX = -1*delta;
+    }
+    
+    // Webkit
+    if ( orgEvent.wheelDeltaY !== undefined ) { deltaY = orgEvent.wheelDeltaY/120; }
+    if ( orgEvent.wheelDeltaX !== undefined ) { deltaX = -1*orgEvent.wheelDeltaX/120; }
+    
+    // Add event and delta to the front of the arguments
+    args.unshift(event, delta, deltaX, deltaY);
+    
+    return ($.event.dispatch || $.event.handle).apply(this, args);
+}
+
+})(jQuery);

+ 89 - 0
src/main/webapp/static/mCustomScrollbar/demo/keyboard_nav_example.html

@@ -0,0 +1,89 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		h2{font-family:Georgia,serif; font-size:16px; font-style:italic; color:#eee;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.content{margin:40px; width:260px; height:500px; padding:20px; overflow:auto; background:#333;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>Keyboard navigation (up/down arrows) example</h1>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("#content_1").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					}
+				});
+				$("#content_1").hover(function(){
+					$(document).data({"keyboard-input":"enabled"});
+					$(this).addClass("keyboard-input");
+				},function(){
+					$(document).data({"keyboard-input":"disabled"});
+					$(this).removeClass("keyboard-input");
+				});
+				$(document).keydown(function(e){
+					if($(this).data("keyboard-input")==="enabled"){
+						var activeElem=$(".keyboard-input"),
+							activeElemPos=Math.abs($(".keyboard-input .mCSB_container").position().top),
+							pixelsToScroll=60;
+						if(e.which===38){ //scroll up
+							e.preventDefault();
+							if(pixelsToScroll>activeElemPos){
+								activeElem.mCustomScrollbar("scrollTo","top");
+							}else{
+								activeElem.mCustomScrollbar("scrollTo",(activeElemPos-pixelsToScroll),{scrollInertia:400,scrollEasing:"easeOutCirc"});
+							}
+						}else if(e.which===40){ //scroll down
+							e.preventDefault();
+							activeElem.mCustomScrollbar("scrollTo",(activeElemPos+pixelsToScroll),{scrollInertia:400,scrollEasing:"easeOutCirc"});
+						}
+					}
+				});
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

+ 66 - 0
src/main/webapp/static/mCustomScrollbar/demo/loading_each_script_separately.html

@@ -0,0 +1,66 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.content{margin:40px; width:260px; height:500px; padding:20px; overflow:auto; background:#333; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>Default scrollbar with scroll buttons</h1>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- CloudFlare CDN mousewheel plugin with fallback to local -->
+	<script src="http://cdnjs.cloudflare.com/ajax/libs/jquery-mousewheel/3.0.6/jquery.mousewheel.min.js"></script>
+	<script>$.event.special.mousewheel || document.write('<script src="js/minified/jquery.mousewheel.min.js"><\/script>')</script>
+	<!-- custom scrollbars plugin -->
+	<script src="js/minified/jquery.mCustomScrollbar.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("#content_1").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					}
+				});
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

BIN
src/main/webapp/static/mCustomScrollbar/demo/mCSB_buttons.png


+ 67 - 0
src/main/webapp/static/mCustomScrollbar/demo/max-height_example.html

@@ -0,0 +1,67 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.output{margin:20px 40px;}
+		.output a{display:inline-block; text-decoration:none; padding:3px 15px; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px; background:#000; margin:5px 20px 5px 0;}
+		code{color:#5b70ff;}
+		.content{margin:40px; width:260px; max-height:380px; padding:20px; overflow:auto; background:#333; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>CSS max-height example</h1>
+	<p class="output"><a href="#" id="add-content">Add content</a> <a href="#" id="remove-content">Remove content</a></p>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<p><code>max-height</code> set to <code>380px</code>.</p>
+   		<p>Lorem ipsum dolor sit amet. Nullam felis tellus, tristique nec egestas in suspendisse potenti. Cras venenatis condimentum nibh a mollis.</p>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("#content_1").mCustomScrollbar();
+				/*demo fn*/
+				$("#add-content").click(function(e){
+					e.preventDefault();
+					$("#content_1 .mCSB_container").append("<p>Lorem ipsum dolor sit amet. Consectetur adipiscing elit. Fusce adipiscing dui eu metus gravida.</p>");
+					$("#content_1").mCustomScrollbar("update");
+				});
+				$("#remove-content").click(function(e){
+					e.preventDefault();
+					$("#content_1 .mCSB_container p:last").remove();
+					$("#content_1").mCustomScrollbar("update");
+				});
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

+ 76 - 0
src/main/webapp/static/mCustomScrollbar/demo/max-width_example.html

@@ -0,0 +1,76 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.output{margin:20px 40px;}
+		.output a{display:inline-block; text-decoration:none; padding:3px 15px; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px; background:#000; margin:5px 20px 5px 0;}
+		code{color:#5b70ff;}
+		.content{margin:40px; max-width:30%; height:140px; padding:20px; overflow:auto; background:#333; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px;}
+		.content .content-wrapper{overflow:hidden;}
+		.content p{width:180px; height:100px; float:left; margin:0 20px; padding:5px 10px; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px; background: #404040;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>CSS max-width example</h1>
+	<p class="output"><a href="#" id="add-content">Add content</a> <a href="#" id="remove-content">Remove content</a></p>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<div class="content-wrapper">
+			<p><code>max-width</code> set to <code>30%</code>. <br />Lorem ipsum dolor sit amet. Aliquam erat volutpat.</p>
+		</div>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("#content_1").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					},
+					horizontalScroll:true,
+					advanced:{autoExpandHorizontalScroll:true,updateOnContentResize:false}
+				});
+				/*demo fn*/
+				$("#add-content").click(function(e){
+					e.preventDefault();
+					$("#content_1 .content-wrapper").append("<p>Lorem ipsum dolor sit amet. Consectetur adipiscing elit. Donec egestas mi turpis. </p>");
+					$("#content_1").mCustomScrollbar("update");
+				});
+				$("#remove-content").click(function(e){
+					e.preventDefault();
+					$("#content_1 .content-wrapper p:last").remove();
+					$("#content_1").mCustomScrollbar("update");
+				});
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

Diferenças do arquivo suprimidas por serem muito extensas
+ 75 - 0
src/main/webapp/static/mCustomScrollbar/demo/multiple_scrollbars_example.html


Diferenças do arquivo suprimidas por serem muito extensas
+ 129 - 0
src/main/webapp/static/mCustomScrollbar/demo/nested_scrollbars_demo.html


Diferenças do arquivo suprimidas por serem muito extensas
+ 116 - 0
src/main/webapp/static/mCustomScrollbar/demo/nested_scrollbars_demo_alt.html


+ 109 - 0
src/main/webapp/static/mCustomScrollbar/demo/nested_scrollbars_demo_alt_2.html

@@ -0,0 +1,109 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.output{margin:20px 40px;}
+		.output a{display:inline-block; text-decoration:none; padding:3px 15px; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px; background:#000; margin:5px 20px 5px 0;}
+		code{color:#5b70ff;}
+		.content{-moz-box-sizing:border-box; -webkit-box-sizing:border-box; box-sizing:border-box;}
+		.content p{min-height:320px;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+		#content-1{overflow:hidden; height:410px; padding:20px; width:100%;}
+		#content-1 p{float:left; width:300px; min-width:100px; margin-right:10px; background:rgba(0,0,0,0.3); padding:10px; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px;}
+		#content-1 p:last-child{width:auto; margin-right:0;}
+		#content-1 .content{background:#252525; width:300px; height:340px; padding:20px; overflow:auto; background:#333; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px; float:left; margin-right:10px;}
+		#content-1 .content p{float:none; width:auto; margin-right:0; min-height:auto;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>Nested custom scrollbars</h1>
+	<!-- content block -->
+	<div id="content-1" class="content">
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam sed massa felis, aliquam pellentesque est.</p>
+   		<!-- nested content block -->
+		<div class="content inner">
+			<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+	   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+	   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa.</p>
+	   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl.</p> 
+			<p>Etiam sed massa felis, aliquam pellentesque est. Aliquam consequat turpis id velit egestas a posuere orci semper.</p>
+	    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla.</p> 
+			<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+			<p>Congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor.</p>
+	    	<p>the end.</p>
+		</div>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<!-- nested content block -->
+		<div class="content inner">
+			<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+	   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+	   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa.</p>
+	   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl.</p> 
+			<p>Etiam sed massa felis, aliquam pellentesque est. Aliquam consequat turpis id velit egestas a posuere orci semper.</p>
+	    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla.</p> 
+			<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+			<p>Congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor.</p>
+	    	<p>the end.</p>
+		</div>
+		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<!-- nested content block -->
+		<div class="content inner">
+			<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+	   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+	   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa.</p>
+	   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl.</p> 
+			<p>Etiam sed massa felis, aliquam pellentesque est. Aliquam consequat turpis id velit egestas a posuere orci semper.</p>
+	    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla.</p> 
+			<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+			<p>Congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor.</p>
+	    	<p>the end.</p>
+		</div>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo.</p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci.</p>
+    	<p>the end.</p>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("#content-1").mCustomScrollbar({
+					horizontalScroll:true
+				});
+				$(".content.inner").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					}
+				});
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

+ 120 - 0
src/main/webapp/static/mCustomScrollbar/demo/scroll_buttons_and_snap_scrolling_examples.html

@@ -0,0 +1,120 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.output{margin:20px 40px;}
+		code{color:#5b70ff;}
+		.content{margin:40px; width:580px; height:90px; padding:10px; overflow:auto; background:#444; -webkit-border-radius:2px; -moz-border-radius:2px; border-radius:2px;}
+		.content .images_container{overflow:hidden;}
+		.content .images_container img{display:block; float:left; margin:0 5px; border:5px solid #777;}
+		a[rel='toggle-buttons-scroll-type']{display:inline-block; text-decoration:none; padding:3px 15px; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px; background:#000; margin:5px 20px 5px 0;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>Example of snap scrolling to images</h1>
+	<p class="output"><a href="#" rel="toggle-buttons-scroll-type"></a></p>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<div class="images_container">
+			<img src="demo_files/mcsThumb1.jpg" />
+			<img src="demo_files/mcsThumb2.jpg" />
+			<img src="demo_files/mcsThumb3.jpg" />
+			<img src="demo_files/mcsThumb4.jpg" />
+			<img src="demo_files/mcsThumb5.jpg" />
+			<img src="demo_files/mcsThumb6.jpg" />
+			<img src="demo_files/mcsThumb7.jpg" />
+			<img src="demo_files/mcsThumb8.jpg" />
+			<img src="demo_files/mcsThumb1.jpg" />
+			<img src="demo_files/mcsThumb2.jpg" />
+			<img src="demo_files/mcsThumb3.jpg" />
+			<img src="demo_files/mcsThumb4.jpg" />
+			<img src="demo_files/mcsThumb5.jpg" />
+			<img src="demo_files/mcsThumb6.jpg" />
+			<img src="demo_files/mcsThumb7.jpg" />
+			<img src="demo_files/mcsThumb8.jpg" />
+		</div>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("#content_1").mCustomScrollbar({
+					scrollInertia:550,
+					horizontalScroll:true,
+					mouseWheelPixels:116,
+					scrollButtons:{
+						enable:true,
+						scrollType:"pixels",
+						scrollAmount:116
+					},
+					callbacks:{
+						onScroll:function(){ snapScrollbar(); }
+					}
+				});
+				/* toggle buttons scroll type */
+				var content=$("#content_1");
+				$("a[rel='toggle-buttons-scroll-type']").html("<code>scrollType: \""+content.data("scrollButtons_scrollType")+"\"</code>");
+				$("a[rel='toggle-buttons-scroll-type']").click(function(e){
+					e.preventDefault();
+					var scrollType;
+					if(content.data("scrollButtons_scrollType")==="pixels"){
+						scrollType="continuous";
+					}else{
+						scrollType="pixels";
+					}
+					content.data({"scrollButtons_scrollType":scrollType}).mCustomScrollbar("update");
+					$(this).html("<code>scrollType: \""+content.data("scrollButtons_scrollType")+"\"</code>");
+				});
+				/* snap scrollbar fn */
+				var snapTo=[];
+				$("#content_1 .images_container img").each(function(){
+					var $this=$(this),thisX=$this.position().left;
+					snapTo.push(thisX);
+				});
+				function snapScrollbar(){
+					var posX=$("#content_1 .mCSB_container").position().left,closestX=findClosest(Math.abs(posX),snapTo);
+					$("#content_1").mCustomScrollbar("scrollTo",closestX,{scrollInertia:350,callbacks:false});
+				}
+				function findClosest(num,arr){
+	                var curr=arr[0];
+    	            var diff=Math.abs(num-curr);
+        	        for(var val=0; val<arr.length; val++){
+            	        var newdiff=Math.abs(num-arr[val]);
+                	    if(newdiff<diff){
+                    	    diff=newdiff;
+                        	curr=arr[val];
+                    	}
+                	}
+                	return curr;
+            	}
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

+ 213 - 0
src/main/webapp/static/mCustomScrollbar/demo/scrollbar_themes_demo.html

@@ -0,0 +1,213 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		h2{font-family:Georgia,serif; font-size:18px; font-style:italic;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.content{margin:0 0 40px 40px; width:260px; height:480px; padding:20px; overflow:auto; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px; float:left;}
+		.content p:nth-child(even){font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		#content_1{background:#333;}
+		#content_1 p:nth-child(even){color:#999;}
+		#content_2{color:#333; background:#eee;}
+		#content_2 p:nth-child(even){color:#666;}
+		#content_3{background:#555;}
+		#content_3 p:nth-child(even){color:#ccc;}
+		#content_4{color:#222; background:#eadc8e;}
+		#content_4 p:nth-child(even){color:#444;}
+		#content_5{background:#eb3755;}
+		#content_5 p:nth-child(even){color:#ddd;}
+		#content_6{color:#333; background:#fff;}
+		#content_6 p:nth-child(even){color:#666;}
+		#content_7{background:#000;}
+		#content_7 p:nth-child(even){color:#ccc;}
+		#content_8{color:#222; background:#26beff;}
+		#content_8 p:nth-child(even){color:#444;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>Scrollbar themes</h1>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<h2>Theme: light (default)</h2>
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<!-- content block -->
+	<div id="content_2" class="content">
+		<h2>Theme: dark</h2>
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<!-- content block -->
+	<div id="content_3" class="content">
+		<h2>Theme: light-2</h2>
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<!-- content block -->
+	<div id="content_4" class="content">
+		<h2>Theme: dark-2</h2>
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<!-- content block -->
+	<div id="content_5" class="content">
+		<h2>Theme: light-thick</h2>
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<!-- content block -->
+	<div id="content_6" class="content">
+		<h2>Theme: dark-thick</h2>
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<!-- content block -->
+	<div id="content_7" class="content">
+		<h2>Theme: light-thin</h2>
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<!-- content block -->
+	<div id="content_8" class="content">
+		<h2>Theme: dark-thin</h2>
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("#content_1").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					}
+				});
+				$("#content_2").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					},
+					theme:"dark"
+				});
+				$("#content_3").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					},
+					theme:"light-2"
+				});
+				$("#content_4").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					},
+					theme:"dark-2"
+				});
+				$("#content_5").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					},
+					theme:"light-thick"
+				});
+				$("#content_6").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					},
+					theme:"dark-thick"
+				});
+				$("#content_7").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					},
+					theme:"light-thin"
+				});
+				$("#content_8").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					},
+					theme:"dark-thin"
+				});
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

+ 63 - 0
src/main/webapp/static/mCustomScrollbar/demo/simple_example.html

@@ -0,0 +1,63 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.content{margin:40px; width:260px; height:500px; padding:20px; overflow:auto; background:#333; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>Default scrollbar with scroll buttons</h1>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("#content_1").mCustomScrollbar({
+					scrollButtons:{
+						enable:true
+					}
+				});
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

+ 92 - 0
src/main/webapp/static/mCustomScrollbar/demo/simple_example_all_params.html

@@ -0,0 +1,92 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.content{margin:40px; width:260px; height:500px; padding:20px; overflow:auto; background:#333; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px;}
+		.content p:nth-child(even){color:#999; font-family:Georgia,serif; font-size:17px; font-style:italic;}
+		.content p:nth-child(3n+0){color:#c96;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>Default scrollbar</h1>
+	<!-- content block -->
+	<div id="content_1" class="content">
+		<p>Lorem ipsum dolor sit amet. Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit.</p>
+   		<p>Aliquam erat volutpat. Maecenas non tortor nulla, non malesuada velit. Nullam felis tellus, tristique nec egestas in, luctus sed diam. Suspendisse potenti. </p>
+   		<p>Consectetur adipiscing elit. Nulla consectetur libero consectetur quam consequat nec tincidunt massa feugiat. Donec egestas mi turpis. Fusce adipiscing dui eu metus gravida vel facilisis ligula iaculis. Cras a rhoncus massa. Donec sed purus eget nunc placerat consequat.</p>
+   		<p>Cras venenatis condimentum nibh a mollis. Duis id sapien nibh. Vivamus porttitor, felis quis blandit tincidunt, erat magna scelerisque urna, a faucibus erat nisl eget nisl. Aliquam consequat turpis id velit egestas a posuere orci semper. Mauris suscipit erat quis urna adipiscing ultricies. In hac habitasse platea dictumst. Nulla scelerisque lorem quis dui sagittis egestas.</p> 
+		<p>Etiam sed massa felis, aliquam pellentesque est.</p>
+    	<p>Nam eu arcu at purus tincidunt pharetra ultrices at ipsum. Mauris urna nunc, vulputate quis gravida in, pharetra id mauris. Ut sit amet mi dictum nulla lobortis adipiscing quis a nulla. Etiam diam ante, imperdiet vel scelerisque eget, venenatis non eros. Praesent ipsum sem, eleifend ut gravida eget, tristique id orci. Nam adipiscing, sem in mattis vulputate, risus libero adipiscing risus, eu molestie mi justo eget nulla.</p> 
+		<p>Cras venenatis metus et urna egestas non laoreet orci rutrum. Pellentesque ullamcorper dictum nisl a tincidunt. Quisque et lacus quam, sed hendrerit mi. Mauris pretium, sapien et malesuada pulvinar, lorem leo viverra leo, et egestas mi nisl quis odio. </p>
+		<p>Aliquam erat volutpat. Sed urna arcu, tempus eu vulputate adipiscing, consectetur et orci. Vivamus congue, nunc vitae fringilla convallis, libero massa lacinia lorem, id convallis mauris elit ut leo. Nulla vel odio sem. Duis lorem urna, congue vitae rutrum sed, tincidunt vel tortor. In hac habitasse platea dictumst. Nunc vitae enim ante, vitae facilisis massa. Etiam sagittis sapien at nibh fermentum consectetur convallis lacus blandit.</p>
+    	<p>the end.</p>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				$("#content_1").mCustomScrollbar({
+					set_width:false, /*optional element width: boolean, pixels, percentage*/
+					set_height:false, /*optional element height: boolean, pixels, percentage*/
+					horizontalScroll:false, /*scroll horizontally: boolean*/
+					scrollInertia:950, /*scrolling inertia: integer (milliseconds)*/
+					mouseWheel:true, /*mousewheel support: boolean*/
+					mouseWheelPixels:"auto", /*mousewheel pixels amount: integer, "auto"*/
+					autoDraggerLength:true, /*auto-adjust scrollbar dragger length: boolean*/
+					autoHideScrollbar:false, /*auto-hide scrollbar when idle*/
+					scrollButtons:{ /*scroll buttons*/
+						enable:false, /*scroll buttons support: boolean*/
+						scrollType:"continuous", /*scroll buttons scrolling type: "continuous", "pixels"*/
+						scrollSpeed:"auto", /*scroll buttons continuous scrolling speed: integer, "auto"*/
+						scrollAmount:40 /*scroll buttons pixels scroll amount: integer (pixels)*/
+					},
+					advanced:{
+						updateOnBrowserResize:true, /*update scrollbars on browser resize (for layouts based on percentages): boolean*/
+						updateOnContentResize:false, /*auto-update scrollbars on content resize (for dynamic content): boolean*/
+						autoExpandHorizontalScroll:false, /*auto-expand width for horizontal scrolling: boolean*/
+						autoScrollOnFocus:true, /*auto-scroll on focused elements: boolean*/
+						normalizeMouseWheelDelta:false /*normalize mouse-wheel delta (-1/1)*/
+					},
+					contentTouchScroll:true, /*scrolling by touch-swipe content: boolean*/
+					callbacks:{
+						onScrollStart:function(){}, /*user custom callback function on scroll start event*/
+						onScroll:function(){}, /*user custom callback function on scroll event*/
+						onTotalScroll:function(){}, /*user custom callback function on scroll end reached event*/
+						onTotalScrollBack:function(){}, /*user custom callback function on scroll begin reached event*/
+						onTotalScrollOffset:0, /*scroll end reached offset: integer (pixels)*/
+						onTotalScrollBackOffset:0, /*scroll begin reached offset: integer (pixels)*/
+						whileScrolling:function(){} /*user custom callback function on scrolling event*/
+					},
+					theme:"light" /*"light", "dark", "light-2", "dark-2", "light-thick", "dark-thick", "light-thin", "dark-thin"*/
+				});
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

BIN
src/main/webapp/static/mCustomScrollbar/demo/source_files/mCSB_buttons.psd


+ 103 - 0
src/main/webapp/static/mCustomScrollbar/demo/textarea_example.html

@@ -0,0 +1,103 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+	<meta charset="utf-8">
+	<meta name="viewport" content="width=device-width, initial-scale=1.0">
+	<title>jQuery custom scrollbar demo</title>
+	<!-- style for demo and examples -->
+	<style>
+		body{margin:0; padding:0; color:#eee; background:#222; font-family:Verdana,Geneva,sans-serif; font-size:13px; line-height:20px;}
+		a:link,a:visited,a:hover{color:inherit;}
+		h1{font-family:Georgia,serif; font-size:18px; font-style:italic; margin:40px; color:#26beff;}
+		h2{font-family:Georgia,serif; font-size:16px; font-style:italic; color:#eee;}
+		p{margin:0 0 20px 0;}
+		hr{height:0; border:none; border-bottom:1px solid rgba(255,255,255,0.13); border-top:1px solid rgba(0,0,0,1); margin:9px 10px; clear:both;}
+		.links{margin:10px;}
+		.links a{display:inline-block; padding:3px 15px; margin:7px 10px; background:#444; text-decoration:none; -webkit-border-radius:15px; -moz-border-radius:15px; border-radius:15px;}
+		.links a:hover{background:#eb3755; color:#fff;}
+		.content{margin:40px; width:260px; padding:20px; background:#333;}
+		.content textarea{width:210px; height:140px; border:none; background:transparent; resize:none; margin:0; padding:0 0 0 10px; overflow:hidden; line-height:20px; font-family: Arial, sans-serif; font-size: 13px; margin:5px 0; outline:none; color:#ccc;}
+		.content .textarea-wrapper{height:162px; overflow:hidden; border:1px solid #666; -webkit-border-radius:5px; -moz-border-radius:5px; border-radius:5px; -webkit-box-shadow:inset 0 0 40px rgba(0,0,0,0.5); -moz-box-shadow:inset 0 0 40px rgba(0,0,0,0.5); box-shadow:inset 0 0 40px rgba(0,0,0,0.5);}
+		.hiddendiv{position:absolute; top:-9999px; left:-9999px; visibility:hidden; white-space: pre-wrap; width: 210px; min-height: 140px; font-family: Arial, sans-serif; font-size: 13px; padding:0 0 0 10px; word-wrap: break-word;}
+		.mCSB_scrollTools{box-sizing:border-box; padding:5px 0;}
+		.mCSB_scrollTools .mCSB_draggerContainer{margin:5px 0;}
+	</style>
+	<!-- Custom scrollbars CSS -->
+	<link href="jquery.mCustomScrollbar.css" rel="stylesheet" />
+</head>
+<body>
+	<p class="links">
+		<a href="http://manos.malihu.gr">malihu</a>
+		<a href="http://manos.malihu.gr/jquery-custom-content-scroller">Plugin home</a>
+		<a href="complete_examples.html">Plugin demo</a>
+	</p>
+	<hr />
+	<h1>Textarea with custom scrollbar</h1>
+	<!-- content block -->
+	<div class="content">
+		<form>
+			<textarea></textarea>
+		</form>
+	</div>
+	<hr />
+	<p>&nbsp;</p>
+	<!-- Google CDN jQuery with fallback to local -->
+	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+	<script>!window.jQuery && document.write(unescape('%3Cscript src="js/minified/jquery-1.9.1.min.js"%3E%3C/script%3E'))</script>
+	<!-- custom scrollbars plugin -->
+	<script src="jquery.mCustomScrollbar.concat.min.js"></script>
+	<script>
+		(function($){
+			$(window).load(function(){
+				var textArea=$(".content textarea");
+				textArea.wrap("<div class='textarea-wrapper' />");
+				var textAreaWrapper=textArea.parent(".textarea-wrapper");
+				textAreaWrapper.mCustomScrollbar({
+					scrollInertia:0,
+					advanced:{autoScrollOnFocus:false}
+				});
+				var hiddenDiv=$(document.createElement("div")),
+        			content=null;
+    			hiddenDiv.addClass("hiddendiv");
+    			$("body").prepend(hiddenDiv);
+    			textArea.bind("keyup",function(e){
+        			content=$(this).val();
+					var clength=content.length;
+        			var cursorPosition=textArea.getCursorPosition();
+					content="<span>"+content.substr(0,cursorPosition)+"</span>"+content.substr(cursorPosition,content.length);
+					content=content.replace(/\n/g,"<br />");
+        			hiddenDiv.html(content+"<br />");
+        			$(this).css("height",hiddenDiv.height());
+					textAreaWrapper.mCustomScrollbar("update");
+					var hiddenDivSpan=hiddenDiv.children("span"),
+						hiddenDivSpanOffset=0,
+						viewLimitBottom=(parseInt(hiddenDiv.css("min-height")))-hiddenDivSpanOffset,
+						viewLimitTop=hiddenDivSpanOffset,
+						viewRatio=Math.round(hiddenDivSpan.height()+textAreaWrapper.find(".mCSB_container").position().top);
+					if(viewRatio>viewLimitBottom || viewRatio<viewLimitTop){
+						if((hiddenDivSpan.height()-hiddenDivSpanOffset)>0){
+							textAreaWrapper.mCustomScrollbar("scrollTo",hiddenDivSpan.height()-hiddenDivSpanOffset);
+						}else{
+							textAreaWrapper.mCustomScrollbar("scrollTo","top");
+						}
+					}
+    			});
+				$.fn.getCursorPosition=function(){
+        			var el=$(this).get(0),
+						pos=0;
+        			if("selectionStart" in el){
+            			pos=el.selectionStart;
+        			}else if("selection" in document){
+            			el.focus();
+            			var sel=document.selection.createRange(),
+							selLength=document.selection.createRange().text.length;
+            			sel.moveStart("character",-el.value.length);
+            			pos=sel.text.length-selLength;
+        			}
+        			return pos;
+    			}
+			});
+		})(jQuery);
+	</script>
+</body>
+</html>

Diferenças do arquivo suprimidas por serem muito extensas
+ 4 - 0
src/main/webapp/static/mCustomScrollbar/jquery.mCustomScrollbar.concat.min.js


+ 0 - 0
src/main/webapp/static/mCustomScrollbar/jquery.mCustomScrollbar.css


Alguns arquivos não foram mostrados porque muitos arquivos mudaram nesse diff