1
0
Alien 12 жил өмнө
parent
commit
d1a3f24e24
100 өөрчлөгдсөн 0 нэмэгдсэн , 4304 устгасан
  1. 0 29
      ReadMe.txt
  2. 0 638
      _locales/zh_CN/messages.json
  3. 0 32
      build.sh
  4. 0 54
      config.php
  5. 0 82
      manifest.json
  6. 0 63
      online.manifest.json
  7. BIN
      output/fe-helper.zip
  8. 0 638
      output/fe-helper/_locales/zh_CN/messages.json
  9. 0 63
      output/fe-helper/manifest.json
  10. 0 1
      output/fe-helper/static/css/fe-endecode.css
  11. 0 1
      output/fe-helper/static/css/fe-endecode_datauri.css
  12. 0 1
      output/fe-helper/static/css/fe-fdp.css
  13. 0 0
      output/fe-helper/static/css/fe-helper.css
  14. 0 0
      output/fe-helper/static/css/fe-jsonformat.css
  15. 0 0
      output/fe-helper/static/css/fe-jsonformat_datauri.css
  16. 0 1
      output/fe-helper/static/css/fe-opt.css
  17. 0 1
      output/fe-helper/static/css/fe-popup.css
  18. 0 1
      output/fe-helper/static/css/fe-qrcode.css
  19. 0 1
      output/fe-helper/static/css/fe-qrcode_datauri.css
  20. BIN
      output/fe-helper/static/img/43.png
  21. BIN
      output/fe-helper/static/img/baidufe_bj.gif
  22. BIN
      output/fe-helper/static/img/fe-128.png
  23. BIN
      output/fe-helper/static/img/fe-16.png
  24. BIN
      output/fe-helper/static/img/fe-48.png
  25. BIN
      output/fe-helper/static/img/grid.png
  26. BIN
      output/fe-helper/static/img/pbar-ani.gif
  27. BIN
      output/fe-helper/static/img/ui-icons_228ef1_256x240.png
  28. 0 1
      output/fe-helper/static/js/core/core.js
  29. 0 0
      output/fe-helper/static/js/core/fe-const.js
  30. 0 15
      output/fe-helper/static/js/core/jquery-1.5.min.js
  31. 0 1
      output/fe-helper/static/js/core/log.js
  32. 0 1
      output/fe-helper/static/js/core/network.js
  33. 0 0
      output/fe-helper/static/js/endecode/endecode-lib.js
  34. 0 1
      output/fe-helper/static/js/endecode/endecode.js
  35. 0 0
      output/fe-helper/static/js/endecode/md5.js
  36. 0 0
      output/fe-helper/static/js/fcp/css/fcp-css-analytic.js
  37. 0 0
      output/fe-helper/static/js/fcp/css/fcp-css.js
  38. 0 1
      output/fe-helper/static/js/fcp/fcp-fl.js
  39. 0 0
      output/fe-helper/static/js/fcp/fcp-main.js
  40. 0 0
      output/fe-helper/static/js/fcp/fcp-tabs.js
  41. 0 0
      output/fe-helper/static/js/fcp/html/fcp-html-analytic.js
  42. 0 0
      output/fe-helper/static/js/fcp/html/fcp-html-doctype.js
  43. 0 0
      output/fe-helper/static/js/fcp/html/fcp-html.js
  44. 0 0
      output/fe-helper/static/js/fcp/js/fcp-js-analytic.js
  45. 0 0
      output/fe-helper/static/js/fcp/js/fcp-js.js
  46. 0 0
      output/fe-helper/static/js/fdp/fdp-main.js
  47. 0 0
      output/fe-helper/static/js/fe-background.js
  48. 0 1
      output/fe-helper/static/js/fe-helper.js
  49. 0 1
      output/fe-helper/static/js/fe-option.js
  50. 0 1
      output/fe-helper/static/js/fe-popup.js
  51. 0 1
      output/fe-helper/static/js/google_analytics.js
  52. 0 0
      output/fe-helper/static/js/grid/grid-main.js
  53. 0 1
      output/fe-helper/static/js/jsonformat/fe-jsonformat.js
  54. 0 0
      output/fe-helper/static/js/jsonformat/json-format-dealer.js
  55. 0 0
      output/fe-helper/static/js/jsonformat/json-format-ent.js
  56. 0 0
      output/fe-helper/static/js/mod/mod_background.js
  57. 0 0
      output/fe-helper/static/js/mod/mod_endecode.js
  58. 0 0
      output/fe-helper/static/js/mod/mod_fdp.js
  59. 0 0
      output/fe-helper/static/js/mod/mod_jsonformat.js
  60. 0 0
      output/fe-helper/static/js/mod/mod_manifest.js
  61. 0 0
      output/fe-helper/static/js/mod/mod_options.js
  62. 0 0
      output/fe-helper/static/js/mod/mod_popup.js
  63. 0 0
      output/fe-helper/static/js/mod/mod_qrcode.js
  64. 0 1
      output/fe-helper/static/js/notification/fe-notification.js
  65. 0 1
      output/fe-helper/static/js/qrcode/fe-qrcode.js
  66. 0 1
      output/fe-helper/static/js/wpo/fe-calc-wpo.js
  67. 0 1
      output/fe-helper/static/js/wpo/fe-wpo.js
  68. 0 0
      output/fe-helper/static/vendor/jquery-ui-1.8/css/jquery-ui-1.8.16.custom.blue_datauri.css
  69. 0 0
      output/fe-helper/static/vendor/jquery-ui-1.8/css/jquery-ui-1.8.16.custom.color_datauri.css
  70. 0 0
      output/fe-helper/static/vendor/jquery-ui-1.8/css/jquery-ui-1.8.16.custom.hot_datauri.css
  71. 0 783
      output/fe-helper/static/vendor/jquery-ui-1.8/js/jquery-ui-1.8.11.custom.min.js
  72. 0 1
      output/fe-helper/template/fehelper_background.html
  73. 0 1
      output/fe-helper/template/fehelper_endecode.html
  74. 0 1
      output/fe-helper/template/fehelper_fdp.html
  75. 0 1
      output/fe-helper/template/fehelper_jsonformat.html
  76. 0 0
      output/fe-helper/template/fehelper_options.html
  77. 0 1
      output/fe-helper/template/fehelper_popup.html
  78. 0 3
      output/fe-helper/template/fehelper_qrcode.html
  79. 0 1
      output/fe-helper/template/fehelper_wpo.html
  80. 0 77
      static/css/fe-endecode.css
  81. 0 128
      static/css/fe-fdp.css
  82. 0 347
      static/css/fe-helper.css
  83. 0 84
      static/css/fe-jsonformat.css
  84. 0 129
      static/css/fe-opt.css
  85. 0 83
      static/css/fe-popup.css
  86. 0 57
      static/css/fe-qrcode.css
  87. BIN
      static/img/43.png
  88. BIN
      static/img/baidufe_bj.gif
  89. BIN
      static/img/fe-128.png
  90. BIN
      static/img/fe-16.png
  91. BIN
      static/img/fe-48.png
  92. BIN
      static/img/grid.png
  93. BIN
      static/img/pbar-ani.gif
  94. BIN
      static/img/ui-icons_228ef1_256x240.png
  95. 0 153
      static/js/core/core.js
  96. 0 391
      static/js/core/fe-const.js
  97. 0 15
      static/js/core/jquery-1.5.min.js
  98. 0 34
      static/js/core/log.js
  99. 0 138
      static/js/core/network.js
  100. 0 241
      static/js/endecode/endecode-lib.js

+ 0 - 29
ReadMe.txt

@@ -1,29 +0,0 @@
-1、扩展安装地址:
-    https://chrome.google.com/webstore/detail/pkgccpejnmalmdinmhkkfafefagiiiad?hl=zh-cn&utm_source=chrome-ntp
-
-2、扩展目前功能:
-    a)、网页兼容性检测
-    b)、编码规范检测
-    c)、网页栅格规范检测
-    d)、JSON格式化
-    e)、二维码生成
-    f)、字符串编解码工具(Unicode、UTF8、Base64、MD5)
-
-3、关于开发
-    下载代码,chrome浏览器中本机开发即可
-
-4、关于发布:
-    方式一)、依赖编译平台FCP(zxlie用)
-        此方式可以进行js、css代码合并、压缩,html压缩,减小extension的体积。
-        运行build.sh脚本,会生成output,进入output目录,会有如下两个文件:
-        fe-helper.zip :上传到chorme web store,发布。
-        fe-helper :可在开发中进行测试
-
-    方式二)、直接压缩为fe-helper.zip包
-        此方式不走FCP,直接压缩,压缩后可将zip包发到zxlie处(mailto:[email protected]),由zxlie发布到webstore。
-        要想把它当成自己作品来发布,可以自己单独申请账号,在webstore缴纳$5,自行上传。
-
-5、主页:
-    HomePage:http://www.baidufe.com/item/889639af23968ee688b9.html#comment 
-    author:zxlie(zhaoxianlie)
-    email:[email protected]

+ 0 - 638
_locales/zh_CN/messages.json

@@ -1,638 +0,0 @@
-{
-	"extensionName": { "message": "前端(FE辅助)侦测工具" },
-	"extensionDescription": { "message": "部分idear来自compatibility-detecotor!" },
-	
-	"normalTitleText": { "message": "点击此按钮开始检测本页面的兼容性问题" },
-	"okTitleText": { "message": "暂时没有发现问题" },
-	"warningTitleText": { "message": "发现警告级别的问题\n点击查看" },
-	"errorTitleText": { "message": "发现错误级别的问题\n点击查看" },
-	
-	"msg0001":{"message":"HTML侦测结果"},
-	"msg0002":{"message":"CSS侦测结果"},
-	"msg0003":{"message":"Javascript侦测结果"},
-	"msg0004":{"message":"共<span class=x-num>$1</span>个,"},
-	"msg0005":{"message":"建议替换它。"},
-	"msg0006":{"message":"HTML5不再支持的标签"},
-	"msg0007":{"message":"<span class=x-num>$1</span>个位于<span class=x-tag>&lt;$2&gt;</span>标签内,"},
-	"msg0008":{"message":"HTML5不再支持的属性"},
-	"msg0009":{"message":"本页设置了DTD,"},
-	"msg0010":{"message":"这个 DTD 使 Chrome 处于<span class=x-num>$1</span>,但有可能使 IE 进入<span class=x-num>$2</span>。"},
-	"msg0011":{"message":"这个 DTD 使 Chrome 处于<span class=x-num>$1</span>,但 DTD 之前存在 IE 条件注释,有可能使 IE 进入$2"},
-	"msg0012":{"message":"本页在 IE 和 Chrome 中将触发 相同的 渲染模式,均为<span class=x-num>$1</span>"},
-	"msg0013":{"message":"建议使用在所有浏览器中均触发标准模式的 DTD,以减少出现兼容性问题的可能"},
-	"msg0014":{"message":"本页在 IE 和 Chrome 中将触发 <strong>不同的</strong> 渲染模式,其中 IE 中为$1,Chrome为$2"},
-	"msg0015":{"message":"建议删除 DTD 之前的内容,以减少出现兼容性问题的可能"},
-	"msg0016":{"message":"本页没有设置 DTD,在所有浏览器中将以<span class=x-num>$1</span>渲染;"},
-	"msg0017":{"message":"文档类型定义(DTD)"},
-	"msg0018":{"message":"发现仅 IE 支持的条件注释<span class=x-num>$1</span>个"},
-	"msg0019":{"message":"建议删掉页面上无用的注释"},
-	"msg0020":{"message":"其他HTML相关检测结果"},
-	"msg0021":{"message":"有<span class=x-num>$1</span>个 <span class=x-tag>&lt;link&gt;</span> 标记未放置在<span class=x-tag>&lt;$2&gt;</span>标签内,如果是动态创建的此标签,可能会导致它失效"},
-	"msg0022":{"message":"link标签"},
-	"msg0023":{"message":"没有发现异常"},
-	"msg0024":{"message":"ID重复性检测"},
-	"msg0025":{"message":"发现如下重复性的ID"},
-	"msg0026":{"message":"发现如下<span class=x-num>$1</span>个ID被重复使用,$2"},
-	"msg0027":{"message":"在文档中没有发现注释"},
-	"msg0028":{"message":"在文档中发现<span class=x-num>$1</span>个DOM节点"},
-	"msg0029":{"message":"发现有<strong>$1</strong>个<span class=x-tag>&lt;input&gt;</span>设置了size属性,size属性不能精确的控制其尺寸,请使用CSS的width替换它"},
-	"msg0030":{"message":"在文档中共发现<span class=x-num>$1</span>个HTML注释,注释总大小为 <span class=x-num>$2</span>字节;"},
-	"msg0031":{"message":"所有处于存活期的cookie"},
-	"msg0032":{"message":"其他Script相关检测结果"},
-	"msg0033":{"message":"在页面上发现独立的<span class=x-tag>&lt;script&gt;</span>块<span class=x-num>$1</span>个"},
-	"msg0034":{"message":"在页面上发现通过<span class=x-tag>&lt;script&gt;</span>标签引入外部js文件<span class=x-num>$1</span>个"},
-	"msg0035":{"message":"发现内联元素<span class=x-tag>$1</span>包含了块级元素<span class=x-tag>$2</span>"},
-	"msg0036":{"message":"内联元素包含块级元素"},
-	"msg0037":{"message":"未闭合的标签"},
-	"msg0038":{"message":"发现有$1未闭合,各浏览器对这些未闭合标签的容错方式不同"},
-	"msg0039":{"message":"冗余的CSS选择器"},
-	"msg0040":{"message":"可能用到的CSS伪类选择器"},
-	"msg0041":{"message":"实际用到的CSS选择器"},
-	"msg0042":{"message":"本页的cookie总大小为<span class=x-num>$1</span>字节"},
-	"msg0043":{"message":"本页的HTML代码没有经过压缩"},
-	"msg0044":{"message":"发现$1内的CSS代码没有经过压缩"},
-	"msg0045":{"message":"发现$1内的Javascript代码没有经过压缩"},
-	"msg0046":{"message":"<span class=x-tag>$1</span>标签"},
-	"msg0047":{"message":"<span class=x-num>$1</span>"},
-	"msg0048":{"message":"所有CSS检测结果"},
-	"msg0049":{"message":"当前页面没有设置<span class=x-tag>&lt;title&gt;</span>标签"},
-	"msg0050":{"message":"当前页面的<span class=x-tag>&lt;title&gt;</span>标签不在<span class=x-tag>&lt;head&gt;</span>标签内"},
-	"msg0051":{"message":"当前页面设置了多个<span class=x-tag>&lt;title&gt;</span>标签"},
-	"msg0052":{"message":",不利于SEO"},
-	"msg0053":{"message":"检测到<span class=x-tag>&lt;img&gt;</span>标签<span class=x-num>$1</span>的src为空"},
-	"msg0054":{"message":"当前页面引入的tangram文件为<span class=x-num>$1</span>"},
-	"msg0055":{"message":"当前页面依次引入了如下tangram文件:<span class=x-num>$1</span>"},
-	"msg0056":{"message":"绑定到window对象上的全局属性或方法"},
-	"msg0057":{"message":"<div><span class=x-tag>$1</span>中引用了<span class=x-num>$2</span>个css背景图片<span class='x-expand -x-expand-$3'>展开</span></div>"},
-	"msg0058":{"message":"CSS中共检测到<span class=x-num>$1</span>个expression,分布在$2"},
-	"msg0059":{"message":"<span class=x-tag>$1</span>中<span class=x-num>$2</span>个"},
-	"msg0060":{"message":"Firefox的注释中不能包含'--',但当前页面上已检测出<span class=x-num>$1</span>个这样的注释"},
-	"msg0061":{"message":"$1相关参考问题及其建议"},
-	"msg0062":{"message":"<a href='$1' target='_blank'>$2</a>"},
-	"msg0063":{"message":"当前页面的最大嵌套深度为<span class=x-num>$1</span>,路径为:<span class=x-tag>$2</span>"},
-	"msg0064":{"message":"<span class=x-tag>$1</span>被使用<span class=x-num>$2</span>次"},
-	"msg0065":{"message":"CSS中使用到的背景图片"},
-	"msg0066":{"message":"如下文件被多次引入,请确认:$1"},
-	"msg0067":{"message":"如下文件路径不同,但内容一样,请确认:$1"},
-	"msg0068":{"message":"<div><a href='$1' target='_blank' class=x-file>$2</a>被引入<span class=x-num>$3</span>次</div>"},
-	"msg0069":{"message":"<a href='$1' target='_blank' class=x-file>$2</a>文件"},
-	"msg0070":{"message":"<div>$1的内容重复</div>"},
-	
-	"html_0001": { "message": "在 Firefox 中注释内容中如果包含 '--' 字符在某些情况下会使该注释解析错误" },
-	"html_0002": { "message": "各浏览器对于字符编码别名支持的宽泛程度存在差异" },
-	"html_0003": { "message": "各浏览器对 URI 中非 ASCII 字符的处理有差异" },
-	"html_0004": { "message": "DTD 之前的非空白字符在某些情况下会使该 DTD 失效" },
-	"html_0005": { "message": "Chrome 和 Safari 中标签紧密相邻的行内元素在折行显示时存在错误" },
-	"html_0006": { "message": "META 标签的 content 属性中使用非 ';' 的符号做数据分割时在某些浏览器中不会被识别" },
-	"html_0007": { "message": "IE6 IE7 IE8(Q) 会忽略 OBJECT 和 IFRAME 标签之后的空白符" },
-	"html_0008": { "message": "IE Opera 对 OBJECT 元素之前的 'non-breaking space' 处理有误" },
-	"html_0009": { "message": "Chrome 和 Safari 中 BR 元素前的空白符不会被忽略" },
-	"html_0010": { "message": "IE 中单元格的 colspan 属性在某些情况下会影响 TABLE 元素的自动布局" },
-	"html_0011": { "message": "Firefox 在 TABLE 元素的宽度属性 (Attribute) 值大于 100% 时会以 100% 计算" },
-	"html_0012": { "message": "IE 支持某些非 TD 和 TH 元素上的 noWrap 属性" },
-	"html_0013": { "message": "各浏览器下使用 OBJECT 元素和 EMBED 元素嵌入 Flash 存在差异" },
-	"html_0014": { "message": "IMG 元素的 src 属性为空时其尺寸在各浏览器中不一致" },
-	"html_0015": { "message": "IE6 IE7 IE8(Q) 中 IMG 元素的 alt 属性在没有 title 属性的情况下会被当作提示信息使用" },
-	"html_0016": { "message": "IE6 不支持 PNG24 格式图片的半透明效果" },
-	"html_0017": { "message": "只有 IE6 中给 IMG 设置相同的 src 时会重载图片" },
-	"html_0018": { "message": "Firefox Opera 不支持通过为 OBJECT 元素设置 classid 引入 Windows 下的 Media Player 或 Flash 插件" },
-	"html_0019": { "message": "Firefox Opera 中 OBJECT 元素的默认尺寸为不可视" },
-	"html_0020": { "message": "在 IE6 IE7 IE8(Q) 中 CENTER 元素自身也会居中对齐,在 IE(S) 与 Opera(S) 中还会使其包含的表格中的文本居中对齐" },
-	"html_0021": { "message": "各浏览器对 align='middle' 的理解有差异" },
-	"html_0022": { "message": "Chrome Safari Firefox 中 IFRAME 元素在文档树中发生变化后父子页面间的某些交互方式会失效" },
-	"html_0023": { "message": "不同内核的浏览器中文件选择控件的外观也不相同" },
-	"html_0024": { "message": "不能以 size 属性精确控制 INPUT 文本框或密码框的宽度" },
-	"html_0025": { "message": "各浏览器中密码框掩码的外观不完全一致" },
-	"html_0026": { "message": "IE6 IE7 IE8(Q) 中 FILEDSET 元素的宽度不是 'auto' 时的表现与行内元素相同" },
-	"html_0027": { "message": "仅在 IE6 IE7 IE8中 \"disabled\" 属性可以作用于非表单控件元素" },
-	"html_0028": { "message": "Chrome Safari Opera 中 INPUT、TEXTAREA 元素的 disabled 属性值为 true 时其前景颜色会发生变化,但在 Chrome Safari 中某些情况下 disabled 属性值由 true 转为 false 后,其前景颜色不会更新至最初的设定色" },
-	"html_0029": { "message": "Firefox 中 TEXTAREA 元素根据 \"rows\" 设置值生成的实际行数为设置值 + 1" },
-	"html_0030": { "message": "Firefox Opera 中 BUTTON 元素的子元素可以溢出按钮渲染" },
-	"html_0031": { "message": "IE Opera 中 src 属性为空的 SCRIPT 元素内的脚本不会被忽略,且内联脚本可以通过修改其所在 SCRIPT 元素的 src 属性引入新的外部脚本文件" },
-	"html_0032": { "message": "Safari 中错误的注释将导致部分 JavaScript 代码无法执行" },
-	"html_0033": { "message": "IE6 IE7 IE8(Q) 中同一元素重复定义的 style 属性会被合并" },
-	"html_0034": { "message": "IE6 IE7 IE8(Q) Firefox(Q) Opera(Q) 会自动修复被大括号包含的 style 属性的值" },
-	"html_0035": { "message": "IE6 IE7 IE8(Q) 中对 UL OL DL 内包含非列表元素的处理跟其他浏览器不同" },
-	"html_0036": { "message": "各浏览器对未闭合标签的容错方式不同" },
-	"html_0037": {"message": "IE6 Firefox Chrome(Q) Safari(Q) 不支持 OPTION 元素的 label 属性"},
-	"html_0038": {"message": "IE6 IE7 不支持 OPTION 和 OPTGROUP 元素的 disabled 属性"},
-	"html_0039": { "message": "IE Opera 中可以通过 MAP 元素的 id 属性与 IMG 元素相关联" },
-	"html_0040": { "message": "各浏览器对表单元素单选按钮组设置非 CDATA 标准的 name 属性值解析不同"},
-	"html_0041": { "message": "各浏览器对 BASE 元素前后的超链接的默认 target 处理存在差异"},
-	"html_0042": { "message": "只有 IE 支持 IMG INPUT[type=image] 标记内的 lowsrc 属性"},
-		
-	"html_0001_suggestion": { "message": "按标准推荐的方法写注释标签" },
-	"html_0002_suggestion": { "message": "首先,对于动态页面必须确保 HTTP \"Content-Type\" 头字段的 \"charset\" 参数与页面自身编码相符,且务必在页面的 META 元素中也声明相符的字符编码信息。对于静态页面,必须保证页面中 META 元素声明中 \"http-equiv\" 为 \"Content-Type\" 对应的值中的 \"charset\" 的值与页面自身编码相符。" },
-	"html_0003_suggestion": { "message": "当 URI 中含有非 ASCII 字符时,不要依赖浏览器对 URI 的编码方式,以避免产生差异。" },
-	"html_0004_suggestion": { "message": "声明 DTD 时,确保 DTD 之前没有其他字符,即便有,也只能是空格符、换行符和制表符。" },
-	"html_0005_suggestion": { "message": "避免出现紧密连接的内联元素标签,可以在每个标记之间加入空格或者换行符来避免这个问题。" },
-	"html_0006_suggestion": { "message": "参照 W3C 的建议,使用英文半角分号“;”。" },
-	"html_0007_suggestion": { "message": "若不希望出现空格,可以将 IFRAME OBJECT 元素设置为块级元素。" },
-	"html_0008_suggestion": { "message": "合理的设置容器及 OBJECT 元素的宽度。" },
-	"html_0009_suggestion": { "message": "删除 BR 元素之前多余的空白符。" },
-	"html_0010_suggestion": { "message": "1. 设置 TABLE 的 'table-layout' 特性值为 fixed,使用固定布局的表格元素可避免此问题。" },
-	"html_0011_suggestion": { "message": "给 TABLE 元素设置宽度的时候,不要使用 HTML 属性 'width',请使用 CSS 特性 'width'。" },
-	"html_0012_suggestion": { "message": "nowrap 属性是被废弃的属性,使用 CSS 规则 white-space:nowrap 代替这个属性。" },
-	"html_0013_suggestion": { "message": "若不考虑 W3C 校验,可统一使用 EMBED 元素嵌入 Flash,这样可以避免因参数不统一导致的兼容性问题。" },
-	"html_0014_suggestion": { "message": "为了防止这种无 \"src\" 的 IMG 元素对页面产生布局影响,需要设置这种 IMG 的 ‘display’ 特性为 'none'。" },
-	"html_0015_suggestion": { "message": "若用户需要显示提示框,则指定 title 属性;" },
-	"html_0016_suggestion": { "message": "使用 IE 专有滤镜 AlphaImageLoader Filter 来修复 IE6 透明通道问题,详情请参考 MSDN 说明:  http://msdn.microsoft.com/en-us/library/ms532969(VS.85).aspx " },
-	"html_0017_suggestion": { "message": "如果需要重复设置相同的 src 值时,均触发 IMG 的 onload 事件,或者需要每次均从服务器端下载图片数据的时候,可以采用图片地址后加上随机数或当前时间戳参数的手段,避免内容被缓存。" },
-	"html_0018_suggestion": { "message": "由于某些浏览器原生无法支持 OBJECT 元素使用 classid 属性引入 Media Player 插件,所以为保证最大的兼容性,应避免使用此方式在页面中播放媒体文件。" },
-	"html_0019_suggestion": { "message": "OBJECT 元素为替换元素,应为 OBJECT 元素设置一个明确的宽度和高度。" },
-	"html_0020_suggestion": { "message": "避免使用 CENTER 标签,使用 CSS 的 'text-align' 特性来代替。" },
-	"html_0021_suggestion": { "message": "align=\"middle\" 仅在 IMG、OBJECT、APPLET 元素上的 align 属性中是合法值,对于其他元素的 align 属性均为非法。各浏览器在上述三个元素之外的元素上遇到 align=\"middle\" 均按照自己的理解方式解释。同时除单元格元素的 align 属性之外,其他的 align 属性均被 W3C 官方废弃(Deprecated.),所以应避免使用此属性。" },
-	"html_0022_suggestion": { "message": "根据上面所得的结果,推荐使用 document.getElementById(\"IFRAME\").contentWindow.document 获取 IFRAME 元素内页面的 document 对象,且对于在文档树中移动位置后的 IFRAME 元素也有很好的兼容性。同时应避免对跨域的父子页面交互。" },
-	"html_0023_suggestion": { "message": "在 Chrome  Safari 中对于文件选择控件的特殊呈现方式为 WebKit 内核特有,且其渲染方式也符合 W3C 对文件选择控件的规定。一般来说这种差异不会带来严重的兼容性问题。" },
-	"html_0024_suggestion": { "message": "不要试图通过设置 \"size\" 属性使 INPUT[type=text/password] 元素在所有浏览器中的宽度一致,这是不可能的。在需要对这类元素做精确的控制时,应使用 CSS 的 'width' 和 'height' 特性。" },
-	"html_0025_suggestion": { "message": "由于掩码字符无法被修改,因此仅通过 CSS 统一密码输入框的掩码样式是不可能的。且这种差异可以忽略不计。" },
-	"html_0026_suggestion": { "message": "这是一个 Bug,通过显式设置 FIELDSET 的样式为 'display:block' 来修复。" },
-	"html_0027_suggestion": { "message": "应避免在非表单控件类元素上使用 \"disabled\" 属性。" },
-	"html_0028_suggestion": { "message": "避免为 INPUT、TEXTAREA 元素设置比较深的背景色,或者在需要使一个文本框在 \"disabled=true\" 及 \"disabled=false\" 之间切换时,尽量通过标准的 DOM 方式创建此元素。" },
-	"html_0029_suggestion": { "message": "当我们仅仅为 TEXTAREA 元素设置 \"rows\" 属性以控制其高度时,在 Firefox 中无法得到我们预期的效果。且其他浏览器对 \"rows\" 属性设置的元素高度也不尽相同,这一点 W3C 没有明确规范 \"rows\" 属性计算高度时的具体算法。" },
-	"html_0030_suggestion": { "message": "合理的设置 BUTTON 及其子元素的宽度及高度,避免出现子元素溢出 BUTTON 的情况。" },
-	"html_0031_suggestion": { "message": "不在设定了 src 属性的 SCRIPT 元素内编写脚本。" },
-	"html_0032_suggestion": { "message": "SCRIPT 标记内如有 HTML 注释标记,请仔细检查,注意他们的闭合情况。" },
-	"html_0033_suggestion": { "message": "不要依赖 IE 的容错机制,避免重复定义 HTML 元素属性。" },
-	"html_0034_suggestion": { "message": "不要在 'style' 的属性值中使用大括号等符号包含样式特性,直接书写样式代码即可避免此类问题。" },
-	"html_0035_suggestion": { "message": "虽然 HTML 4.01 规范中没有明确指出列表元素的兄弟元素必须是同一列表元素;但是根据 HTML 语义化理念,建议不要在列表元素 LI DD DT 之后插入其他元素。" },
-	"html_0036_suggestion": { "message": "编写代码时要注意,不要遗失应有的闭合标签,以确保在各浏览器中都能按照预期的文档结构来渲染页面。" },
-	"html_0037_suggestion": { "message": "尽量避免在 OPTION 元素上使用 label 属性,如果想替代 OPTION 原有的内容值,请使用 Javascript。" },
-	"html_0038_suggestion": { "message": "使用其他方式使想要 disabled 的 OPTION 和 OPTGROUP 无效,比如使用脚本动态删除 OPTION 或 OPTGROUP。" },
-	"html_0039_suggestion": { "message": "若需要 IMG 元素与 MAP 元素相关联,注意通过 IMG 元素的 usemap 属性关联的 MAP 元素的 name 属性的值。" },
-	"html_0040_suggestion": { "message": "单选按钮的 \"name\" 属性值必须以字母 ([A-Za-z])和数字([0-9])开头 ,其后由任何字母、数字、连字符(\"-\")、下划线(\"_\")、冒号(\":\")和句号 (\".\") 组成。" },
-	"html_0041_suggestion": { "message": "不要在 HEAD 元素之外定义 BASE 元素,保证各浏览器兼容。" },
-	"html_0042_suggestion": { "message": "如无特殊应用需求,应避免使用 lowsrc 为属性名,防止他与 IE 扩展属性混淆。"},
-	
-	"css_0001": { "message": "Chrome Safari 中 '@charset' 声明的位置错误将导致其后的一个规则集无效" },
-	"css_0002": { "message": "各浏览器在 HTML 页面与页面中引入的外部 CSS 文件编码不一致时表现不同" },
-	"css_0003": { "message": "IE6 IE7(Q) IE8(Q) 不支持子选择器" },
-	"css_0004": { "message": "IE6 IE7(Q) IE8(Q) 不支持相邻兄弟选择器" },
-	"css_0005": { "message": "IE6 IE7(Q) IE8(Q) 不支持属性选择器" },
-	"css_0006": { "message": "IE6 IE7(Q) IE8(Q) 不支持 ':first-child' 伪元素" },
-	"css_0007": { "message": "IE6 IE7(Q) IE8(Q) 中 A 元素的 :visited :hover :active 伪类未按规范要求的算法来计算针对性" },
-	"css_0008": { "message": "IE6 IE7(Q) IE8(Q) 不支持 A 元素以外的其他元素的 ':hover' 伪类" },
-	"css_0009": { "message": "IE6 IE7 IE8(Q) 不支持 A 元素以外的其他元素的 ':active' 伪类" },
-	"css_0010": { "message": "IE6 IE7 IE8(Q) 不支持 ':focus' 伪类" },
-	"css_0011": { "message": "IE6 IE7 IE8(Q) 不支持 ':before' 和 ':after' 伪元素" },
-	"css_0012": { "message": "IE6 IE7 IE8(Q) 不支持 CSS 特性的 'inherit' 值" },
-	"css_0013": { "message": "IE8  Chrome Safari 中具有加粗效果的 HTML 元素的 'font-weight' 特性会受到其祖先元素的影响" },
-	"css_0014": { "message": "IE6 IE7(Q) IE8(Q) 不完全支持 !important 规则" },
-	"css_0015": { "message": "IE6 IE7 IE8(Q) 负边距 (margin) 导致元素溢出 hasLayout 容器时显示异常" },
-	"css_0016": { "message": "Chrome Safari 中为处于浮动元素后创建了 in-flow 的 Block Formatting Context 的元素设置的 'margin-left' 或 'margin-right' 特性会出错" },
-	"css_0017": { "message": "Firefox 中 'display:table '的元素的外边距不会与包含块的外边距折叠" },
-	"css_0018": { "message": "IE6 IE7 IE8(Q) 中浮动元素和定位元素某些情况下会影响普通流中毗邻 'margin' 的折叠" },
-	"css_0019": { "message": "IE6 IE7 IE8(Q) 中父元素或子元素触发 hasLayout 时子元素的 margin 值与期望值不符" },
-	"css_0020": { "message": "IE6 IE7 IE8(Q) 不支持 'display' 的替代值" },
-	"css_0021": { "message": "不能在 IE6 IE7 IE8(Q) 中触发 hasLayout 并在其他浏览器中创建 Block Formatting Context 的元素的表现会有差异" },
-	"css_0022": { "message": "各浏览器中浮动元素与相邻的 Block Formatting Context 之间的关系有差异" },
-	"css_0023": { "message": "IE6 IE7 IE8(Q) 中零高度的浮动元素会阻挡其兄弟浮动元素" },
-	"css_0024": { "message": "IE6 IE7 IE8(Q) 中行内元素后相邻的浮动元素在某些情况下会折行放置在之前行内元素所在行框的底部" },
-	"css_0025": { "message": "IE6 IE7 IE8(Q)中设置了 'clear' 特性的元素 'margin-top' 特性处理有误,某些情况下会与浮动元素重叠" },
-	"css_0026": { "message": "在 IE6 IE7 IE8(Q) 中包含被清除浮动的浮动元素的块级元素的背景在某些情况下不是设置值" },
-	"css_0027": { "message": "IE6 IE7 IE8(Q) 中对浮动元素上 'clear' 特性的解释出现错误,使其自身位置和其后浮动元素的位置与其他浏览器中不同" },
-	"css_0028": { "message": "IE6 IE7 IE8(Q) 中一些块级元素的默认上下外边距会在其浮动或触碰到 hasLayout 的容器后消失" },
-	"css_0029": { "message": "IE6 IE7 IE8(Q) 中元素的 'padding-top' 遇到 'clear' 特性在某些情况下复制到 'padding-bottom'" },
-	"css_0030": { "message": "Firefox 浏览器对 TABLE 中绝对定位元素包含块的判定有错误,某些情况下会导致绝对定位元素位置跟其他浏览器中有差异" },
-	"css_0031": { "message": "IE6 IE7 IE8(Q) Firefox Opera 中绝对定位元素的静态位置计算某些情况下会出错" },
-	"css_0032": { "message": "IE6 IE7(Q) IE8(Q) 不支持固定定位(position:fixed)" },
-	"css_0033": { "message": "IE6 IE7 IE8(Q) 中某些情况下浮动元素会在其浮动方向溢出其包含块" },
-	"css_0034": { "message": "IE6 IE7 IE8(Q) 中定位元素 'z-index' 为默认值在某些情况下会产生新的层叠上下文" },
-	"css_0035": { "message": "IE6 IE7 IE8(Q) 中溢出容器的浮动元素导致容器兄弟元素文本定位错误" },
-	"css_0036": { "message": "IE7(S) 中元素溢出包含块的部分会被 hasLayout 元素遮住" },
-	"css_0037": { "message": "IE6 IE7(Q) IE8(Q) 中包含块若未触发 hasLayout 则会影响参照其定位的绝对定位元素的偏移位置计算" },
-	"css_0038": { "message": "各浏览器中 'width' 和 'height' 在某些元素上的作用位置有差异" },
-	"css_0039": { "message": "IE6 IE7(Q) IE8(Q) 中 'width' 或 'height' 的设定值在不足以容纳其内容时将被撑大" },
-	"css_0040": { "message": "零宽高的 IFRAME 元素的实际尺寸在不同浏览器中有差异" },
-	"css_0041": { "message": "IE6 IE7 IE8(Q) 中浮动元素宽度的 shrink-to-fit 算法与标准规定的算法不同" },
-	"css_0042": { "message": "Chrome Safari 中浮动元素之前的非 inline 级元素会对包含块的 shrink-to-fit 宽度计算有影响" },
-	"css_0043": { "message": "IE6 IE7 IE8(Q) 中右浮动元素会撑大其祖先级元素的宽度" },
-	"css_0044": { "message": "IE Opera 计算 shrink-to-fit 的宽度时会考虑浮动元素的宽度" },
-	"css_0045": { "message": "IE6 IE7(Q) IE8(Q) 绝对定位元素无法根据其四个方向的偏移量自动计算其尺寸" },
-	"css_0046": { "message": "IE6 IE7 IE8(Q) 中行框的顶边与底边位置识别有误" },
-	"css_0047": { "message": "IE6 IE7(Q) IE8(Q) 不支持 'min-width' 和 'max-width' 特性" },
-	"css_0048": { "message": "IE6 IE7 IE8(Q) 中行内非替换元素中的非文本文字会撑高其高度" },
-	"css_0049": { "message": "不同浏览器内 'line-height' 样式设置会影响不同行内替换元素的显示高度" },
-	"css_0050": { "message": "IE6 IE7 IE8(Q) 中触发 hasLayout 的空块级非替换元素的高度不是0" },
-	"css_0051": { "message": "行内非替换元素的高度和宽度的设置仅在 IE 混杂模式中生效" },
-	"css_0052": { "message": "IE6 IE7(Q) IE8(Q)不支持 'min-height' 和 'max-height' 特性" },
-	"css_0053": { "message": "各浏览器对常用行内替换元素的 'baseline' 位置理解不同" },
-	"css_0054": { "message": "Safari Chrome 中行框高度计算有误" },
-	"css_0055": { "message": "Safari Chrome 中元素 'overflow' 值为非默认值时其最后一个内联子元素的半差异高度被忽略" },
-	"css_0056": { "message": "各浏览器对行内元素绝对定位后的静态位置的 'top' 特性计算存在差异,IE6 IE7 IE8(Q) 还会考虑半差异的高度" },
-	"css_0057": { "message": "在不同的文档模式中,当唯一的非表单控件类行内替换元素存在于其包容块中时,其父框的行高并不一定会计算文本基线高度。" },
-	"css_0058": { "message": "各浏览器中当容器元素 shrink-to-fit 时容器内 MARQUEE 标签的计算宽度不一致" },
-	"css_0059": { "message": "IE 中当 'overflow-x' 或 'overflow-y' 的值被设置成非 'visible' 时,另一个特性的计算值为 'visible' 而非 'auto'" },
-	"css_0060": { "message": "IE6 IE7 IE8(Q) 中 'overflow' 特性不为 'visible' 的非定位元素内包含溢出的定位元素时的渲染效果有误" },
-	"css_0061": { "message": "IE6 IE7 IE8(Q) 中 UL 和 OL 标记为实现放置 LI 元素标记框 'outside' 设置时所使用的样式设定不同于其他浏览器" },
-	"css_0062": { "message": "IE6 IE7 IE8(Q) 中如果列表元素设置 'list-style-type:none' 时不影响 ‘list-style-position:inside’ 设置产生的标记块  " },
-	"css_0063": { "message": "LI 元素设置标记类型的特性 'style-list-type' 的 'disc | circle | square' 三个特性值在各浏览器中的渲染方式不同" },
-	"css_0064": { "message": "IE6 IE7(Q) IE8(Q) 中 IFRAME 元素 'background-color' 特性默认值不是 transparent" },
-	"css_0065": { "message": "IE6 不支持 HTML、BODY 以外元素的 background-attachment:fixed" },
-	"css_0066": { "message": "各浏览器对 '@font-face' 规则支持的字体格式不同,IE 支持 EOT 字体,Firefox Safari Opera 支持 TrueType 等字体" },
-	"css_0067": { "message": "在某些条件下 Firefox Chrome Safari 的标准模式中 'text-decoration' 会作用于 IMG 元素上" },
-	"css_0068": { "message": "元素和其子孙元素的 'text-decoration' 特性对其内文本的渲染在各浏览器中不同" },
-	"css_0069": { "message": "'text-align' 特性在 IE6 IE7 IE8(Q) 中可以影响块级元素的对齐方式,并且在所有浏览器的混杂模式中均不能被 TABLE 元素继承" },
-	"css_0070": { "message": "WebKit 浏览器中 'white-space:nowrap' 使表格内的浮动元素不折行" },
-	"css_0071": { "message": "'text-overflow:ellipsis' 会引起兼容性问题" },
-	"css_0072": { "message": "某些条件下 IE6 IE7 IE8(Q) 中 'word-wrap:break-word' 作用于 TD 时导致其中 IMG 元素不换行" },
-	"css_0073": { "message": "'word-wrap:break-word' 只有在 WebKit 浏览器中对 SELECT 元素上的文字有效" },
-	"css_0074": { "message": "'word-wrap:break-word' 导致在 IE6, IE7 及 IE8(Q) 中空格不被忽略" },
-	"css_0075": { "message": "仅 Firefox 支持小数数值的 'letter-spacing' 特性" },
-	"css_0076": { "message": "Firefox 中 A 元素的 ':hover' 伪类中设置的下划线某些情况下会失效" },
-	"css_0077": { "message": "固定表格布局下的各浏览器对与表格宽度计算算法不同" },
-	"css_0078": { "message": "WebKit 中某些条件下 empty cell 的宽度和高度为 0" },
-	"css_0079": { "message": "IE6 IE7 IE8(Q) 中自动布局的表格在其中包含无内容的左浮动元素时的宽度计算在某些情况下有误" },
-	"css_0080": { "message": "IE 混杂模式下 TR 元素的最终高度始终不会超过其所有 TD 子元素的高度" },
-	"css_0081": { "message": "单元格的高度计算受其 'padding' 和 'line-height' 的影响 " },
-	"css_0082": { "message": "IE6(Q) IE7(Q) IE8(Q) Chrome(S) Safari(S) Firefox 对多层嵌套的表格级元素百分比高度计算错误" },
-	"css_0083": { "message": "IE6 IE7 IE8(Q) Firefox(Q) Opera(Q) 中空单元格的边框某些情况下会消失" },
-	"css_0084": { "message": "IE6 IE7 IE8(Q) 中空单元格的上下 'padding' 失效" },
-	"css_0085": { "message": "IE6 IE7 IE8(Q) 中单元格对齐依据的是元素的原始宽度而不是其因某些原因被拉大后的宽度" },
-	"css_0086": { "message": "IE Firefox Opera 的混杂模式对于百分比单位高度的单元格内子元素的百分比高度计算错误" },
-	"css_0087": { "message": "只有 IE 和 Opera 支持 'cursor:hand'" },
-	"css_0088": { "message": "IE6 IE7 IE8(Q) 不支持 'outline' 特性" },
-	"css_0089": { "message": "IE6 IE7 IE8(Q) 会自动修复 'font-family' 特性的值是由一个引号包括了整个字体家族时的错误书写的代码" },
-	"css_0090": { "message": "各浏览器对 CSS 代码及 CSS 相关 DOM 操作中长度 \"&lt;length&gt;\" 类型的值缺失单位的容错程度存在差异" },
-	"css_0091": { "message": "各浏览器对 CSS 错误解析规则的差异及 CSS hack" },
-	"css_0092": { "message": "各浏览器对不合法的类选择器名称的容错程度存在差异" },
-	"css_0093": { "message": "各浏览器对于计算后宽度和高度为含有小数的长度值时,其最终值会不一致" },
-	"css_0094": { "message": "IE5.0 IE5.5 IE6 中浮动元素在某些情况下会有双倍外边距" },
-	"css_0095": { "message": "IE6 IE7 IE8(Q) 中从单元格溢出的内容会被自动剪裁" },
-	"css_0096": { "message": "IE6 IE7 IE8(Q) 中 'white-space' 特性在某些情况下不会自动继承" },
-	"css_0097": { "message": "非 IE 浏览器中 'margin' 特性对 TABLE 元素的 align 属性会有影响" },
-	"css_0098": { "message": "IE6 IE7(Q) IE8(Q) 中 A 元素的 ':hover' 伪类以及 IE6 IE7 IE8(Q) 中的 ':active' 伪类 在当缺少 href 属性时会失效" },
-	"css_0099": { "message": "IE(Q) Firefox(Q) Opera 中 BR 元素的 'line-height' 特性的计算值在某些情况下会小于其继承值" },
-	"css_0100": { "message": "字体样式标签(U、B、S等)对某些 CSS 特性有影响" },
-	"css_0101": { "message": "IE6 IE7 IE8(Q) 中 cellspacing 属性在重合的边框模型的表格中仍然有效" },
-	"css_0102": { "message": "各浏览器中 IFRAME 元素的 scrolling 属性与其子页面 HTML 与 BODY 元素 'overflow' 特性的制约关系有差异" },
-	"css_0103": { "message": "IE6(Q) IE7(Q) IE8(Q) 中给 IMG 元素设置 'padding' 无效" },
-	"css_0104": { "message": "各浏览器中 FONT 元素的颜色设置在某些情况下会作用到由其祖先级元素设定的装饰线的颜色" },
-	"css_0105": { "message": "不同浏览器中 Flash 与其他元素发生覆盖时有差异" },
-	"css_0106": { "message": "IE6 IE7 IE8(Q) 没有完全正确地将 IMG、OBJECT、IFRAME、TABLE 元素的 align='left|right' 理解为浮动" },
-	"css_0107": { "message": "IE 对浮动非替换元素内包含宽度单位为百分比的元素时的 \"shrink-to-fit\" 宽度算法有误" },
-	"css_0108": {"message": "IE6 IE7 IE8(Q) 下 'background-attachment : scroll' 时背景图片会随着元素内容滚动" },
-	"css_0109": {"message": "各浏览器禁止内容选中的方式不同" },
-	"css_0110": {"message": "IE6 IE7 IE8(Q) 不支持 border-spacing 特性" },
-	"css_0111": { "message": "各浏览器对于未明确设定高度的包含块内包含百分比单位高度的块级元素或行内块元素的高度计算存在差异" },
-	"css_0112": { "message": "IE6 IE7 IE8(Q) 不支持 border-spacing 特性" },
-	"css_0113": { "message": "IE6 IE7 IE8(Q) 中空 TABLE 的宽度和高度均为 0" },
-	"css_0114": { "message": "IE6 IE7 IE8(Q) 中对浮动元素上 'clear' 特性的解释出现错误,使其自身位置和其后浮动元素的位置与其他浏览器中不同" },
-	"css_0115": { "message": "IE6 IE7 IE8(Q) 中零高度的浮动元素会阻挡其兄弟浮动元素" },
-	"css_0116": { "message": "只有 IE Chrome Safari 支持 'zoom' 特性并且他们的具体实现方式不同"},
-	"css_0117": { "message": "Chrome Safari 认为 'float:center' 是合法值且其计算值为 'none'"},
-	"css_0118": { "message": "各浏览器对 'marginwidth' 和 'marginheight' 属性的错误设定值的处理不同"},
-	"css_0119": { "message": "各主流浏览器均不支持非标准的 LAYER 元素" },
-	
-	"css_0001_suggestion": { "message": "要使用 '@charset' 规则,请确保将其放在样式表的最开始,前边不能有任何字符。" },
-	"css_0002_suggestion": { "message": "当 HTML 文件或 CSS 文件要引入一个不同编码的 CSS 文件时,要明确声明将被引入的 CSS 文件的编码,以避免发生上述问题。" },
-	"css_0003_suggestion": { "message": "避免在 IE6 IE7(Q) IE8(Q) 中使用子选择器。" },
-	"css_0004_suggestion": { "message": "避免在非标准模式中对 IE7 以下版本使相邻兄弟选择器。" },
-	"css_0005_suggestion": { "message": "避免在 IE6 IE7(Q) IE8(Q) 中使用属性选择器。" },
-	"css_0006_suggestion": { "message": "避免在 IE6 IE7(Q) IE8(Q) 中使用 ‘:first-child’ 伪元素。" },
-	"css_0007_suggestion": { "message": "严格按照标准的建议,以 L-V-H-A 的顺序声明 A 标签的伪类,以保证在各浏览器中兼容。" },
-	"css_0008_suggestion": { "message": "使用 JavaScript 绑定 'onmouseover' 和 'onmouseout'(模仿 ':hover');" },
-	"css_0009_suggestion": { "message": "使用 JavaScript 绑定 onmousedown onmouseup 事件模仿 ‘:active’ 伪类效果;" },
-	"css_0010_suggestion": { "message": "使用 JavaScript 绑定 onfocus onblur 事件模仿 ‘:focus’ 效果;" },
-	"css_0011_suggestion": { "message": "使用 JavaScript 判断在 IE6 IE7 IE8(Q) 中通过脚本实现 ':before' 及 ':after' 伪元素的效果;" },
-	"css_0012_suggestion": { "message": "使用标准模式渲染页面;" },
-	"css_0013_suggestion": { "message": "最好为元素设置绝对明确的 'font-weight' 特性的值,避免使用 bolder、lighter 这类相对量以及浏览器的默认样式。" },
-	"css_0014_suggestion": { "message": "这是浏览器的 Bug 导致,无法通过常规方式解决。不过,一般 '!important' 规则常常用于 CSS hack 以区分 IE6 与其他浏览器,其作为 hack 存在的意义已大于其本身的含义。" },
-	"css_0015_suggestion": { "message": "首先需要保证容器在IE中触发 hasLayout 属性,可以通过zoom:1实现。" },
-	"css_0016_suggestion": { "message": "为该创建了 BFC 的元素设置一个明确的宽度。" },
-	"css_0017_suggestion": { "message": "由于 IE6 IE7 IE8(Q) Firefox 元素的 'margin' 处理与 W3C 规范中的差异,若我们需要利用 \"margin collapse\" 达到某些布局效果时,在这几种浏览器中可能会由于没有发生 \"margin collapse\" 而出现 \"额外边距\" 的情况。所以应避免为表格设置上下边距,以及导致其 \"margin collapse\" 的发生,可以使用为表格的父元素使用 'padding' 代替表格元素的 'margin' 。" },
-	"css_0018_suggestion": { "message": "1. 根据具体需求,调整 'margin' 的位置和大小;" },
-	"css_0019_suggestion": { "message": "为容器显式地设置高度。若容器高度不定,则要避免在触发了 hasLayout 的容器内的浮动子元素上设置 'margin-bottom' 特性,可以通过为容器设置 'padding-bottom' 达到相似的效果。" },
-	"css_0020_suggestion": { "message": "尽量仅使用所有浏览器都支持的 'display' 特性值:'inline'、'block'、'list-item'、'none'。" },
-	"css_0021_suggestion": { "message": "仅当一个元素即在 IE 早期版本中触发了 hasLayout,又在其他浏览器中创建了 block formatting context 时,才能避免上述问题的发生。即同时启用上述两者以保证各浏览器的兼容,或者相反,两者皆不启用:" },
-	"css_0022_suggestion": { "message": "合理地设置容器的宽度、浮动元素的宽度、BFC 的宽度的值,尽量保证 BFC 的宽度小于 \"容器的剩余空间宽度\" 。若需要 BFC 折行显示在新的一行上,可以通过 BFC 设置 'clear' 特性等手段使其换行。" },
-	"css_0023_suggestion": { "message": "如果希望一个浮动元素能阻挡与其向相同方向浮动的兄弟元素,请确保其高度不为零,以使页面布局在各浏览器中的表现一致。" },
-	"css_0024_suggestion": { "message": "使用绝对定位(position:absolute)模拟右浮动(float:right)。" },
-	"css_0025_suggestion": { "message": "尽量避免为 'clear' 特性不为 none 的元素(即清理元素)设置 'margin-top' 特性,尤其是负值。" },
-	"css_0026_suggestion": { "message": "使丢失背景的容器触发 IE 浏览器特有的 hasLayout,如 'zoom:1',或者设置宽度和高度。" },
-	"css_0027_suggestion": { "message": "不要将 'clear' 特性应用在浮动元素上,以免出现上述不兼容的问题。" },
-	"css_0028_suggestion": { "message": "用自定义的 'margin' 取代浏览器的默认外边距样式。" },
-	"css_0029_suggestion": { "message": "方案1.不触发容器的 hasLayout 特性;" },
-	"css_0030_suggestion": { "message": "这是 Firefox 的一个 bug,绝对定位元素无法根据 'display' 特性是 'table' 且是绝对定位的祖先元素定位。" },
-	"css_0031_suggestion": { "message": "首先对于绝对定位元素,应尽可能避免使其 'top'、'right'、'bottom'、'left' 特性的值均为 'auto'。若必须这么做,则尽可能的保证绝对定位元素之前的兄弟元素为非浮动的块级元素。" },
-	"css_0032_suggestion": { "message": "在 IE6 IE7(Q) IE8(Q) 中为固定定位元素设置 'position:absolute',再通过 JavaScript 脚本或者 CSS Expression 动态设置其偏移量。如:" },
-	"css_0033_suggestion": { "message": "当文字方向为 'ltr' 时应避免使右浮动元素的宽度超出其包含块的宽度。同样地,当文字方向为 'rtl' 时应避免使左浮动元素的宽度超出其包含块的宽度。" },
-	"css_0034_suggestion": { "message": "理解层叠上下文、层叠级别与 'z-index' 之间的关系。" },
-	"css_0035_suggestion": { "message": "及时地为容器清除浮动,并且确保浮动元素没有溢出容器。" },
-	"css_0036_suggestion": { "message": "合理设置元素的 'width'、'height' 和 'overflow' 特性,避免内容溢出容器。 " },
-	"css_0037_suggestion": { "message": "使包含块触发 hasLayout 特性。如 'zoom:1' 或者设置明确的宽度、高度。" },
-	"css_0038_suggestion": { "message": "1. 使用能触发标准模式 (S) 的 DTD" },
-	"css_0039_suggestion": { "message": "使用能触发标准模式 (S) 的 DTD,以将受此问题影响的浏览器范围缩小到仅 IE6(S)。" },
-	"css_0040_suggestion": { "message": "根据实际情况选择使用 'visibility:hidden' 或者 'display:none' 隐藏 IFRAME 。" },
-	"css_0041_suggestion": { "message": "这个问题的影响较大,避免该问题的最直接的方式是给浮动非替换元素指定一个宽度,而不使用其默认值 'auto',从而避免其宽度为 shrink-to-fit,以使页面布局在各浏览器中的表现一致。" },
-	"css_0042_suggestion": { "message": "在容器为绝对定位、浮动或行内块元素且没有明确设定宽度时,若浮动元素之前出现非 inline 级元素,则要小心这个元素对容器 shrink-to-fit 宽度的影响。可以为容器明确的设定一个宽度。" },
-	"css_0043_suggestion": { "message": "如果有一个右浮动元素,应注意避免其祖先级元素的宽度为 shrink-to-fit,即给它们设定一个明确的宽度。以使页面布局在各浏览器中的表现一致。" },
-	"css_0044_suggestion": { "message": "尽量为非替换浮动元素、非替换绝对定位元素、非替换行内块元素显式地设置一个宽度,防止浏览器在 'width:auto' 时对于 shrink-to-fit 的宽度计算方式不同造成布局上的差异。" },
-	"css_0045_suggestion": { "message": "若能为非替换绝对定位元素设定固定的宽度及高度,则尽量不使用此方式自动计算绝对定位元素的 'width' 及 'height'。" },
-	"css_0046_suggestion": { "message": "为了取得正常布局,建议 'line-height' 计算值设置永远大于 'font-size' 计算值设置。 " },
-	"css_0047_suggestion": { "message": "使用 Javascript 实现 'min-width' 和 'max-width' 特性功能。" },
-	"css_0048_suggestion": { "message": "针对不同的需求,可以采取如下方式来避免此问题:" },
-	"css_0049_suggestion": { "message": "尽量避免使用 'line-height' 为 INPUT[type=text]、INPUT[type=password]、INPUT[type=button]、INPUT[type=file]、input[type=submit] 和 BUTTON 标记设置 ‘line-height’,而应改用规范内说明的 'height' 属性。 " },
-	"css_0050_suggestion": { "message": "如果想让一个触发了 hasLayout 的块级非替换元素的高度为0,可以给这个空的块级非替换元素增加一个空的注释块:" },
-	"css_0051_suggestion": { "message": "在页面上添加&lt;!DOCTYPE HTML&gt;,使页面工作在标准模式下。" },
-	"css_0052_suggestion": { "message": "使用 Javascript 实现 'min-height' 和 'max-height' 特性功能。" },
-	"css_0053_suggestion": { "message": "出现这种情况时,应避免使用 'baseline' 对齐方式,需为元素指定 'vertical-align' 值非 'baseline',推荐使用 'vertical-align:bottom' 或  'vertical-align:top'。" },
-	"css_0054_suggestion": { "message": "为了取得正常布局,建议 'line-height' 计算值永远大于 'font-size' 计算值设置。" },
-	"css_0055_suggestion": { "message": "为了准确得到容器高度,建议避免使用行高为行内元素指定高度,而应改用块标记,并且明确的指定其 'height' 值。" },
-	"css_0056_suggestion": { "message": "在使行内元素绝对定位的时候,要注意其行高对静态位置带来的影响,明确设置定位的元素偏移位置。" },
-	"css_0057_suggestion": { "message": "如果在 非标准模式 中,需要父容器在仅有行内替换元素的情况下计算出包含文本基线高度的行高值,则必须加入其他行内文本元素。" },
-	"css_0058_suggestion": { "message": "给 MARQUEE 元素定义具体的宽度,保证各浏览器兼容。" },
-	"css_0059_suggestion": { "message": "同时设置 'overflow-x' 和 'overflow-y' 的值,不要出现其中之一为 'hidden' 时,而另一个是 'visible' 的情况;" },
-	"css_0060_suggestion": { "message": "根据实际需求可以去掉包含块的 'overflow:hidden' 或采用其他定位方案,避免在 IE 中触发此问题,实现在各浏览器表现一致。" },
-	"css_0061_suggestion": { "message": "此种情况时可以将 IE6 IE7 IE8(Q) 浏览器的 UL OL 标记样式更改为与其他浏览器样式一致,即:" },
-	"css_0062_suggestion": { "message": "为了避免此问题,建议在设置 'list-style-type:none' 时仅将 'list-style-position' 属性值设置为默认的 'outside'。 " },
-	"css_0063_suggestion": { "message": "建议弃使用 'disc | circle | square' 这三个样式,改用背景图片代替样式显示,如: " },
-	"css_0064_suggestion": { "message": "IFRAME 透明是一个常见的问题,有时候我们需要其透明,这时需要为 IFRAME 元素添加属性 allowtransparency=\"true\"," },
-	"css_0065_suggestion": { "message": "避免为非 BODY、HTML 元素设置 'background-attachment:fixed' 特性。" },
-	"css_0066_suggestion": { "message": "由于各浏览器对 '@font-face' 规则字体格式支持存在差异,若仅通过定义一个 '@font-face' 规则,可以通过 CSS hack 的方式在 IE、Firefox、Chrome、Safari、Opera 中得到相同的字体效果:" },
-	"css_0067_suggestion": { "message": "尽量给需要修饰的文本单独设置 'text-decoration' 特性;若需要给图片添加上划线或下划线,则使用 'border-top' 和 'border-bottom' 来模拟 'text-decoration'。" },
-	"css_0068_suggestion": { "message": "根据具体应用环境,参照“问题分析”中各种情况在各浏览器下的结果汇总使用兼容性较好的方案。" },
-	"css_0069_suggestion": { "message": "避免在包含宽度比自身小的块级元素或表格的元素上设置 'text-align' 特性。" },
-	"css_0070_suggestion": { "message": "不要在 TD 标记中使用 'white-space:nowrap' 样式,或者为 TABLE 标记设置 'table-layout:fixed' 样式严格计算其内部布局。" },
-	"css_0071_suggestion": { "message": "不要在包含块级元素的元素上使用 'text-overflow:ellipsis';" },
-	"css_0072_suggestion": { "message": "限制 TD 元素宽度并设置 'word-wrap' 特性值为默认值。" },
-	"css_0073_suggestion": { "message": "不在 SELECT 元素上设置 'word-wrap:break-word;'" },
-	"css_0074_suggestion": { "message": "删除不必要的空格。" },
-	"css_0075_suggestion": { "message": "避免在使用 px 单位时为 'letter-spacing' 特性设置小数数值。" },
-	"css_0076_suggestion": { "message": "选用合适的文档头,让该页面使用标准模式;如:" },
-	"css_0077_suggestion": { "message": "在 'table-layout:fixed' 这种固定布局算法下的表格中,可以为表格最后一列不设置宽度,尽量消除由算法差异带来的列的宽度差异。" },
-	"css_0078_suggestion": { "message": "在空的 TD、TH 元素内添加 ' ';" },
-	"css_0079_suggestion": { "message": "避免在 TD 元素内出现左浮动、内容为空的元素。" },
-	"css_0080_suggestion": { "message": "避免为 TR 设置高度。 " },
-	"css_0081_suggestion": { "message": "避免为 TD 元素设置 'padding-top' 'padding-bottom' 特性" },
-	"css_0082_suggestion": { "message": "尽量避免为 TABLE 级别的元素设置百分比为单位的 'height' 特性,以避免 Firefox 对 TABLE 级别元素的高度算法 Bug。" },
-	"css_0083_suggestion": { "message": "避免出现空单元格,使用 “ ” 代替空单元格。" },
-	"css_0084_suggestion": { "message": "在需要留空的单元格中加一个空格: " },
-	"css_0085_suggestion": { "message": "不要同时为 TABLE 元素及其内部各列显式设置宽度,当需要应用各列设定宽度时,TABLE 元素的宽度应保持默认的 \"auto\" ,当需要限定 TABLE的宽度时,应至少保证有一列的宽度为默认的  \"auto\" 。" },
-	"css_0086_suggestion": { "message": "使用标准模式——&lt;!DOCTYPE html&gt;;尽量避免在表格及块级元素上使用百分比高度。" },
-	"css_0087_suggestion": { "message": "使用 CSS 规范中定义的 'cursor:  pointer' 样式代替 'cursor:hand' 样式。" },
-	"css_0088_suggestion": { "message": "由于 'outline' 特性不影响盒模型及文本流,所以使用此特性时,在不支持的 IE6 IE7 IE8(Q) 中不会出现影响布局的兼容性问题,只会在较小的程度上影响视觉效果,暂时没有好的替代方案。" },
-	"css_0089_suggestion": { "message": "这是由于疏忽笔误造成的错误,首先应按照 W3C 规范中的标准写法定义 'font-family' 。而不能利用浏览器对错误代码的容错机制。" },
-	"css_0090_suggestion": { "message": "对于那些长度类型的 CSS 特性,在 CSS 代码及使用 DOM 操作相关样式时,应明确为其标注单位字符。 " },
-	"css_0091_suggestion": { "message": "合理运用各浏览器对 CSS 错误解析规则的差异及 CSS hack 为不同浏览器赋予不同样式。" },
-	"css_0092_suggestion": { "message": "坚持以字母开头命名选择器,这样可保证在所有浏览器下都能兼容。" },
-	"css_0093_suggestion": { "message": "如果页面需要精确到像素级的话,建议为宽高属性指定整型值。" },
-	"css_0094_suggestion": { "message": "尽量避免同时使用 'margin-left' 与 float:left,及 'margin-right' 与 float:right;" },
-	"css_0095_suggestion": { "message": "遵照 W3C 规范所描述的,为单元格元素设置 \"overflow:hidden\" ,在所有浏览器中均会裁切溢出单元格的内容。" },
-	"css_0096_suggestion": { "message": "明确地为 TD 的子元素设置 'white-space' 特性,避免使 TD 元素自动继承父元素的 'white-space' 特性。或者避免同时为 TD 元素设置宽度及 white-space:nowrap(或是 nowrap 属性)。" },
-	"css_0097_suggestion": { "message": "由于 TABLE 元素的 align 属性已经被 W3C 废弃,所以在考虑 TABLE 元素对齐问题上应避免使用 align 属性,而改用 CSS。" },
-	"css_0098_suggestion": { "message": "如果需要一个 A 元素能根据用户的行为改变样式,请添加 A 元素的 'href' 属性使伪类生效。" },
-	"css_0099_suggestion": { "message": "尽可能不为 BR 元素设定一个可能小于其继承值的值。" },
-	"css_0100_suggestion": { "message": "U、S 元素本身是废弃元素,应避免使用,而用 CSS 相关特性来替代这些元素产生的效果。" },
-	"css_0101_suggestion": { "message": "在使用 border-collapse:collapse 时应保证 TABLE 元素的 cellspacing 属性值为 0。" },
-	"css_0102_suggestion": { "message": "W3C 规范并没有说明 scrolling 属性应该控制子页面哪个元素的滚动条的生成或者 'overflow' 特性,为防止在某些情况下 Chrome Safari 的 IFRAME 子页面中出现多余滚动条,应避免为 HTML 或者 BODY 元素设置 overflow:scroll。" },
-	"css_0103_suggestion": { "message": "使用标准模式。" },
-	"css_0104_suggestion": { "message": "FONT 元素本身是废弃元素,并且其所有属性均已不推荐使用,应避免使用 FONT 元素。" },
-	"css_0105_suggestion": { "message": "若有页面需求是要求其他元素遮挡 Flash " },
-	"css_0106_suggestion": { "message": "align 属性已被废弃,应避免使用这类 HTML 属性。为 IMG、OBJECT、IFRAME、TABLE、APPLET、EMBED 元素使用 CSS 的 'float' 特性以达到相同的效果。" },
-	"css_0107_suggestion": { "message": "1. 明确为浮动元素设置一个宽度值,避免其在进行 \"shrink-to-fit\" 计算时在不同浏览器之间出现的宽度计算差异。" },
-	"css_0108_suggestion": {"message": "若需要在所有浏览器下元素图片不随元素内容滚动,则不给元素设置任何背景,并且在元素的父元素上设置背景图,例如:"},
-	"css_0109_suggestion": {"message": "给标签设置样式 -moz-user-select:none ;-webkit-user-select:none 同时标签设置 unselectable=\"on\" ,保证各浏览器都可以禁止内容选中。"},
-	"css_0110_suggestion": {"message": "'border-spacing' 不是所有浏览器都能很好的支持,若水平和垂直方向的空间相等,可以用 TABLE 的 cellspacing 属性代替 'border-spacing' 特性。"},
-	"css_0111_suggestion": { "message": "要对设置有百分比高度的块级元素的包含块设置明确的 height 属性值。" },
-	"css_0112_suggestion": { "message": "'border-spacing' 不是所有浏览器都能很好的支持,若水平和垂直方向的空间相等,可以用 TABLE 的 cellspacing 属性代替 'border-spacing' 特性。"},
-	"css_0113_suggestion": { "message": "避免出现空 TABLE ,保证各浏览器兼容。" },
-	"css_0114_suggestion": { "message": "不要将 'clear' 特性应用在浮动元素上,以免出现上述不兼容的问题。" },
-	"css_0115_suggestion": { "message": "如果希望一个浮动元素能阻挡与其向相同方向浮动的兄弟元素,请确保其高度不为零,以使页面布局在各浏览器中的表现一致。反之,如果不希望零高度的浮动元素阻挡其兄弟浮动元素,请隐藏该元素,如使用 'display:none'。但要注意,这样做也会使其可能存在的绝对定位的内容也不可见。" },
-	"css_0116_suggestion": { "message": "由于各浏览器对 'zoom' 的实现上存在差异,并且Firefox Opera 并不支持 'zoom',因此不建议为 'zoom' 设定值大于 1 的值来对元素进行缩放应用。" },
-	"css_0117_suggestion": { "message": "避免使用非法的 'float' 特性值。"},
-	"css_0118_suggestion": { "message": "在使用 \"marginwidth\" 和 \"marginheight\" 时应严格遵照规范中的描述,要对其设定大于等于零的整数值。"},
-	"css_0119_suggestion": { "message": "放弃使用 LAYER 元素,改用 CSS 中的绝对定位样式 'position:absloute' 处理相关情况。" },
-
-	"javascript_0001": { "message": "IE6 IE7 IE8 的函数声明和函数表达式的实现与其他浏览器有差异" },
-	"javascript_0002": { "message": "Firefox 对条件判断语句块内的函数声明的处理与其他浏览器有差异" },
-	"javascript_0003": { "message": "Safari Chrome 中用 for in 可以遍历出 Date Array String 对象中被更新的原型方法" },
-	"javascript_0004": { "message": "各浏览器中 Date 对象的 toLocalString 方法的返回值不一致" },
-	"javascript_0005": { "message": "IE6 IE7 IE8 会忽略 JavaScript 代码中大括号之后的第一个分号" },
-	"javascript_0006": { "message": "在 IE6 IE7 IE8(Q) 中不能在 JSON 直接量的最后一个键值对后加 ','" },
-	"javascript_0007": { "message": "IE6 IE7 IE8 不会忽略数组直接量的末尾空元素" },
-	"javascript_0008": { "message": "仅 IE 支持使用含中文标点符号的变量名" },
-	"javascript_0009": { "message": "元素的内联事件处理函数的特殊作用域在各浏览器中存在差异" },
-	"javascript_0010": { "message": "各浏览器中 Date 对象的 getYear 方法的返回值不一致" },
-	"javascript_0011": { "message": "IE6 IE7 IE8(Q) 中的 getElementById 方法能以 name 属性为参数获取某些元素" },
-	"javascript_0012": { "message": "IE6 IE7 IE8(Q) 中的 getElementById 方法的参数不区分大小写" },
-	"javascript_0013": { "message": "IE 在创建 DOM 树时会忽略某些空白字符" },
-	"javascript_0014": { "message": "各浏览器中的 NodeList 接口存在差异" },
-	"javascript_0015": { "message": "IE 中一个对象的 native 方法是跟该对象绑定的" },
-	"javascript_0016": { "message": "IE 混淆了 DOM 对象属性(property)及 HTML 标签属性(attribute),造成了对 setAttribute、getAttribute 的不正确实现" },
-	"javascript_0017": { "message": "IE 对 DOMImplementation 接口的支持程度停留在 DOM 1 Core 阶段" },
-	"javascript_0018": { "message": "已经被废弃的 DocumentLS 接口目前仅在 Firefox 和 Opera 下被部分支持" },
-	"javascript_0019": { "message": "Firefox 和 Opera 不支持 \"document.styleSheets\" 通过 STYLE 元素 id 获取 CSSStyleSheet 对象" },
-	"javascript_0020": { "message": "仅 IE 中的 createElement 方法支持传入 \"HTML String\" 做参数" },
-	"javascript_0021": { "message": "事件模型在各浏览器中存在差异" },
-	"javascript_0022": { "message": "IE6 IE7 IE8 中 getElementsByName 方法的参数不区分大小写" },
-	"javascript_0023": { "message": "各浏览器对于 document、document.body、document.documentElement 对象的 onscroll 事件的支持存在差异" },
-	"javascript_0024": { "message": "IE 标准模式中 BODY 元素的高度变化和 IE6(S) 中 BODY 元素的宽度变化会触发 window.onresize 事件" },
-	"javascript_0025": { "message": "各浏览器对于 DOM 对象的鼠标滚轮事件事件存在差异" },
-	"javascript_0026": { "message": "Firefox 不支持 DOM 对象的 insertAdjacentHTML 和 insertAdjacentText 方法" },
-	"javascript_0027": { "message": "Firefox 不支持 DOM 对象的 outerHTML、innerText、outerText 属性" },
-	"javascript_0028": { "message": "IE6 IE7 IE8(Q) 中 DOM 元素的 offsetParent 在某些情况下为距离其最近的触发了 hasLayout 的祖先级元素" },
-	"javascript_0029": { "message": "插入空白页面 IFRAME 元素时 Chrome Safari Opera 浏览器中会触发 load 事件" },
-	"javascript_0030": { "message": "仅 IE 和 Firefox 支持 window 对象的 onerror 事件" },
-	"javascript_0031": { "message": "各浏览器对元素在没有设置 tabindex 属性时触发 onfocus 事件以及通过其 focus() 方法获得焦点的情况有差异" },
-	"javascript_0032": { "message": "各浏览器对页面 onload 事件处理方式不一致" },
-	"javascript_0033": { "message": "IE Chrome Safari 在计算 'overflow' 特性值为 visible 的容器的 scrollHeight 的值时会考虑其内脱离了文本流的元素" },
-	"javascript_0034": { "message": "Firefox Safari 中对 cookie 中未经编码的中文汉字处理有问题" },
-	"javascript_0035": { "message": "不能保证带有 name 属性的 BUTTON / INPUT [ type = submit / button / image ] 元素的 value 属性值在所有浏览器中都可以被提交到服务端" },
-	"javascript_0036": { "message": "IE 未按预期方式处理 content-type 为 text/plain 的内容" },
-	"javascript_0037": { "message": "IE6 和 Chrome 未按预期方式处理 content-type 为 application/rss+xml 的内容" },
-	"javascript_0038": { "message": "WebKit 中依赖文本流定位的绝对定位元素某些情况下不会更新其位置" },
-	"javascript_0039": { "message": "Webkit 中 NOBR 标签与其他标签紧密相连在某些情况下会导致部分内容无法换行" },
-	"javascript_0040": { "message": "Webkit 浏览器会压缩 OPTION 元素中的全角空格" },
-	"javascript_0041": { "message": "Chrome 中文版配置文件中对最小字体限制为 12px" },
-	"javascript_0042": { "message": "Chrome Safari 中的表单在某些情况下不能够重复提交" },
-	"javascript_0043": { "message": "WebKit 中 MARQUEE 元素 的 behavior 属性值为 alternate 时如果其中包含块级元素则会影响其滚动效果" },
-	"javascript_0044": { "message": "WebKit 中 HR 元素 noshade 属性会影响其 'color' 特性" },
-	"javascript_0045": { "message": "只有 IE 的 TABLE、THEAD、TBODY、TFOOT 有 moveRow 方法" },
-	"javascript_0046": { "message": "只有 IE 支持 TABLE 元素的 'bordercolordark' 和 'bordercolorlight' 属性" },
-	"javascript_0047": { "message": "只有 IE 支持条件注释" },
-	"javascript_0048": { "message": "只有 IE 的脚本引擎支持 VBScript" },
-	"javascript_0049": { "message": "只有 IE 的脚本引擎支持 JScript.Encode" },
-	"javascript_0050": { "message": "Element.all 属性方法只有 IE 和 Opera 支持" },
-	"javascript_0051": { "message": "只有 IE 和 Opera 支持使用 currentStyle 获取 HTMLElement 的计算后的样式" },
-	"javascript_0052": { "message": "只有 IE 和 Opear 支持 FORM.item() 方法" },
-	"javascript_0053": { "message": "只有 IE 支持 CSS Expression" },
-	"javascript_0054": { "message": "只有 IE 支持 CSS Filter" },
-	"javascript_0055": { "message": "IE 的 external 对象提供的方法是 IE 特有的" },
-	"javascript_0056": { "message": "只有 IE 可以设置滚动条样式" },
-	"javascript_0057": { "message": "只有 IE 支持 'writing-mode' 特性" },
-	"javascript_0058": { "message": "只有 IE 和 Opera 支持 TABLE 元素的 cells 属性" },
-	"javascript_0059": { "message": "只有 IE 和 Opera 支持 document.frames" },
-	"javascript_0060": { "message": "只有 IE 支持 mouseenter 和 mouseleave 事件" },
-	"javascript_0061": { "message": "只有 IE 的脚本引擎支持 CollectGarbage ScriptEngine 等 JScript 特有的方法" },
-	"javascript_0062": { "message": "IE 中可以使用 ActiveXObject 创建 Automation 对象,同时该对象的方法及属性名称大小写不敏感" },
-	"javascript_0063": { "message": "只有 IE 支持 OBJECT 元素的 onerror 事件" },
-	"javascript_0064": { "message": "IE 中可以使用 classid 与 codebase 属性结合完成下载、安装和使用 ActiveX 插件" },
-	"javascript_0065": { "message": "IE 会忽略触发 hasLayout 的元素内尾部的全角空格" },
-	"javascript_0066": { "message": "只有 IE 支持 DHTML Behaviors 及相关方法" },
-	"javascript_0067": { "message": "只有 IE 支持 window.createPopup 方法" },
-	"javascript_0068": { "message": "在 IE 中被透明元素遮挡的元素仍能响应鼠标事件" },
-	"javascript_0069": { "message": "只有 IE 的 HTMLElement 有 mergeAttributes 与 clearAttributes 方法" },
-	"javascript_0070": { "message": "只有 IE 的 HTMLElement 有 applyElement 方法" },
-	"javascript_0071": { "message": "只有 IE 的 HTMLDOMNode 有 replaceNode 与 swapNode 方法" },
-	"javascript_0072": { "message": "只有 IE 支持 BGSOUND 标签" },
-	"javascript_0073": { "message": "仅 IE 和 Opera 支持 HTMLFrameElement 和 HTMLIFrameElement 的 document 属性" },
-	"javascript_0074": { "message": "只有 IE 和 Opera 的 HTMLDOMNode 有 removeNode 方法" },
-	"javascript_0075": { "message": "只有 IE 支持 XML 数据岛" },
-	"javascript_0076": { "message": "IE 中页面内 OBJECT 对象相对其他浏览器额外包含了其引入的 ActiveX 插件的部分私有属性" },
-	"javascript_0077": { "message": "Firefox 中块级元素高度或宽度过小会导致滚动条消失" },
-	"javascript_0078": { "message": "Firefox 不识别 type 或 language 被设置为 JScript 的 SCRIPT 标签" },
-	"javascript_0079": { "message": "Firefox 中 Date.now 方法被重写后 MARQUEE 元素不再滚动" },
-	"javascript_0080": { "message": "IE 支持使用 window.clipboardData 访问系统剪贴板,Chrome 和 Safari 中存在类似的 Clipboard 对象但尚未实现,Firefox 和 Opera 不支持这类对象" },
-	"javascript_0081": { "message": "document.all 在各浏览器中的支持不同" },
-	"javascript_0082": { "message": "特定的 URL 伪协议需安装提供该协议的特定软件才有效" },
-	"javascript_0083": { "message": "浏览器后退按钮在各浏览器中的行为在某种情况下不一致" },
-	"javascript_0084": { "message": "各浏览器对 TABLE、TH、TD 元素的 bordercolor 属性的处理有差异" },
-	"javascript_0085": { "message": "获取文档可视尺寸(视口)时在各浏览器中的参考元素有差异" },
-	"javascript_0086": { "message": "各浏览器对于获取文档水平及垂直方向滚动条位置(scrollLeft、scrollTop)时的参考元素存在差异" },
-	"javascript_0087": { "message": "各浏览器在宽度不够时不会对连续的全角空格进行折行处理存在差异" },
-	"javascript_0088": { "message": "各浏览器中对直接以 id 或者 name 属性值获取元素存在差异" },
-	"javascript_0089": { "message": "某些情况下除了 IE 和 Opera 之外的浏览器中 window.close 方法无法关闭由直接输入 URL 或 Ctrl + 点击链接方式打开的窗口" },
-	"javascript_0090": { "message": "动态引入的外部 JS 文件在各浏览器中的加载顺序不一致" },
-	"javascript_0091": { "message": "document.write 方式引入外部 JavaScript 文件导致脚本程序执行顺序不同以及 DOM 树更新延迟问题" },
-	"javascript_0092": { "message": "Webkit 浏览器中 TD 的 \"noWrap\" 属性会引起的它里面 MARQUEE 元素宽度计算错误" },
-	"javascript_0093": { "message": "非 IE 浏览器中为 MARQUEE 元素设置某些 CSS 特性会导致其失去滚动效果" },
-	"javascript_0094": { "message": "Chrome Safari 中设置了 'bordercolor' 属性的 TABLE 元素,会为其自动设置3px的边框宽度" },
-	"javascript_0095": { "message": "IE6 IE7 IE8 对 onreadystatechange 事件的扩充" },
-	"javascript_0096": { "message": "各浏览器对遇到中文标点符号时折行的处理有差异" },
-	"javascript_0097": { "message": "在 IE 中一些特殊字符的最终呈现字体不是设定值" },
-	"javascript_0098": { "message": "Firefox 不支持 DOM 元素 style 属性中的 pixel* 属性,并且某些情况下 Webkit 浏览器 pixel* 属性的返回值和 IE 中不同" },
-	"javascript_0099": { "message": "新版本的浏览器都已经不支持古老的 document.layers" },
-	"javascript_0100": { "message": "各浏览器对使用 document.id 和 document.name 获取对象的支持存在差异" },
-	"javascript_0101": { "message": "IE 和 Firefox 可以通过特定方法使 innerHTML 方法载入的 SCRIPT 标签中的 JavaScript 代码在页面加载后也可以执行" },
-	"javascript_0102": { "message": "IE8(S) Firefox Opera Chrome Safari 在某些情况下计算 MARQUEE 元素的宽度时会参考其子元素的宽度" },
-	"javascript_0103": { "message": "IE 和 Chrome 支持通过 EMBED 元素嵌入 MP3 格式文件" },
-	"javascript_0104": { "message": "判断浏览器类型或版本时使用的方法不当将导致代码不能按照预期的效果执行" },
-	"javascript_0105": { "message": "IE 中 location=\"\" 或 location.href=\"\" 将使页面跳转至当前页面所在根目录" },
-	"javascript_0106": { "message": "Opera 和 Chrome 对模态对话框(showModalDialog)的支持有缺陷,且非 IE 浏览器均不支持非模态对话框(showModelessDialog)" },
-	"javascript_0107": { "message": "溢出定位流的不可视元素,其包含块的滚动条生成差异" },
-	"javascript_0108": { "message": "IE8 标准模式及 Opera 不支持 WBR 元素" },
-	"javascript_0109": { "message": "各浏览器对 navigator 对象中几个与语言相关的属性的返回值存在差异" },
-	"javascript_0110": { "message": "各浏览器创建 XMLHttpRequest 对象的方式不同" },
-	"javascript_0111": { "message": "各浏览器对 window.execScript 方法的支持不同"},
-    "javascript_0112": { "message": "各浏览器下在向文档树中插入通过 cloneNode(true) 创建的节点时,其内的 SCRIPT 元素中的脚本执行有差异" },
-	"javascript_0113": { "message": "IE6 IE7 IE8 Opera 支持除 INPUT 和 BUTTON 元素以外的其他元素的 click 方法" },
-	"javascript_0114": {"message": "为 SELECT 对象增加或删除选项的方法在各浏览器中的支持情况不同"},
-	
-	
-	"javascript_0001_suggestion": { "message": "避免使用 IE 的这些“特性”,以保证兼容所有浏览器。" },
-	"javascript_0002_suggestion": { "message": "将条件语句中的函数声明替换为函数表达式,如:" },
-	"javascript_0003_suggestion": { "message": "对于数组,避免用 for...in 方式而采用索引即数字下标的形式枚举数组成员。" },
-	"javascript_0004_suggestion": { "message": "要获得相同格式的时间字符串,请不要使用 Date.prototype.toLocaleString() 方法,可以通过分别使用 getFullYear、getMonth、getDate 和 getDay 分别获得各关键字符串并拼装。" },
-	"javascript_0005_suggestion": { "message": "按照规范书写正确的代码。" },
-	"javascript_0006_suggestion": { "message": "即便规范没有强调最后一个键值对的后边不能出现 ',',也要确保最后一个键值对之后没有多余的 ',',以兼容各浏览器。" },
-	"javascript_0007_suggestion": { "message": "数组直接量的最后不要出现 ',',以保证兼容各浏览器。" },
-	"javascript_0008_suggestion": { "message": "避免在变量名(即标识符)中出现中文标点,以保证兼容各浏览器。" },
-	"javascript_0009_suggestion": { "message": "1. 尽量不要使用内联事件处理函数,使用 DOM 标准的事件注册方式为该元素注册事件处理函数,如:" },
-	"javascript_0010_suggestion": { "message": "要获得一个具体时间的年份,请不要使用 Date.prototype.getYear() 方法,使用 Date.prototype.getFullYear() 代替,以在各浏览器下获得相同的表现。" },
-	"javascript_0011_suggestion": { "message": "在使用 document.getElementById 方法获取页面元素时,应传入元素的 id 属性值,而不能使用元素的 name 属性值。" },
-	"javascript_0012_suggestion": { "message": "在使用 document.getElementById 获取页面元素时,应保证作为参数的 id 与目标元素的实际 id 值完全一致。" },
-	"javascript_0013_suggestion": { "message": "1. 没有必要时尽量去掉各标签之间的空白字符。" },
-	"javascript_0014_suggestion": { "message": "要从 NodeList 中获取元素,请使用 NodeList[index]、NodeList[name] 或 NodeList.item(index),以保证兼容各浏览器。" },
-	"javascript_0015_suggestion": { "message": "使用方式 1 达到简写一些 DOM 和 BOM 对象原生方法的目的。" },
-	"javascript_0016_suggestion": { "message": "避免使用 \"Element.setAttribute(\"style\", \"XXX\")\" 在所有浏览器中设置元素的 style 属性,可以改用符合规范的 \"Element.style.cssText = \"XXX\"\";" },
-	"javascript_0017_suggestion": { "message": "避免使用各浏览器支持程度不同的 DOMImplementation 的接口。" },
-	"javascript_0018_suggestion": { "message": "由于 W3C 推荐的标准中,已经放弃了 DocumentLS 接口,为更好的兼容各浏览器,建议采用 XMLHttpRequest 方式载入xml文件,示例代码如下:" },
-	"javascript_0019_suggestion": { "message": "避免使用 \"document.styleSheets\" 通过 STYLE 元素 id 获取 CSSStyleSheet 对象,使用 W3C 规范中的整数下标方式获取。" },
-	"javascript_0020_suggestion": { "message": "对于一般的非替换元素,在各浏览器中均使用 W3C 规范中的标准的为 createElement 方法传入标签名的做法。" },
-	"javascript_0021_suggestion": { "message": "1. 使用特性判断创建无兼容性问题的事件监听器绑定和解绑函数" },
-	"javascript_0022_suggestion": { "message": "在使用 document.getElementsByName 方法获取页面元素时,应保证作为参数的 name 与目标元素的实际 name 值完全一致。" },
-	"javascript_0023_suggestion": { "message": "在给整个浏览器窗口绑定滚动事件 (scroll) 的时候,绑定到 window 对象上。" },
-	"javascript_0024_suggestion": { "message": "1. 不期望触发 window.onresize 事件时:" },
-	"javascript_0025_suggestion": { "message": "利用浏览器类型判断,给各浏览器绑定各自支持的鼠标滚轮事件。如,res.html" },
-	"javascript_0026_suggestion": { "message": "在 Firefox 中,可通过扩展 HTMLElement 的原型 (prototype) 来实现这两个方法:" },
-	"javascript_0027_suggestion": { "message": "在 Firefox 中,可通过扩展 HTMLElement 的原型 (prototype) 来实现相关属性。" },
-	"javascript_0028_suggestion": { "message": "使得元素的 offsetParent 在各浏览器中一致。例如,对于以上测试样例,可考虑对于 DIV[id=\"div\"] 设置 position 为(absolute | relative | fixed)。" },
-	"javascript_0029_suggestion": { "message": "为 IFRAME 标签的 src 属性指定具体 URL 后再将节点插入 DOM 树中 。" },
-	"javascript_0030_suggestion": { "message": "放弃使用 window.onerror,通过合理使用 try-catch 来达到近似的效果。" },
-	"javascript_0031_suggestion": { "message": "对于一般常见的可视元素,若需要元素可触发 onfocus 事件以及通过其 focus() 方法获得焦点,则应为其设置 tabindex 属性。" },
-	"javascript_0032_suggestion": { "message": "统一为 window 对象的 onload 事件绑定函数,避免在 Firefox 中产生 document.body.onload 事件理解歧义。" },
-	"javascript_0033_suggestion": { "message": "确保读取 scrollHeight 属性的元素均创建了新的 block formatting context,或者此容器与内部子容器处于同一文档流中,以此避免各浏览器中读数不同。" },
-	"javascript_0034_suggestion": { "message": "在设置和读取 cookie 时,始终为字符进行编解码操作,推荐使用 \"encodeURIComponent\" 和 \"decodeURIComponent\" 方法做相应编解码工作。" },
-	"javascript_0035_suggestion": { "message": "通常情况下,服务器端不需要按钮的 key/value 信息,建议删除按钮的 name 属性,不使其成为 successful control。" },
-	"javascript_0036_suggestion": { "message": "这是由于 IE 浏览器的特有内容嗅探机制导致,故在不修改服务器端代码的情况下,无法通过常规办法解决此 IE 特性问题。更多关于此问题的资料参考官方信息:Internet Explorer 未按预期方式处理“Text/Plain”内容类型。" },
-	"javascript_0037_suggestion": { "message": "各浏览器对于 RSS 的支持及渲染方式为浏览器各自实现导致,故无法通过常规办法使各浏览器达到一致的效果,对于暂不支持 RSS 的浏览器应给予提示。Chrome 可通过安装扩展插件实现此功能。" },
-	"javascript_0038_suggestion": { "message": "在绝对定位元素的包含块可能发生改变时(即该绝对定位元素的“静态位置”可能发生变化时),不要让该绝对定位元素依赖其“静态位置”来定位,给该元素设定明确的 left、right、top 或 bottom 值。" },
-	"javascript_0039_suggestion": { "message": "&lt;div style=\"width:150px;background:gold\"&gt;" },
-	"javascript_0040_suggestion": { "message": "避免在 OPTION 元素中使用全角空格,必要时可使用两个 \" \" 代替。" },
-	"javascript_0041_suggestion": { "message": "避免使用小于 12px 的字号,过小的文字建议用图片代替。" },
-	"javascript_0042_suggestion": { "message": "每次提交表单后都修改 action 属性内的 URL(加入时间戳)。" },
-	"javascript_0043_suggestion": { "message": "在 MARQUEE 标记内避免使用普通流中的块级元素,或用脚本程序模拟 MARQUEE 标记的效果。" },
-	"javascript_0044_suggestion": { "message": "去除 HR 元素的 noshade 属性或者将 noshade 属性放置在 color 属性之前。" },
-	"javascript_0045_suggestion": { "message": "不要使用 IE 的特性设计页面代码。" },
-	"javascript_0046_suggestion": { "message": "这两个属性为 IE 私有属性,并且 MSDN 官方文档上也不再推荐使用它们。所以,若要达到这两个属性的效果,可以在 TABLE 和  TD 元素上使用 \"border-color\" 。" },
-	"javascript_0047_suggestion": { "message": "在没有特殊需求的情况下,尽量避免使用 IE 特有的条件注释。" },
-	"javascript_0048_suggestion": { "message": "避免使用 VBScript,使用 JavaScript 书写页面上的脚本。" },
-	"javascript_0049_suggestion": { "message": "避免使用 IE 特有脚本扩展方式书写代码。" },
-	"javascript_0050_suggestion": { "message": "使用 Node 接口的 'childNodes' 属性,注意在非 IE 浏览器中使用该属性会返回文本节点,使用 Node.nodeType 判断节点类型以获取想要的节点;" },
-	"javascript_0051_suggestion": { "message": "要获取元素的某种样式计算后的值,请考虑所有浏览器的兼容性情况。如使用以下代码给不支持 getComputedStyle 的 IE 提供与其他浏览器相同的函数:" },
-	"javascript_0052_suggestion": { "message": "当使用 item 方法遍历 HTMLCollection 时,只有在IE Opera 浏览器下可以直接获取 HTMLFormElement 元素内所有标记引用,其他浏览器并不支持这种方法。" },
-	"javascript_0053_suggestion": { "message": "CSS Expression 是一个已经过时的技术,微软官方日后可能不会再对其进行开发及支持。 除非为了利用 CSS hack 去弥补某些 IE 中不支持的 CSS 特性,否则应尽量避免使用 CSS Expression。" },
-	"javascript_0054_suggestion": { "message": "由于 CSS Filter 是 IE 特有的技术,其他浏览器均不支持,所以为了最大的兼容性及标准化,应尽量避免为 IE 单独使用 Filter,如需要其某些特效,应同时考虑其他浏览器,利用非 IE 浏览器对 CSS3 草案的良好支持保证最好的兼容性。" },
-	"javascript_0055_suggestion": { "message": "不要使用 IE 的特性设计页面代码。" },
-	"javascript_0056_suggestion": { "message": "尽量不要去修改滚动条的样式。以免造成 IE 跟其他浏览器之间的差异。" },
-	"javascript_0057_suggestion": { "message": "其他浏览器中不支持文字的垂直排列,所以,尽量避免使用 IE 中特有的 'writing-mode' 特性。" },
-	"javascript_0058_suggestion": { "message": "避免使用 TABLE 的 cells 属性获取元素,而对 table row(TR) 使用 cells 属性,或用 document.getElementsByTagName 等方式获取元素。" },
-	"javascript_0059_suggestion": { "message": "用 window.frames 代替 document.frames。" },
-	"javascript_0060_suggestion": { "message": "1. 避免使用 mouseenter 和 mouseleave 事件。" },
-	"javascript_0061_suggestion": { "message": "避免使用此类由浏览器厂商提供的私有方法和扩展。" },
-	"javascript_0062_suggestion": { "message": "为了最好的兼容性,应尽量避免使用这种技术,或者在非 IE 浏览器中使用其他的替代技术,如 NPAPI 插件。" },
-	"javascript_0063_suggestion": { "message": "避免使用非标准的 onerror 事件。对于 OBJECT 元素可以通过对客户端浏览器类型进行判断,来达到有好地提示错误的效果。" },
-	"javascript_0064_suggestion": { "message": "ActiveX 为微软专有技术,仅被 Windows 中的 IE 支持。所以若希望这类组件可以运行于多种浏览器,则需要使用其他非 IE 支持的 NPAPI 重新设计在这种接口下的插件。以保证最好的兼容性。" },
-	"javascript_0065_suggestion": { "message": "避免使用全角空格占位,使用“ ”代替全角空格。" },
-	"javascript_0066_suggestion": { "message": "1. 避免使用 IE 的特性。" },
-	"javascript_0067_suggestion": { "message": "尽量不要使用 IE 的特性,必须使用弹出窗口时,可以通过脚本使用兼容各浏览器的方式来实现。" },
-	"javascript_0068_suggestion": { "message": "如果想遮盖某些元素,请为其设置一个非 'transparent' 的背景色。如果需要让这个遮掩层“隐形”,使用 'opacity:0' 和 'filter:alpha(opacity=0)' 来实现。" },
-	"javascript_0069_suggestion": { "message": "尽量避免使用 IE 独有的这两个方法编写代码,改用标准方法 setAttribute 和 removeAttribute 单独设置和删除属性来实现需求。" },
-	"javascript_0070_suggestion": { "message": "尽量避免使用 applyElement 方法编写代码,可以使用标准方法实现同样功能,如 appendChild、insertBefore、removeChild、replaceChild、cloneChild 等。" },
-	"javascript_0071_suggestion": { "message": "不要使用 IE 的特性设计页面代码。" },
-	"javascript_0072_suggestion": { "message": "如果背景音乐是必须的,请考虑使用被广泛使用的 Flash 插件来实现,以兼容所有浏览器。" },
-	"javascript_0073_suggestion": { "message": "使用 HTMLFrameElement 或 HTMLIFrameElement 对象的 contentWindow 属性得到该框架页的 window 对象应用,再访问其下的 document 对象。" },
-	"javascript_0074_suggestion": { "message": "不要使用 IE 的特性设计页面代码。" },
-	"javascript_0075_suggestion": { "message": "应考虑其他标准的、符合 W3C 规范的、各浏览器均支持的 XML 相关技术解析 XML 文档。" },
-	"javascript_0076_suggestion": { "message": "ActiveX 技术为微软的专有技术,仅在Windows 下的 IE 浏览器中可以得到支持。" },
-	"javascript_0077_suggestion": { "message": "针对 Firefox 中的这种特有现象,在确定不需要滚动条时为元素设置 'overflow:hidden',并且合理地为需要携带滚动条元素设置其宽度及高度。" },
-	"javascript_0078_suggestion": { "message": "为了保证脚本程序可以正常执行,除非特意使用仅 IE 支持的 VBScript 和 Script Encoder 机制外,应当将 SCRIPT 标记的 \"type\" 属性设置为 \"javascript\",并且不要设置已经废弃的 \"Languange\" 属性。" },
-	"javascript_0079_suggestion": { "message": "MARQUEE 元素为非 W3C 标准元素,应尽量避免使用。同时应尽可能不对原生的 JavaScript 进行修改甚至删除。" },
-	"javascript_0080_suggestion": { "message": "判断浏览器类型,若不是 IE 则弹出提示,告诉用户当前浏览器不能访问剪贴板。如:" },
-	"javascript_0081_suggestion": { "message": "由于 document.all 方法存在支持程度问题,获取元素还是推荐用 W3C DOM 规范中提供的 document.getElementById、document.getElementsByTagName 等标准方法。" },
-	"javascript_0082_suggestion": { "message": "某些协议是由特定的厂商自定义的,如:\"tencent://\" 和 \"msnim:chat\" 之类,需安装特定的客户端软件以注册该类伪协议,方可正常使用。例如,安装 QQ 或 MSN 应用程序。" },
-	"javascript_0083_suggestion": { "message": "以上所提到的情况,我们应该尽量避免,我们期望随着各浏览器新版本的发布,相应的问题也能得到修复,如 Chrome 的新版本就修复了 IFRAME 地址改变不记录历史记录的问题。" },
-	"javascript_0084_suggestion": { "message": "在 W3C HTML4 属性表中没有找到 bordercolor 属性,可见这并不是 W3C 规范中的标准属性,各浏览器根据各自的理解实现了该属性的渲染方式,应避免使用这种非标准属性。" },
-	"javascript_0085_suggestion": { "message": "当出现页面垂直滚动条的时候尽量使用 'document.body.scrollHeight' 获取页面滚动条的高度。" },
-	"javascript_0086_suggestion": { "message": "使用 \"||\" 逻辑语句将这两种获取方式相连,以保证兼容性。如:" },
-	"javascript_0087_suggestion": { "message": "使用两个半角空格代替一个全角空格。" },
-	"javascript_0088_suggestion": { "message": "通过上面的测试可以看到,仅仅在通过 name 属性获取 IFRAME 和 FRAME 元素内子页面的 window 对象时,所有浏览器没有差异。" },
-	"javascript_0089_suggestion": { "message": "使用 window.close() 来关闭窗口时,需注意以下两点:" },
-	"javascript_0090_suggestion": { "message": "对于必须动态附加到文档的外部 js 文件,要保证动态引入的脚本全部执行完成后,才能执行后续代码。" },
-	"javascript_0091_suggestion": { "message": "如果外部引用的 JavaScript 文件内程序,要求在执行顺序上一致,请避免使用 document.write 语句引入的 JS 程序文件中再次使用他来加载外部 JavaScript 文件。" },
-	"javascript_0092_suggestion": { "message": "HTML 4.01 中表示 \"nowrap\" 属性已经被废弃,使用 'white-space' 样式代替他 。" },
-	"javascript_0093_suggestion": { "message": "首先 MARQUEE 元素为非 W3C 标准元素,应尽量避免使用。若必须使用,则应尽量避免为 MARQUEE 元素设置其默认值之外的 'overflow'、 'display'、'-moz-bind' 特性值。" },
-	"javascript_0094_suggestion": { "message": "避免给 TABLE 设置 'bordercolor' ,使用 CSS 中 'border' 实现其效果,保证各浏览器兼容。" },
-	"javascript_0095_suggestion": { "message": "在现行 W3C 标准规范中仅有 XmlHttpRequest 对象中存在 onreadystatechange 事件 ( 请参考  XMLHttpRequest 规范 )。" },
-	"javascript_0096_suggestion": { "message": "对段落文字排版时须谨慎,注意标点符号的位置。如果不好控制文字内容,可以使用Javascript根据文字内容所占的高度动态缩改文字内容。" },
-	"javascript_0097_suggestion": { "message": "针对问题 1,避免使用可以触发这种特殊现象的字体,如 \"宋体\" ,为特殊字符设置其他字体。" },
-	"javascript_0098_suggestion": { "message": "避免使用 IE6 IE7 IE8  浏览器私有 DOM 属性值,改用标准 DOM 规范中定义的有度量单位的 \"width \"、\"height\"、\"top\"、 \"right\"、 \"left\"、 \"bottom\" 属性来代替它们。" },
-	"javascript_0099_suggestion": { "message": "用其他方式判断浏览器类型,避免使用 document.layers 属性;" },
-	"javascript_0100_suggestion": { "message": "使用 W3C 标准中的 document.getElementById(id) 方法获取对象。" },
-	"javascript_0101_suggestion": { "message": "上面提到的 IE 及 Firefox 中使通过 innerHTML 方法动态插入的 SCRIPT 元素中脚本执行的方法均比较特殊,是利用了浏览器的 Bug,或者是利用了浏览器提供的特性。而 innerHTML 方法只是用来插入 HTML 代码,并不能使其中包含的脚本代码执行。" },
-	"javascript_0102_suggestion": { "message": "总是为 MARQUEE 元素显式地设定一个宽度。" },
-	"javascript_0103_suggestion": { "message": "在 HTML5 尚未制定完成且普及时,使用 Flash 播放 MP3 文件,以保证最大的兼容性。" },
-	"javascript_0104_suggestion": { "message": "浏览器类型或版本判别推荐采用分析 navigator.userAgent 属性的方式。" },
-	"javascript_0105_suggestion": { "message": "在为 location 或 location.href 赋值做页面跳转时必须保证所赋的字符串地址的合法性,不要使用空字符串。" },
-	"javascript_0106_suggestion": { "message": "showModalDialog 方法与 showModelessDialog 方法均不被 W3C 支持,虽然 showModalDialog 方法目前已比较广泛的被支持,但还是应避免使用它。因为模态对话框会阻塞父窗口的输入,使其是去焦点,这将对用户体验不利。" },
-	"javascript_0107_suggestion": { "message": "避免在定位流内出现不可视元素且溢出父容器。" },
-	"javascript_0108_suggestion": { "message": "1. 可以为WBR元素添加一个 :after 伪元素,强迫其后插入一个软换行符。" },
-	"javascript_0109_suggestion": { "message": "可以使用下面的代码获取当前浏览器语言:" },
-	"javascript_0110_suggestion": { "message": "判断浏览器版本,使用不同的 XMLHttpRequest 对象创建方式。如:" },
-	"javascript_0111_suggestion": { "message": "window.execScript 方法不是所有浏览器都支持,同时所支持的脚本语言种类并不尽相同,请确定在目标浏览器均支持此方法的情况下再使用它。"},
-	"javascript_0112_suggestion": { "message": "避免深度复制 cloneNode(true) 包含 SCRIPT 元素的节点。" },
-	"javascript_0113_suggestion": { "message": "建议尽量避免对除 INPUT 和 BUTTON 元素以外的其他元素通过 click 方法模拟鼠标点击事件。" },
-	"javascript_0114_suggestion": { "message": "1. 在添加 OPTION 元素时,如果需要向指定索引前插入 OPTION,可以使用 options.add(option, index)。" }
-	
-}

+ 0 - 32
build.sh

@@ -1,32 +0,0 @@
-#!/bin/sh
-MOD_NAME="fe-helper"
-
-#把需要的文件都copy到相应的目录下
-rm -rf output && mkdir output
-cp -r static output/
-cp -r _locales output/
-cp online.manifest.json output/manifest.json
-
-#下载fcp代码,开始编译
-rm -rf fcp*
-cp -r ../fcp/fcp .
-php fcp/index.php $MOD_NAME $USER
-
-#如果有错,则没有产物
-if [[ -f "fcp/error.log" ]];then
-	rm -rf fcp*
-	rm -rf output
-	exit 1;
-fi
-rm -rf fcp*
-
-#删掉svn目录
-cd output
-find . -type d -name ".svn" | xargs rm -rf
-rm -rf static.uncompress
-cd ../ && mv output $MOD_NAME && mkdir output && mv $MOD_NAME output
-
-#生成zip包
-cd output
-zip -r $MOD_NAME.zip $MOD_NAME/ > /dev/null
-cd ../

+ 0 - 54
config.php

@@ -1,54 +0,0 @@
-<?php
-return array(
-	'DEBUG'                       	=>	1 ,       //是否是debug模式,debug模式下打印各个功能编译的时间
-	'TPL_LEFT_DELIMITER'          	=>	'<&' ,    //smarty左界符
-	'TPL_RIGHT_DELIMITER'         	=>	'&>' ,    //smarty右界符
-	'TPL_SUFFIX'                  	=>	'html' ,  //模板文件后缀名
-	'FILE_ENCODING'               	=>	'utf-8' , //文件编码
-	'MOD_DIR_CHECK'               	=>	0 ,       //是否进行模块目录检查,
-	'MOD_FILENAME_CHECK'          	=>	0 ,       //是否进行文件命名检查
-	'MOD_JS_REGULAR_CHECK'        	=>	0 ,       //是否进行js规范检测
-	'MOD_CSS_REGULAR_CHECK'       	=>	0 ,       //是否进行css规范检测
-	'MOD_HTML_REGULAR_CHECK'      	=>	0 ,       //是否进行html规范检测
-	'MOD_SMARTY_REGULAR_CHECK'    	=>	0 ,       //是否进行smarty模板规范检测
-	'MOD_DOS2UNIX'                	=>	0 ,       //是否对原文件进行dos2unix格式转换
-	'MOD_JS_BEAUTIFY'             	=>	0 ,       //是否进行js beautify
-	'MOD_CSS_BEAUTIFY'            	=>	0 ,       //是否进行css beautify
-	'CSS_BEAUTIFY_INDENT'         	=>	'space' , //缩进符号 tab/space
-	'MOD_CSS_SPRITES'             	=>	0 ,       //是否进行css sprites
-	'CSS_SPRITES_REGULAR'         	=>	'' ,      //a|gif|1,c|png|2,文件夹_后缀_方向, 1是垂直方向,2是水平方向
-	'CSS_SPRITES_CONFIG'          	=>	array(    //css sprites的配置项
-		'spritetest'	=>	array(    //css文件文件夹或文件名,*表示所有
-			'image'   	=>	'png,gif,jpg' ,//指定需要合并的图片类型,可以支持这三种
-			'margin'  	=>	5 ,       //配置小图之间的间距,默认是5px
-		),
-	),
-	'MOD_CSS3_AUTOCOMPLETE'       	=>	0 ,       //css3样式自动补全
-	'MOD_JS_COMBINE'              	=>	1 ,       //JS文件是否启用合并
-	'MOD_CSS_COMBINE'             	=>	1 ,       //CSS文件是否启用合并
-	'MOD_HTML_COMPRESS'           	=>	1 ,       //HTML文件是否启用压缩
-	'MOD_JS_COMPRESS'             	=>	1 ,       //JS文件是否启用压缩
-	'JS_COMPRESS_ENGINE'          	=>	'yui' ,   //JS压缩压缩引擎,可选:yui(default)、uglifyjs
-	'MOD_CSS_COMPRESS'            	=>	1 ,       //CSS文件是否启用压缩
-	'MOD_CSS_SUPER_COMPRESS'      	=>	0 ,       //是否开启CSS极限压缩,会同时修改HTML,css的class在js里使用会有统一的js-前缀
-	'MOD_SHA1_FILES'              	=>	0 ,       //给所有静态文件加戳或生成新文件,0:关闭,1:加戳,2:生成新文件
-	'MOD_OPTI_IMG'                	=>	0 ,       //是否优化图片
-	'MOD_XSS_CHECK'               	=>	0 ,       //是否进行XSS检查
-	'MOD_XSS_FIXED_MODE'          	=>	0 ,       //XSS自动修复,0:功能关闭,1:源文件修复,2:output文件修复(安静模式)
-	'MOD_REPLACE_DOMAIN'          	=>	0 ,       //是否启用地址替换
-	'MOD_OFFLINE_DOMAIN_CHECK'    	=>	0 ,       //是否进行线下地址检测
-	'MOD_DOMAIN_MULTIPLE'         	=>	0 ,       //是否进行域名分发
-	'CSS_IMG_DATAURI_SIZE'        	=>	3000 ,    //图片DataUri转换后的最大尺寸限制,单位(字节),0:关闭
-	'MOD_INLINE_JS_CSS'           	=>	0 ,       //在inc文件中,将js或css内容直接引入进来
-	'IS_SHOW_WARNING_INFO'        	=>	1 ,       //是否显示警告信息
-	'MOD_FORBID_FUNCTION'         	=>	array(    //强制关闭的功能
-	),
-	'JS_CSS_LIST'                 	=>	array(    //css的class在js里用到的列表
-	),
-	'XSS_SAFE_VAR'                	=>	array(    //安全变量列表,必须是正则,不包含$
-	),
-	'REPLACE_DOMAIN_LIST'         	=>	array(    //线下地址替换成线上地址
-	),
-	'DOMAIN_MULTIPLE_LIST'        	=>	array(    //'http://img.baidu.com' => 'http://(a,b,c,d,e).img.baidu.com',
-	),
-);

+ 0 - 82
manifest.json

@@ -1,82 +0,0 @@
-{ 
-	"name": "WEB前端助手(FeHelper)", 
-	"version": "2.0",
-    "manifest_version": 2,
-	 
-	"default_locale": "zh_CN", 
-	
-	"description": "FE助手:包括编码规范检测、栅格检测、字符串编解码、页面性能检测、JSON查看器、QR码生成工具", 
-	"icons": { 
-		"16": "static/img/fe-16.png",
-		"48": "static/img/fe-48.png",
-		"128": "static/img/fe-128.png"
-	 }, 
-	 
-	"browser_action": {
-		"default_icon" : "static/img/fe-16.png",
-		"default_title" : "WEB前端助手",
-		"default_popup" : "template/fehelper_popup.html"
-	},
-
-    "background": {
-        "persistent": false,
-        "page": "template/fehelper_background.html"
-    },
-	"options_page": "template/fehelper_options.html", 
-	
-	"permissions": [
-		"tabs",
-		"contextMenus",
-		"cookies",
-		"notifications",
-        "alarms",
-        "webNavigation",
-		"\u003Call_urls\u003E" 
-	],
-
-    "web_accessible_resources": [
-        "static/img/43.png",
-        "static/img/baidufe_bj.png",
-        "static/img/grid.png",
-        "static/img/fe-18.png",
-        "static/img/fe-48.png",
-        "static/img/fe-128.png",
-        "static/img/pbar-ani.gif",
-        "static/img/ui-icons_228ef1_256x240.png",
-        "static/css/fe-helper.css",
-        "static/vendor/jquery-ui-1.8/css/jquery-ui-1.8.16.custom.hot_datauri.css"
-    ],
-
-	"content_scripts": [{	
-		"matches":["http://*/*","https://*/*"],
-		"js":[
-			"static/js/core/jquery-1.5.min.js",
-			"static/vendor/jquery-ui-1.8/js/jquery-ui-1.8.11.custom.min.js",
-			
-			"static/js/core/core.js",
-			"static/js/core/fe-const.js",
-			"static/js/core/log.js",
-			
-			"static/js/fcp/fcp-fl.js",
-			"static/js/fcp/css/fcp-css-analytic.js",
-			"static/js/fcp/css/fcp-css.js",
-			"static/js/fcp/html/fcp-html-analytic.js",
-			"static/js/fcp/html/fcp-html-doctype.js",
-			"static/js/fcp/html/fcp-html.js",
-			"static/js/fcp/js/fcp-js.js",
-			"static/js/fcp/fcp-tabs.js",
-			"static/js/fcp/fcp-main.js",
-			
-			"static/js/grid/grid-main.js",
-			"static/js/fdp/fdp-main.js",
-			"static/js/fe-helper.js",
-			"static/js/notification/fe-notification.js",
-			"static/js/wpo/fe-calc-wpo.js"
-		],
-		"run_at":"document_end",
-		"all_frames":false
-	}],
-    "content_security_policy": "script-src 'self' https://ssl.google-analytics.com 'unsafe-eval'; object-src 'self'",
-	"homepage_url": "http://www.baidufe.com/item/889639af23968ee688b9.html"
-
-}

+ 0 - 63
online.manifest.json

@@ -1,63 +0,0 @@
-{
-    "name": "WEB前端助手(FeHelper)",
-    "version": "2.0",
-    "manifest_version": 2,
-
-    "default_locale": "zh_CN",
-
-    "description": "FE助手:包括编码规范检测、栅格检测、字符串编解码、页面性能检测、JSON查看器、QR码生成工具",
-	"icons": { 
-		"16": "static/img/fe-16.png",
-		"48": "static/img/fe-48.png",
-		"128": "static/img/fe-128.png"
-	 }, 
-	 
-	"browser_action": {
-		"default_icon" : "static/img/fe-16.png",
-		"default_title" : "WEB前端助手",
-		"default_popup" : "template/fehelper_popup.html"
-	},
-
-    "background": {
-        "persistent": false,
-        "page": "template/fehelper_background.html"
-    },
-	"options_page": "template/fehelper_options.html",
-
-    "permissions": [
-        "tabs",
-        "contextMenus",
-        "cookies",
-        "notifications",
-        "alarms",
-        "webNavigation",
-        "\u003Call_urls\u003E"
-    ],
-
-    "web_accessible_resources": [
-        "static/img/43.png",
-        "static/img/baidufe_bj.png",
-        "static/img/grid.png",
-        "static/img/fe-18.png",
-        "static/img/fe-48.png",
-        "static/img/fe-128.png",
-        "static/img/pbar-ani.gif",
-        "static/img/ui-icons_228ef1_256x240.png",
-        "static/css/fe-helper.css",
-        "static/vendor/jquery-ui-1.8/css/jquery-ui-1.8.16.custom.hot_datauri.css"
-    ],
-
-	"content_scripts": [{	
-		"matches":["http://*/*","https://*/*"],
-		"js":[
-			"static/js/core/jquery-1.5.min.js",
-			"static/vendor/jquery-ui-1.8/js/jquery-ui-1.8.11.custom.min.js",
-			
-			"static/js/mod/mod_manifest.js"
-		],
-		"run_at":"document_end",
-		"all_frames":false
-	}],
-    "content_security_policy": "script-src 'self' https://ssl.google-analytics.com 'unsafe-eval'; object-src 'self'",
-    "homepage_url": "http://www.baidufe.com/item/889639af23968ee688b9.html"
-}

BIN
output/fe-helper.zip


+ 0 - 638
output/fe-helper/_locales/zh_CN/messages.json

@@ -1,638 +0,0 @@
-{
-	"extensionName": { "message": "前端(FE辅助)侦测工具" },
-	"extensionDescription": { "message": "部分idear来自compatibility-detecotor!" },
-	
-	"normalTitleText": { "message": "点击此按钮开始检测本页面的兼容性问题" },
-	"okTitleText": { "message": "暂时没有发现问题" },
-	"warningTitleText": { "message": "发现警告级别的问题\n点击查看" },
-	"errorTitleText": { "message": "发现错误级别的问题\n点击查看" },
-	
-	"msg0001":{"message":"HTML侦测结果"},
-	"msg0002":{"message":"CSS侦测结果"},
-	"msg0003":{"message":"Javascript侦测结果"},
-	"msg0004":{"message":"共<span class=x-num>$1</span>个,"},
-	"msg0005":{"message":"建议替换它。"},
-	"msg0006":{"message":"HTML5不再支持的标签"},
-	"msg0007":{"message":"<span class=x-num>$1</span>个位于<span class=x-tag>&lt;$2&gt;</span>标签内,"},
-	"msg0008":{"message":"HTML5不再支持的属性"},
-	"msg0009":{"message":"本页设置了DTD,"},
-	"msg0010":{"message":"这个 DTD 使 Chrome 处于<span class=x-num>$1</span>,但有可能使 IE 进入<span class=x-num>$2</span>。"},
-	"msg0011":{"message":"这个 DTD 使 Chrome 处于<span class=x-num>$1</span>,但 DTD 之前存在 IE 条件注释,有可能使 IE 进入$2"},
-	"msg0012":{"message":"本页在 IE 和 Chrome 中将触发 相同的 渲染模式,均为<span class=x-num>$1</span>"},
-	"msg0013":{"message":"建议使用在所有浏览器中均触发标准模式的 DTD,以减少出现兼容性问题的可能"},
-	"msg0014":{"message":"本页在 IE 和 Chrome 中将触发 <strong>不同的</strong> 渲染模式,其中 IE 中为$1,Chrome为$2"},
-	"msg0015":{"message":"建议删除 DTD 之前的内容,以减少出现兼容性问题的可能"},
-	"msg0016":{"message":"本页没有设置 DTD,在所有浏览器中将以<span class=x-num>$1</span>渲染;"},
-	"msg0017":{"message":"文档类型定义(DTD)"},
-	"msg0018":{"message":"发现仅 IE 支持的条件注释<span class=x-num>$1</span>个"},
-	"msg0019":{"message":"建议删掉页面上无用的注释"},
-	"msg0020":{"message":"其他HTML相关检测结果"},
-	"msg0021":{"message":"有<span class=x-num>$1</span>个 <span class=x-tag>&lt;link&gt;</span> 标记未放置在<span class=x-tag>&lt;$2&gt;</span>标签内,如果是动态创建的此标签,可能会导致它失效"},
-	"msg0022":{"message":"link标签"},
-	"msg0023":{"message":"没有发现异常"},
-	"msg0024":{"message":"ID重复性检测"},
-	"msg0025":{"message":"发现如下重复性的ID"},
-	"msg0026":{"message":"发现如下<span class=x-num>$1</span>个ID被重复使用,$2"},
-	"msg0027":{"message":"在文档中没有发现注释"},
-	"msg0028":{"message":"在文档中发现<span class=x-num>$1</span>个DOM节点"},
-	"msg0029":{"message":"发现有<strong>$1</strong>个<span class=x-tag>&lt;input&gt;</span>设置了size属性,size属性不能精确的控制其尺寸,请使用CSS的width替换它"},
-	"msg0030":{"message":"在文档中共发现<span class=x-num>$1</span>个HTML注释,注释总大小为 <span class=x-num>$2</span>字节;"},
-	"msg0031":{"message":"所有处于存活期的cookie"},
-	"msg0032":{"message":"其他Script相关检测结果"},
-	"msg0033":{"message":"在页面上发现独立的<span class=x-tag>&lt;script&gt;</span>块<span class=x-num>$1</span>个"},
-	"msg0034":{"message":"在页面上发现通过<span class=x-tag>&lt;script&gt;</span>标签引入外部js文件<span class=x-num>$1</span>个"},
-	"msg0035":{"message":"发现内联元素<span class=x-tag>$1</span>包含了块级元素<span class=x-tag>$2</span>"},
-	"msg0036":{"message":"内联元素包含块级元素"},
-	"msg0037":{"message":"未闭合的标签"},
-	"msg0038":{"message":"发现有$1未闭合,各浏览器对这些未闭合标签的容错方式不同"},
-	"msg0039":{"message":"冗余的CSS选择器"},
-	"msg0040":{"message":"可能用到的CSS伪类选择器"},
-	"msg0041":{"message":"实际用到的CSS选择器"},
-	"msg0042":{"message":"本页的cookie总大小为<span class=x-num>$1</span>字节"},
-	"msg0043":{"message":"本页的HTML代码没有经过压缩"},
-	"msg0044":{"message":"发现$1内的CSS代码没有经过压缩"},
-	"msg0045":{"message":"发现$1内的Javascript代码没有经过压缩"},
-	"msg0046":{"message":"<span class=x-tag>$1</span>标签"},
-	"msg0047":{"message":"<span class=x-num>$1</span>"},
-	"msg0048":{"message":"所有CSS检测结果"},
-	"msg0049":{"message":"当前页面没有设置<span class=x-tag>&lt;title&gt;</span>标签"},
-	"msg0050":{"message":"当前页面的<span class=x-tag>&lt;title&gt;</span>标签不在<span class=x-tag>&lt;head&gt;</span>标签内"},
-	"msg0051":{"message":"当前页面设置了多个<span class=x-tag>&lt;title&gt;</span>标签"},
-	"msg0052":{"message":",不利于SEO"},
-	"msg0053":{"message":"检测到<span class=x-tag>&lt;img&gt;</span>标签<span class=x-num>$1</span>的src为空"},
-	"msg0054":{"message":"当前页面引入的tangram文件为<span class=x-num>$1</span>"},
-	"msg0055":{"message":"当前页面依次引入了如下tangram文件:<span class=x-num>$1</span>"},
-	"msg0056":{"message":"绑定到window对象上的全局属性或方法"},
-	"msg0057":{"message":"<div><span class=x-tag>$1</span>中引用了<span class=x-num>$2</span>个css背景图片<span class='x-expand -x-expand-$3'>展开</span></div>"},
-	"msg0058":{"message":"CSS中共检测到<span class=x-num>$1</span>个expression,分布在$2"},
-	"msg0059":{"message":"<span class=x-tag>$1</span>中<span class=x-num>$2</span>个"},
-	"msg0060":{"message":"Firefox的注释中不能包含'--',但当前页面上已检测出<span class=x-num>$1</span>个这样的注释"},
-	"msg0061":{"message":"$1相关参考问题及其建议"},
-	"msg0062":{"message":"<a href='$1' target='_blank'>$2</a>"},
-	"msg0063":{"message":"当前页面的最大嵌套深度为<span class=x-num>$1</span>,路径为:<span class=x-tag>$2</span>"},
-	"msg0064":{"message":"<span class=x-tag>$1</span>被使用<span class=x-num>$2</span>次"},
-	"msg0065":{"message":"CSS中使用到的背景图片"},
-	"msg0066":{"message":"如下文件被多次引入,请确认:$1"},
-	"msg0067":{"message":"如下文件路径不同,但内容一样,请确认:$1"},
-	"msg0068":{"message":"<div><a href='$1' target='_blank' class=x-file>$2</a>被引入<span class=x-num>$3</span>次</div>"},
-	"msg0069":{"message":"<a href='$1' target='_blank' class=x-file>$2</a>文件"},
-	"msg0070":{"message":"<div>$1的内容重复</div>"},
-	
-	"html_0001": { "message": "在 Firefox 中注释内容中如果包含 '--' 字符在某些情况下会使该注释解析错误" },
-	"html_0002": { "message": "各浏览器对于字符编码别名支持的宽泛程度存在差异" },
-	"html_0003": { "message": "各浏览器对 URI 中非 ASCII 字符的处理有差异" },
-	"html_0004": { "message": "DTD 之前的非空白字符在某些情况下会使该 DTD 失效" },
-	"html_0005": { "message": "Chrome 和 Safari 中标签紧密相邻的行内元素在折行显示时存在错误" },
-	"html_0006": { "message": "META 标签的 content 属性中使用非 ';' 的符号做数据分割时在某些浏览器中不会被识别" },
-	"html_0007": { "message": "IE6 IE7 IE8(Q) 会忽略 OBJECT 和 IFRAME 标签之后的空白符" },
-	"html_0008": { "message": "IE Opera 对 OBJECT 元素之前的 'non-breaking space' 处理有误" },
-	"html_0009": { "message": "Chrome 和 Safari 中 BR 元素前的空白符不会被忽略" },
-	"html_0010": { "message": "IE 中单元格的 colspan 属性在某些情况下会影响 TABLE 元素的自动布局" },
-	"html_0011": { "message": "Firefox 在 TABLE 元素的宽度属性 (Attribute) 值大于 100% 时会以 100% 计算" },
-	"html_0012": { "message": "IE 支持某些非 TD 和 TH 元素上的 noWrap 属性" },
-	"html_0013": { "message": "各浏览器下使用 OBJECT 元素和 EMBED 元素嵌入 Flash 存在差异" },
-	"html_0014": { "message": "IMG 元素的 src 属性为空时其尺寸在各浏览器中不一致" },
-	"html_0015": { "message": "IE6 IE7 IE8(Q) 中 IMG 元素的 alt 属性在没有 title 属性的情况下会被当作提示信息使用" },
-	"html_0016": { "message": "IE6 不支持 PNG24 格式图片的半透明效果" },
-	"html_0017": { "message": "只有 IE6 中给 IMG 设置相同的 src 时会重载图片" },
-	"html_0018": { "message": "Firefox Opera 不支持通过为 OBJECT 元素设置 classid 引入 Windows 下的 Media Player 或 Flash 插件" },
-	"html_0019": { "message": "Firefox Opera 中 OBJECT 元素的默认尺寸为不可视" },
-	"html_0020": { "message": "在 IE6 IE7 IE8(Q) 中 CENTER 元素自身也会居中对齐,在 IE(S) 与 Opera(S) 中还会使其包含的表格中的文本居中对齐" },
-	"html_0021": { "message": "各浏览器对 align='middle' 的理解有差异" },
-	"html_0022": { "message": "Chrome Safari Firefox 中 IFRAME 元素在文档树中发生变化后父子页面间的某些交互方式会失效" },
-	"html_0023": { "message": "不同内核的浏览器中文件选择控件的外观也不相同" },
-	"html_0024": { "message": "不能以 size 属性精确控制 INPUT 文本框或密码框的宽度" },
-	"html_0025": { "message": "各浏览器中密码框掩码的外观不完全一致" },
-	"html_0026": { "message": "IE6 IE7 IE8(Q) 中 FILEDSET 元素的宽度不是 'auto' 时的表现与行内元素相同" },
-	"html_0027": { "message": "仅在 IE6 IE7 IE8中 \"disabled\" 属性可以作用于非表单控件元素" },
-	"html_0028": { "message": "Chrome Safari Opera 中 INPUT、TEXTAREA 元素的 disabled 属性值为 true 时其前景颜色会发生变化,但在 Chrome Safari 中某些情况下 disabled 属性值由 true 转为 false 后,其前景颜色不会更新至最初的设定色" },
-	"html_0029": { "message": "Firefox 中 TEXTAREA 元素根据 \"rows\" 设置值生成的实际行数为设置值 + 1" },
-	"html_0030": { "message": "Firefox Opera 中 BUTTON 元素的子元素可以溢出按钮渲染" },
-	"html_0031": { "message": "IE Opera 中 src 属性为空的 SCRIPT 元素内的脚本不会被忽略,且内联脚本可以通过修改其所在 SCRIPT 元素的 src 属性引入新的外部脚本文件" },
-	"html_0032": { "message": "Safari 中错误的注释将导致部分 JavaScript 代码无法执行" },
-	"html_0033": { "message": "IE6 IE7 IE8(Q) 中同一元素重复定义的 style 属性会被合并" },
-	"html_0034": { "message": "IE6 IE7 IE8(Q) Firefox(Q) Opera(Q) 会自动修复被大括号包含的 style 属性的值" },
-	"html_0035": { "message": "IE6 IE7 IE8(Q) 中对 UL OL DL 内包含非列表元素的处理跟其他浏览器不同" },
-	"html_0036": { "message": "各浏览器对未闭合标签的容错方式不同" },
-	"html_0037": {"message": "IE6 Firefox Chrome(Q) Safari(Q) 不支持 OPTION 元素的 label 属性"},
-	"html_0038": {"message": "IE6 IE7 不支持 OPTION 和 OPTGROUP 元素的 disabled 属性"},
-	"html_0039": { "message": "IE Opera 中可以通过 MAP 元素的 id 属性与 IMG 元素相关联" },
-	"html_0040": { "message": "各浏览器对表单元素单选按钮组设置非 CDATA 标准的 name 属性值解析不同"},
-	"html_0041": { "message": "各浏览器对 BASE 元素前后的超链接的默认 target 处理存在差异"},
-	"html_0042": { "message": "只有 IE 支持 IMG INPUT[type=image] 标记内的 lowsrc 属性"},
-		
-	"html_0001_suggestion": { "message": "按标准推荐的方法写注释标签" },
-	"html_0002_suggestion": { "message": "首先,对于动态页面必须确保 HTTP \"Content-Type\" 头字段的 \"charset\" 参数与页面自身编码相符,且务必在页面的 META 元素中也声明相符的字符编码信息。对于静态页面,必须保证页面中 META 元素声明中 \"http-equiv\" 为 \"Content-Type\" 对应的值中的 \"charset\" 的值与页面自身编码相符。" },
-	"html_0003_suggestion": { "message": "当 URI 中含有非 ASCII 字符时,不要依赖浏览器对 URI 的编码方式,以避免产生差异。" },
-	"html_0004_suggestion": { "message": "声明 DTD 时,确保 DTD 之前没有其他字符,即便有,也只能是空格符、换行符和制表符。" },
-	"html_0005_suggestion": { "message": "避免出现紧密连接的内联元素标签,可以在每个标记之间加入空格或者换行符来避免这个问题。" },
-	"html_0006_suggestion": { "message": "参照 W3C 的建议,使用英文半角分号“;”。" },
-	"html_0007_suggestion": { "message": "若不希望出现空格,可以将 IFRAME OBJECT 元素设置为块级元素。" },
-	"html_0008_suggestion": { "message": "合理的设置容器及 OBJECT 元素的宽度。" },
-	"html_0009_suggestion": { "message": "删除 BR 元素之前多余的空白符。" },
-	"html_0010_suggestion": { "message": "1. 设置 TABLE 的 'table-layout' 特性值为 fixed,使用固定布局的表格元素可避免此问题。" },
-	"html_0011_suggestion": { "message": "给 TABLE 元素设置宽度的时候,不要使用 HTML 属性 'width',请使用 CSS 特性 'width'。" },
-	"html_0012_suggestion": { "message": "nowrap 属性是被废弃的属性,使用 CSS 规则 white-space:nowrap 代替这个属性。" },
-	"html_0013_suggestion": { "message": "若不考虑 W3C 校验,可统一使用 EMBED 元素嵌入 Flash,这样可以避免因参数不统一导致的兼容性问题。" },
-	"html_0014_suggestion": { "message": "为了防止这种无 \"src\" 的 IMG 元素对页面产生布局影响,需要设置这种 IMG 的 ‘display’ 特性为 'none'。" },
-	"html_0015_suggestion": { "message": "若用户需要显示提示框,则指定 title 属性;" },
-	"html_0016_suggestion": { "message": "使用 IE 专有滤镜 AlphaImageLoader Filter 来修复 IE6 透明通道问题,详情请参考 MSDN 说明:  http://msdn.microsoft.com/en-us/library/ms532969(VS.85).aspx " },
-	"html_0017_suggestion": { "message": "如果需要重复设置相同的 src 值时,均触发 IMG 的 onload 事件,或者需要每次均从服务器端下载图片数据的时候,可以采用图片地址后加上随机数或当前时间戳参数的手段,避免内容被缓存。" },
-	"html_0018_suggestion": { "message": "由于某些浏览器原生无法支持 OBJECT 元素使用 classid 属性引入 Media Player 插件,所以为保证最大的兼容性,应避免使用此方式在页面中播放媒体文件。" },
-	"html_0019_suggestion": { "message": "OBJECT 元素为替换元素,应为 OBJECT 元素设置一个明确的宽度和高度。" },
-	"html_0020_suggestion": { "message": "避免使用 CENTER 标签,使用 CSS 的 'text-align' 特性来代替。" },
-	"html_0021_suggestion": { "message": "align=\"middle\" 仅在 IMG、OBJECT、APPLET 元素上的 align 属性中是合法值,对于其他元素的 align 属性均为非法。各浏览器在上述三个元素之外的元素上遇到 align=\"middle\" 均按照自己的理解方式解释。同时除单元格元素的 align 属性之外,其他的 align 属性均被 W3C 官方废弃(Deprecated.),所以应避免使用此属性。" },
-	"html_0022_suggestion": { "message": "根据上面所得的结果,推荐使用 document.getElementById(\"IFRAME\").contentWindow.document 获取 IFRAME 元素内页面的 document 对象,且对于在文档树中移动位置后的 IFRAME 元素也有很好的兼容性。同时应避免对跨域的父子页面交互。" },
-	"html_0023_suggestion": { "message": "在 Chrome  Safari 中对于文件选择控件的特殊呈现方式为 WebKit 内核特有,且其渲染方式也符合 W3C 对文件选择控件的规定。一般来说这种差异不会带来严重的兼容性问题。" },
-	"html_0024_suggestion": { "message": "不要试图通过设置 \"size\" 属性使 INPUT[type=text/password] 元素在所有浏览器中的宽度一致,这是不可能的。在需要对这类元素做精确的控制时,应使用 CSS 的 'width' 和 'height' 特性。" },
-	"html_0025_suggestion": { "message": "由于掩码字符无法被修改,因此仅通过 CSS 统一密码输入框的掩码样式是不可能的。且这种差异可以忽略不计。" },
-	"html_0026_suggestion": { "message": "这是一个 Bug,通过显式设置 FIELDSET 的样式为 'display:block' 来修复。" },
-	"html_0027_suggestion": { "message": "应避免在非表单控件类元素上使用 \"disabled\" 属性。" },
-	"html_0028_suggestion": { "message": "避免为 INPUT、TEXTAREA 元素设置比较深的背景色,或者在需要使一个文本框在 \"disabled=true\" 及 \"disabled=false\" 之间切换时,尽量通过标准的 DOM 方式创建此元素。" },
-	"html_0029_suggestion": { "message": "当我们仅仅为 TEXTAREA 元素设置 \"rows\" 属性以控制其高度时,在 Firefox 中无法得到我们预期的效果。且其他浏览器对 \"rows\" 属性设置的元素高度也不尽相同,这一点 W3C 没有明确规范 \"rows\" 属性计算高度时的具体算法。" },
-	"html_0030_suggestion": { "message": "合理的设置 BUTTON 及其子元素的宽度及高度,避免出现子元素溢出 BUTTON 的情况。" },
-	"html_0031_suggestion": { "message": "不在设定了 src 属性的 SCRIPT 元素内编写脚本。" },
-	"html_0032_suggestion": { "message": "SCRIPT 标记内如有 HTML 注释标记,请仔细检查,注意他们的闭合情况。" },
-	"html_0033_suggestion": { "message": "不要依赖 IE 的容错机制,避免重复定义 HTML 元素属性。" },
-	"html_0034_suggestion": { "message": "不要在 'style' 的属性值中使用大括号等符号包含样式特性,直接书写样式代码即可避免此类问题。" },
-	"html_0035_suggestion": { "message": "虽然 HTML 4.01 规范中没有明确指出列表元素的兄弟元素必须是同一列表元素;但是根据 HTML 语义化理念,建议不要在列表元素 LI DD DT 之后插入其他元素。" },
-	"html_0036_suggestion": { "message": "编写代码时要注意,不要遗失应有的闭合标签,以确保在各浏览器中都能按照预期的文档结构来渲染页面。" },
-	"html_0037_suggestion": { "message": "尽量避免在 OPTION 元素上使用 label 属性,如果想替代 OPTION 原有的内容值,请使用 Javascript。" },
-	"html_0038_suggestion": { "message": "使用其他方式使想要 disabled 的 OPTION 和 OPTGROUP 无效,比如使用脚本动态删除 OPTION 或 OPTGROUP。" },
-	"html_0039_suggestion": { "message": "若需要 IMG 元素与 MAP 元素相关联,注意通过 IMG 元素的 usemap 属性关联的 MAP 元素的 name 属性的值。" },
-	"html_0040_suggestion": { "message": "单选按钮的 \"name\" 属性值必须以字母 ([A-Za-z])和数字([0-9])开头 ,其后由任何字母、数字、连字符(\"-\")、下划线(\"_\")、冒号(\":\")和句号 (\".\") 组成。" },
-	"html_0041_suggestion": { "message": "不要在 HEAD 元素之外定义 BASE 元素,保证各浏览器兼容。" },
-	"html_0042_suggestion": { "message": "如无特殊应用需求,应避免使用 lowsrc 为属性名,防止他与 IE 扩展属性混淆。"},
-	
-	"css_0001": { "message": "Chrome Safari 中 '@charset' 声明的位置错误将导致其后的一个规则集无效" },
-	"css_0002": { "message": "各浏览器在 HTML 页面与页面中引入的外部 CSS 文件编码不一致时表现不同" },
-	"css_0003": { "message": "IE6 IE7(Q) IE8(Q) 不支持子选择器" },
-	"css_0004": { "message": "IE6 IE7(Q) IE8(Q) 不支持相邻兄弟选择器" },
-	"css_0005": { "message": "IE6 IE7(Q) IE8(Q) 不支持属性选择器" },
-	"css_0006": { "message": "IE6 IE7(Q) IE8(Q) 不支持 ':first-child' 伪元素" },
-	"css_0007": { "message": "IE6 IE7(Q) IE8(Q) 中 A 元素的 :visited :hover :active 伪类未按规范要求的算法来计算针对性" },
-	"css_0008": { "message": "IE6 IE7(Q) IE8(Q) 不支持 A 元素以外的其他元素的 ':hover' 伪类" },
-	"css_0009": { "message": "IE6 IE7 IE8(Q) 不支持 A 元素以外的其他元素的 ':active' 伪类" },
-	"css_0010": { "message": "IE6 IE7 IE8(Q) 不支持 ':focus' 伪类" },
-	"css_0011": { "message": "IE6 IE7 IE8(Q) 不支持 ':before' 和 ':after' 伪元素" },
-	"css_0012": { "message": "IE6 IE7 IE8(Q) 不支持 CSS 特性的 'inherit' 值" },
-	"css_0013": { "message": "IE8  Chrome Safari 中具有加粗效果的 HTML 元素的 'font-weight' 特性会受到其祖先元素的影响" },
-	"css_0014": { "message": "IE6 IE7(Q) IE8(Q) 不完全支持 !important 规则" },
-	"css_0015": { "message": "IE6 IE7 IE8(Q) 负边距 (margin) 导致元素溢出 hasLayout 容器时显示异常" },
-	"css_0016": { "message": "Chrome Safari 中为处于浮动元素后创建了 in-flow 的 Block Formatting Context 的元素设置的 'margin-left' 或 'margin-right' 特性会出错" },
-	"css_0017": { "message": "Firefox 中 'display:table '的元素的外边距不会与包含块的外边距折叠" },
-	"css_0018": { "message": "IE6 IE7 IE8(Q) 中浮动元素和定位元素某些情况下会影响普通流中毗邻 'margin' 的折叠" },
-	"css_0019": { "message": "IE6 IE7 IE8(Q) 中父元素或子元素触发 hasLayout 时子元素的 margin 值与期望值不符" },
-	"css_0020": { "message": "IE6 IE7 IE8(Q) 不支持 'display' 的替代值" },
-	"css_0021": { "message": "不能在 IE6 IE7 IE8(Q) 中触发 hasLayout 并在其他浏览器中创建 Block Formatting Context 的元素的表现会有差异" },
-	"css_0022": { "message": "各浏览器中浮动元素与相邻的 Block Formatting Context 之间的关系有差异" },
-	"css_0023": { "message": "IE6 IE7 IE8(Q) 中零高度的浮动元素会阻挡其兄弟浮动元素" },
-	"css_0024": { "message": "IE6 IE7 IE8(Q) 中行内元素后相邻的浮动元素在某些情况下会折行放置在之前行内元素所在行框的底部" },
-	"css_0025": { "message": "IE6 IE7 IE8(Q)中设置了 'clear' 特性的元素 'margin-top' 特性处理有误,某些情况下会与浮动元素重叠" },
-	"css_0026": { "message": "在 IE6 IE7 IE8(Q) 中包含被清除浮动的浮动元素的块级元素的背景在某些情况下不是设置值" },
-	"css_0027": { "message": "IE6 IE7 IE8(Q) 中对浮动元素上 'clear' 特性的解释出现错误,使其自身位置和其后浮动元素的位置与其他浏览器中不同" },
-	"css_0028": { "message": "IE6 IE7 IE8(Q) 中一些块级元素的默认上下外边距会在其浮动或触碰到 hasLayout 的容器后消失" },
-	"css_0029": { "message": "IE6 IE7 IE8(Q) 中元素的 'padding-top' 遇到 'clear' 特性在某些情况下复制到 'padding-bottom'" },
-	"css_0030": { "message": "Firefox 浏览器对 TABLE 中绝对定位元素包含块的判定有错误,某些情况下会导致绝对定位元素位置跟其他浏览器中有差异" },
-	"css_0031": { "message": "IE6 IE7 IE8(Q) Firefox Opera 中绝对定位元素的静态位置计算某些情况下会出错" },
-	"css_0032": { "message": "IE6 IE7(Q) IE8(Q) 不支持固定定位(position:fixed)" },
-	"css_0033": { "message": "IE6 IE7 IE8(Q) 中某些情况下浮动元素会在其浮动方向溢出其包含块" },
-	"css_0034": { "message": "IE6 IE7 IE8(Q) 中定位元素 'z-index' 为默认值在某些情况下会产生新的层叠上下文" },
-	"css_0035": { "message": "IE6 IE7 IE8(Q) 中溢出容器的浮动元素导致容器兄弟元素文本定位错误" },
-	"css_0036": { "message": "IE7(S) 中元素溢出包含块的部分会被 hasLayout 元素遮住" },
-	"css_0037": { "message": "IE6 IE7(Q) IE8(Q) 中包含块若未触发 hasLayout 则会影响参照其定位的绝对定位元素的偏移位置计算" },
-	"css_0038": { "message": "各浏览器中 'width' 和 'height' 在某些元素上的作用位置有差异" },
-	"css_0039": { "message": "IE6 IE7(Q) IE8(Q) 中 'width' 或 'height' 的设定值在不足以容纳其内容时将被撑大" },
-	"css_0040": { "message": "零宽高的 IFRAME 元素的实际尺寸在不同浏览器中有差异" },
-	"css_0041": { "message": "IE6 IE7 IE8(Q) 中浮动元素宽度的 shrink-to-fit 算法与标准规定的算法不同" },
-	"css_0042": { "message": "Chrome Safari 中浮动元素之前的非 inline 级元素会对包含块的 shrink-to-fit 宽度计算有影响" },
-	"css_0043": { "message": "IE6 IE7 IE8(Q) 中右浮动元素会撑大其祖先级元素的宽度" },
-	"css_0044": { "message": "IE Opera 计算 shrink-to-fit 的宽度时会考虑浮动元素的宽度" },
-	"css_0045": { "message": "IE6 IE7(Q) IE8(Q) 绝对定位元素无法根据其四个方向的偏移量自动计算其尺寸" },
-	"css_0046": { "message": "IE6 IE7 IE8(Q) 中行框的顶边与底边位置识别有误" },
-	"css_0047": { "message": "IE6 IE7(Q) IE8(Q) 不支持 'min-width' 和 'max-width' 特性" },
-	"css_0048": { "message": "IE6 IE7 IE8(Q) 中行内非替换元素中的非文本文字会撑高其高度" },
-	"css_0049": { "message": "不同浏览器内 'line-height' 样式设置会影响不同行内替换元素的显示高度" },
-	"css_0050": { "message": "IE6 IE7 IE8(Q) 中触发 hasLayout 的空块级非替换元素的高度不是0" },
-	"css_0051": { "message": "行内非替换元素的高度和宽度的设置仅在 IE 混杂模式中生效" },
-	"css_0052": { "message": "IE6 IE7(Q) IE8(Q)不支持 'min-height' 和 'max-height' 特性" },
-	"css_0053": { "message": "各浏览器对常用行内替换元素的 'baseline' 位置理解不同" },
-	"css_0054": { "message": "Safari Chrome 中行框高度计算有误" },
-	"css_0055": { "message": "Safari Chrome 中元素 'overflow' 值为非默认值时其最后一个内联子元素的半差异高度被忽略" },
-	"css_0056": { "message": "各浏览器对行内元素绝对定位后的静态位置的 'top' 特性计算存在差异,IE6 IE7 IE8(Q) 还会考虑半差异的高度" },
-	"css_0057": { "message": "在不同的文档模式中,当唯一的非表单控件类行内替换元素存在于其包容块中时,其父框的行高并不一定会计算文本基线高度。" },
-	"css_0058": { "message": "各浏览器中当容器元素 shrink-to-fit 时容器内 MARQUEE 标签的计算宽度不一致" },
-	"css_0059": { "message": "IE 中当 'overflow-x' 或 'overflow-y' 的值被设置成非 'visible' 时,另一个特性的计算值为 'visible' 而非 'auto'" },
-	"css_0060": { "message": "IE6 IE7 IE8(Q) 中 'overflow' 特性不为 'visible' 的非定位元素内包含溢出的定位元素时的渲染效果有误" },
-	"css_0061": { "message": "IE6 IE7 IE8(Q) 中 UL 和 OL 标记为实现放置 LI 元素标记框 'outside' 设置时所使用的样式设定不同于其他浏览器" },
-	"css_0062": { "message": "IE6 IE7 IE8(Q) 中如果列表元素设置 'list-style-type:none' 时不影响 ‘list-style-position:inside’ 设置产生的标记块  " },
-	"css_0063": { "message": "LI 元素设置标记类型的特性 'style-list-type' 的 'disc | circle | square' 三个特性值在各浏览器中的渲染方式不同" },
-	"css_0064": { "message": "IE6 IE7(Q) IE8(Q) 中 IFRAME 元素 'background-color' 特性默认值不是 transparent" },
-	"css_0065": { "message": "IE6 不支持 HTML、BODY 以外元素的 background-attachment:fixed" },
-	"css_0066": { "message": "各浏览器对 '@font-face' 规则支持的字体格式不同,IE 支持 EOT 字体,Firefox Safari Opera 支持 TrueType 等字体" },
-	"css_0067": { "message": "在某些条件下 Firefox Chrome Safari 的标准模式中 'text-decoration' 会作用于 IMG 元素上" },
-	"css_0068": { "message": "元素和其子孙元素的 'text-decoration' 特性对其内文本的渲染在各浏览器中不同" },
-	"css_0069": { "message": "'text-align' 特性在 IE6 IE7 IE8(Q) 中可以影响块级元素的对齐方式,并且在所有浏览器的混杂模式中均不能被 TABLE 元素继承" },
-	"css_0070": { "message": "WebKit 浏览器中 'white-space:nowrap' 使表格内的浮动元素不折行" },
-	"css_0071": { "message": "'text-overflow:ellipsis' 会引起兼容性问题" },
-	"css_0072": { "message": "某些条件下 IE6 IE7 IE8(Q) 中 'word-wrap:break-word' 作用于 TD 时导致其中 IMG 元素不换行" },
-	"css_0073": { "message": "'word-wrap:break-word' 只有在 WebKit 浏览器中对 SELECT 元素上的文字有效" },
-	"css_0074": { "message": "'word-wrap:break-word' 导致在 IE6, IE7 及 IE8(Q) 中空格不被忽略" },
-	"css_0075": { "message": "仅 Firefox 支持小数数值的 'letter-spacing' 特性" },
-	"css_0076": { "message": "Firefox 中 A 元素的 ':hover' 伪类中设置的下划线某些情况下会失效" },
-	"css_0077": { "message": "固定表格布局下的各浏览器对与表格宽度计算算法不同" },
-	"css_0078": { "message": "WebKit 中某些条件下 empty cell 的宽度和高度为 0" },
-	"css_0079": { "message": "IE6 IE7 IE8(Q) 中自动布局的表格在其中包含无内容的左浮动元素时的宽度计算在某些情况下有误" },
-	"css_0080": { "message": "IE 混杂模式下 TR 元素的最终高度始终不会超过其所有 TD 子元素的高度" },
-	"css_0081": { "message": "单元格的高度计算受其 'padding' 和 'line-height' 的影响 " },
-	"css_0082": { "message": "IE6(Q) IE7(Q) IE8(Q) Chrome(S) Safari(S) Firefox 对多层嵌套的表格级元素百分比高度计算错误" },
-	"css_0083": { "message": "IE6 IE7 IE8(Q) Firefox(Q) Opera(Q) 中空单元格的边框某些情况下会消失" },
-	"css_0084": { "message": "IE6 IE7 IE8(Q) 中空单元格的上下 'padding' 失效" },
-	"css_0085": { "message": "IE6 IE7 IE8(Q) 中单元格对齐依据的是元素的原始宽度而不是其因某些原因被拉大后的宽度" },
-	"css_0086": { "message": "IE Firefox Opera 的混杂模式对于百分比单位高度的单元格内子元素的百分比高度计算错误" },
-	"css_0087": { "message": "只有 IE 和 Opera 支持 'cursor:hand'" },
-	"css_0088": { "message": "IE6 IE7 IE8(Q) 不支持 'outline' 特性" },
-	"css_0089": { "message": "IE6 IE7 IE8(Q) 会自动修复 'font-family' 特性的值是由一个引号包括了整个字体家族时的错误书写的代码" },
-	"css_0090": { "message": "各浏览器对 CSS 代码及 CSS 相关 DOM 操作中长度 \"&lt;length&gt;\" 类型的值缺失单位的容错程度存在差异" },
-	"css_0091": { "message": "各浏览器对 CSS 错误解析规则的差异及 CSS hack" },
-	"css_0092": { "message": "各浏览器对不合法的类选择器名称的容错程度存在差异" },
-	"css_0093": { "message": "各浏览器对于计算后宽度和高度为含有小数的长度值时,其最终值会不一致" },
-	"css_0094": { "message": "IE5.0 IE5.5 IE6 中浮动元素在某些情况下会有双倍外边距" },
-	"css_0095": { "message": "IE6 IE7 IE8(Q) 中从单元格溢出的内容会被自动剪裁" },
-	"css_0096": { "message": "IE6 IE7 IE8(Q) 中 'white-space' 特性在某些情况下不会自动继承" },
-	"css_0097": { "message": "非 IE 浏览器中 'margin' 特性对 TABLE 元素的 align 属性会有影响" },
-	"css_0098": { "message": "IE6 IE7(Q) IE8(Q) 中 A 元素的 ':hover' 伪类以及 IE6 IE7 IE8(Q) 中的 ':active' 伪类 在当缺少 href 属性时会失效" },
-	"css_0099": { "message": "IE(Q) Firefox(Q) Opera 中 BR 元素的 'line-height' 特性的计算值在某些情况下会小于其继承值" },
-	"css_0100": { "message": "字体样式标签(U、B、S等)对某些 CSS 特性有影响" },
-	"css_0101": { "message": "IE6 IE7 IE8(Q) 中 cellspacing 属性在重合的边框模型的表格中仍然有效" },
-	"css_0102": { "message": "各浏览器中 IFRAME 元素的 scrolling 属性与其子页面 HTML 与 BODY 元素 'overflow' 特性的制约关系有差异" },
-	"css_0103": { "message": "IE6(Q) IE7(Q) IE8(Q) 中给 IMG 元素设置 'padding' 无效" },
-	"css_0104": { "message": "各浏览器中 FONT 元素的颜色设置在某些情况下会作用到由其祖先级元素设定的装饰线的颜色" },
-	"css_0105": { "message": "不同浏览器中 Flash 与其他元素发生覆盖时有差异" },
-	"css_0106": { "message": "IE6 IE7 IE8(Q) 没有完全正确地将 IMG、OBJECT、IFRAME、TABLE 元素的 align='left|right' 理解为浮动" },
-	"css_0107": { "message": "IE 对浮动非替换元素内包含宽度单位为百分比的元素时的 \"shrink-to-fit\" 宽度算法有误" },
-	"css_0108": {"message": "IE6 IE7 IE8(Q) 下 'background-attachment : scroll' 时背景图片会随着元素内容滚动" },
-	"css_0109": {"message": "各浏览器禁止内容选中的方式不同" },
-	"css_0110": {"message": "IE6 IE7 IE8(Q) 不支持 border-spacing 特性" },
-	"css_0111": { "message": "各浏览器对于未明确设定高度的包含块内包含百分比单位高度的块级元素或行内块元素的高度计算存在差异" },
-	"css_0112": { "message": "IE6 IE7 IE8(Q) 不支持 border-spacing 特性" },
-	"css_0113": { "message": "IE6 IE7 IE8(Q) 中空 TABLE 的宽度和高度均为 0" },
-	"css_0114": { "message": "IE6 IE7 IE8(Q) 中对浮动元素上 'clear' 特性的解释出现错误,使其自身位置和其后浮动元素的位置与其他浏览器中不同" },
-	"css_0115": { "message": "IE6 IE7 IE8(Q) 中零高度的浮动元素会阻挡其兄弟浮动元素" },
-	"css_0116": { "message": "只有 IE Chrome Safari 支持 'zoom' 特性并且他们的具体实现方式不同"},
-	"css_0117": { "message": "Chrome Safari 认为 'float:center' 是合法值且其计算值为 'none'"},
-	"css_0118": { "message": "各浏览器对 'marginwidth' 和 'marginheight' 属性的错误设定值的处理不同"},
-	"css_0119": { "message": "各主流浏览器均不支持非标准的 LAYER 元素" },
-	
-	"css_0001_suggestion": { "message": "要使用 '@charset' 规则,请确保将其放在样式表的最开始,前边不能有任何字符。" },
-	"css_0002_suggestion": { "message": "当 HTML 文件或 CSS 文件要引入一个不同编码的 CSS 文件时,要明确声明将被引入的 CSS 文件的编码,以避免发生上述问题。" },
-	"css_0003_suggestion": { "message": "避免在 IE6 IE7(Q) IE8(Q) 中使用子选择器。" },
-	"css_0004_suggestion": { "message": "避免在非标准模式中对 IE7 以下版本使相邻兄弟选择器。" },
-	"css_0005_suggestion": { "message": "避免在 IE6 IE7(Q) IE8(Q) 中使用属性选择器。" },
-	"css_0006_suggestion": { "message": "避免在 IE6 IE7(Q) IE8(Q) 中使用 ‘:first-child’ 伪元素。" },
-	"css_0007_suggestion": { "message": "严格按照标准的建议,以 L-V-H-A 的顺序声明 A 标签的伪类,以保证在各浏览器中兼容。" },
-	"css_0008_suggestion": { "message": "使用 JavaScript 绑定 'onmouseover' 和 'onmouseout'(模仿 ':hover');" },
-	"css_0009_suggestion": { "message": "使用 JavaScript 绑定 onmousedown onmouseup 事件模仿 ‘:active’ 伪类效果;" },
-	"css_0010_suggestion": { "message": "使用 JavaScript 绑定 onfocus onblur 事件模仿 ‘:focus’ 效果;" },
-	"css_0011_suggestion": { "message": "使用 JavaScript 判断在 IE6 IE7 IE8(Q) 中通过脚本实现 ':before' 及 ':after' 伪元素的效果;" },
-	"css_0012_suggestion": { "message": "使用标准模式渲染页面;" },
-	"css_0013_suggestion": { "message": "最好为元素设置绝对明确的 'font-weight' 特性的值,避免使用 bolder、lighter 这类相对量以及浏览器的默认样式。" },
-	"css_0014_suggestion": { "message": "这是浏览器的 Bug 导致,无法通过常规方式解决。不过,一般 '!important' 规则常常用于 CSS hack 以区分 IE6 与其他浏览器,其作为 hack 存在的意义已大于其本身的含义。" },
-	"css_0015_suggestion": { "message": "首先需要保证容器在IE中触发 hasLayout 属性,可以通过zoom:1实现。" },
-	"css_0016_suggestion": { "message": "为该创建了 BFC 的元素设置一个明确的宽度。" },
-	"css_0017_suggestion": { "message": "由于 IE6 IE7 IE8(Q) Firefox 元素的 'margin' 处理与 W3C 规范中的差异,若我们需要利用 \"margin collapse\" 达到某些布局效果时,在这几种浏览器中可能会由于没有发生 \"margin collapse\" 而出现 \"额外边距\" 的情况。所以应避免为表格设置上下边距,以及导致其 \"margin collapse\" 的发生,可以使用为表格的父元素使用 'padding' 代替表格元素的 'margin' 。" },
-	"css_0018_suggestion": { "message": "1. 根据具体需求,调整 'margin' 的位置和大小;" },
-	"css_0019_suggestion": { "message": "为容器显式地设置高度。若容器高度不定,则要避免在触发了 hasLayout 的容器内的浮动子元素上设置 'margin-bottom' 特性,可以通过为容器设置 'padding-bottom' 达到相似的效果。" },
-	"css_0020_suggestion": { "message": "尽量仅使用所有浏览器都支持的 'display' 特性值:'inline'、'block'、'list-item'、'none'。" },
-	"css_0021_suggestion": { "message": "仅当一个元素即在 IE 早期版本中触发了 hasLayout,又在其他浏览器中创建了 block formatting context 时,才能避免上述问题的发生。即同时启用上述两者以保证各浏览器的兼容,或者相反,两者皆不启用:" },
-	"css_0022_suggestion": { "message": "合理地设置容器的宽度、浮动元素的宽度、BFC 的宽度的值,尽量保证 BFC 的宽度小于 \"容器的剩余空间宽度\" 。若需要 BFC 折行显示在新的一行上,可以通过 BFC 设置 'clear' 特性等手段使其换行。" },
-	"css_0023_suggestion": { "message": "如果希望一个浮动元素能阻挡与其向相同方向浮动的兄弟元素,请确保其高度不为零,以使页面布局在各浏览器中的表现一致。" },
-	"css_0024_suggestion": { "message": "使用绝对定位(position:absolute)模拟右浮动(float:right)。" },
-	"css_0025_suggestion": { "message": "尽量避免为 'clear' 特性不为 none 的元素(即清理元素)设置 'margin-top' 特性,尤其是负值。" },
-	"css_0026_suggestion": { "message": "使丢失背景的容器触发 IE 浏览器特有的 hasLayout,如 'zoom:1',或者设置宽度和高度。" },
-	"css_0027_suggestion": { "message": "不要将 'clear' 特性应用在浮动元素上,以免出现上述不兼容的问题。" },
-	"css_0028_suggestion": { "message": "用自定义的 'margin' 取代浏览器的默认外边距样式。" },
-	"css_0029_suggestion": { "message": "方案1.不触发容器的 hasLayout 特性;" },
-	"css_0030_suggestion": { "message": "这是 Firefox 的一个 bug,绝对定位元素无法根据 'display' 特性是 'table' 且是绝对定位的祖先元素定位。" },
-	"css_0031_suggestion": { "message": "首先对于绝对定位元素,应尽可能避免使其 'top'、'right'、'bottom'、'left' 特性的值均为 'auto'。若必须这么做,则尽可能的保证绝对定位元素之前的兄弟元素为非浮动的块级元素。" },
-	"css_0032_suggestion": { "message": "在 IE6 IE7(Q) IE8(Q) 中为固定定位元素设置 'position:absolute',再通过 JavaScript 脚本或者 CSS Expression 动态设置其偏移量。如:" },
-	"css_0033_suggestion": { "message": "当文字方向为 'ltr' 时应避免使右浮动元素的宽度超出其包含块的宽度。同样地,当文字方向为 'rtl' 时应避免使左浮动元素的宽度超出其包含块的宽度。" },
-	"css_0034_suggestion": { "message": "理解层叠上下文、层叠级别与 'z-index' 之间的关系。" },
-	"css_0035_suggestion": { "message": "及时地为容器清除浮动,并且确保浮动元素没有溢出容器。" },
-	"css_0036_suggestion": { "message": "合理设置元素的 'width'、'height' 和 'overflow' 特性,避免内容溢出容器。 " },
-	"css_0037_suggestion": { "message": "使包含块触发 hasLayout 特性。如 'zoom:1' 或者设置明确的宽度、高度。" },
-	"css_0038_suggestion": { "message": "1. 使用能触发标准模式 (S) 的 DTD" },
-	"css_0039_suggestion": { "message": "使用能触发标准模式 (S) 的 DTD,以将受此问题影响的浏览器范围缩小到仅 IE6(S)。" },
-	"css_0040_suggestion": { "message": "根据实际情况选择使用 'visibility:hidden' 或者 'display:none' 隐藏 IFRAME 。" },
-	"css_0041_suggestion": { "message": "这个问题的影响较大,避免该问题的最直接的方式是给浮动非替换元素指定一个宽度,而不使用其默认值 'auto',从而避免其宽度为 shrink-to-fit,以使页面布局在各浏览器中的表现一致。" },
-	"css_0042_suggestion": { "message": "在容器为绝对定位、浮动或行内块元素且没有明确设定宽度时,若浮动元素之前出现非 inline 级元素,则要小心这个元素对容器 shrink-to-fit 宽度的影响。可以为容器明确的设定一个宽度。" },
-	"css_0043_suggestion": { "message": "如果有一个右浮动元素,应注意避免其祖先级元素的宽度为 shrink-to-fit,即给它们设定一个明确的宽度。以使页面布局在各浏览器中的表现一致。" },
-	"css_0044_suggestion": { "message": "尽量为非替换浮动元素、非替换绝对定位元素、非替换行内块元素显式地设置一个宽度,防止浏览器在 'width:auto' 时对于 shrink-to-fit 的宽度计算方式不同造成布局上的差异。" },
-	"css_0045_suggestion": { "message": "若能为非替换绝对定位元素设定固定的宽度及高度,则尽量不使用此方式自动计算绝对定位元素的 'width' 及 'height'。" },
-	"css_0046_suggestion": { "message": "为了取得正常布局,建议 'line-height' 计算值设置永远大于 'font-size' 计算值设置。 " },
-	"css_0047_suggestion": { "message": "使用 Javascript 实现 'min-width' 和 'max-width' 特性功能。" },
-	"css_0048_suggestion": { "message": "针对不同的需求,可以采取如下方式来避免此问题:" },
-	"css_0049_suggestion": { "message": "尽量避免使用 'line-height' 为 INPUT[type=text]、INPUT[type=password]、INPUT[type=button]、INPUT[type=file]、input[type=submit] 和 BUTTON 标记设置 ‘line-height’,而应改用规范内说明的 'height' 属性。 " },
-	"css_0050_suggestion": { "message": "如果想让一个触发了 hasLayout 的块级非替换元素的高度为0,可以给这个空的块级非替换元素增加一个空的注释块:" },
-	"css_0051_suggestion": { "message": "在页面上添加&lt;!DOCTYPE HTML&gt;,使页面工作在标准模式下。" },
-	"css_0052_suggestion": { "message": "使用 Javascript 实现 'min-height' 和 'max-height' 特性功能。" },
-	"css_0053_suggestion": { "message": "出现这种情况时,应避免使用 'baseline' 对齐方式,需为元素指定 'vertical-align' 值非 'baseline',推荐使用 'vertical-align:bottom' 或  'vertical-align:top'。" },
-	"css_0054_suggestion": { "message": "为了取得正常布局,建议 'line-height' 计算值永远大于 'font-size' 计算值设置。" },
-	"css_0055_suggestion": { "message": "为了准确得到容器高度,建议避免使用行高为行内元素指定高度,而应改用块标记,并且明确的指定其 'height' 值。" },
-	"css_0056_suggestion": { "message": "在使行内元素绝对定位的时候,要注意其行高对静态位置带来的影响,明确设置定位的元素偏移位置。" },
-	"css_0057_suggestion": { "message": "如果在 非标准模式 中,需要父容器在仅有行内替换元素的情况下计算出包含文本基线高度的行高值,则必须加入其他行内文本元素。" },
-	"css_0058_suggestion": { "message": "给 MARQUEE 元素定义具体的宽度,保证各浏览器兼容。" },
-	"css_0059_suggestion": { "message": "同时设置 'overflow-x' 和 'overflow-y' 的值,不要出现其中之一为 'hidden' 时,而另一个是 'visible' 的情况;" },
-	"css_0060_suggestion": { "message": "根据实际需求可以去掉包含块的 'overflow:hidden' 或采用其他定位方案,避免在 IE 中触发此问题,实现在各浏览器表现一致。" },
-	"css_0061_suggestion": { "message": "此种情况时可以将 IE6 IE7 IE8(Q) 浏览器的 UL OL 标记样式更改为与其他浏览器样式一致,即:" },
-	"css_0062_suggestion": { "message": "为了避免此问题,建议在设置 'list-style-type:none' 时仅将 'list-style-position' 属性值设置为默认的 'outside'。 " },
-	"css_0063_suggestion": { "message": "建议弃使用 'disc | circle | square' 这三个样式,改用背景图片代替样式显示,如: " },
-	"css_0064_suggestion": { "message": "IFRAME 透明是一个常见的问题,有时候我们需要其透明,这时需要为 IFRAME 元素添加属性 allowtransparency=\"true\"," },
-	"css_0065_suggestion": { "message": "避免为非 BODY、HTML 元素设置 'background-attachment:fixed' 特性。" },
-	"css_0066_suggestion": { "message": "由于各浏览器对 '@font-face' 规则字体格式支持存在差异,若仅通过定义一个 '@font-face' 规则,可以通过 CSS hack 的方式在 IE、Firefox、Chrome、Safari、Opera 中得到相同的字体效果:" },
-	"css_0067_suggestion": { "message": "尽量给需要修饰的文本单独设置 'text-decoration' 特性;若需要给图片添加上划线或下划线,则使用 'border-top' 和 'border-bottom' 来模拟 'text-decoration'。" },
-	"css_0068_suggestion": { "message": "根据具体应用环境,参照“问题分析”中各种情况在各浏览器下的结果汇总使用兼容性较好的方案。" },
-	"css_0069_suggestion": { "message": "避免在包含宽度比自身小的块级元素或表格的元素上设置 'text-align' 特性。" },
-	"css_0070_suggestion": { "message": "不要在 TD 标记中使用 'white-space:nowrap' 样式,或者为 TABLE 标记设置 'table-layout:fixed' 样式严格计算其内部布局。" },
-	"css_0071_suggestion": { "message": "不要在包含块级元素的元素上使用 'text-overflow:ellipsis';" },
-	"css_0072_suggestion": { "message": "限制 TD 元素宽度并设置 'word-wrap' 特性值为默认值。" },
-	"css_0073_suggestion": { "message": "不在 SELECT 元素上设置 'word-wrap:break-word;'" },
-	"css_0074_suggestion": { "message": "删除不必要的空格。" },
-	"css_0075_suggestion": { "message": "避免在使用 px 单位时为 'letter-spacing' 特性设置小数数值。" },
-	"css_0076_suggestion": { "message": "选用合适的文档头,让该页面使用标准模式;如:" },
-	"css_0077_suggestion": { "message": "在 'table-layout:fixed' 这种固定布局算法下的表格中,可以为表格最后一列不设置宽度,尽量消除由算法差异带来的列的宽度差异。" },
-	"css_0078_suggestion": { "message": "在空的 TD、TH 元素内添加 ' ';" },
-	"css_0079_suggestion": { "message": "避免在 TD 元素内出现左浮动、内容为空的元素。" },
-	"css_0080_suggestion": { "message": "避免为 TR 设置高度。 " },
-	"css_0081_suggestion": { "message": "避免为 TD 元素设置 'padding-top' 'padding-bottom' 特性" },
-	"css_0082_suggestion": { "message": "尽量避免为 TABLE 级别的元素设置百分比为单位的 'height' 特性,以避免 Firefox 对 TABLE 级别元素的高度算法 Bug。" },
-	"css_0083_suggestion": { "message": "避免出现空单元格,使用 “ ” 代替空单元格。" },
-	"css_0084_suggestion": { "message": "在需要留空的单元格中加一个空格: " },
-	"css_0085_suggestion": { "message": "不要同时为 TABLE 元素及其内部各列显式设置宽度,当需要应用各列设定宽度时,TABLE 元素的宽度应保持默认的 \"auto\" ,当需要限定 TABLE的宽度时,应至少保证有一列的宽度为默认的  \"auto\" 。" },
-	"css_0086_suggestion": { "message": "使用标准模式——&lt;!DOCTYPE html&gt;;尽量避免在表格及块级元素上使用百分比高度。" },
-	"css_0087_suggestion": { "message": "使用 CSS 规范中定义的 'cursor:  pointer' 样式代替 'cursor:hand' 样式。" },
-	"css_0088_suggestion": { "message": "由于 'outline' 特性不影响盒模型及文本流,所以使用此特性时,在不支持的 IE6 IE7 IE8(Q) 中不会出现影响布局的兼容性问题,只会在较小的程度上影响视觉效果,暂时没有好的替代方案。" },
-	"css_0089_suggestion": { "message": "这是由于疏忽笔误造成的错误,首先应按照 W3C 规范中的标准写法定义 'font-family' 。而不能利用浏览器对错误代码的容错机制。" },
-	"css_0090_suggestion": { "message": "对于那些长度类型的 CSS 特性,在 CSS 代码及使用 DOM 操作相关样式时,应明确为其标注单位字符。 " },
-	"css_0091_suggestion": { "message": "合理运用各浏览器对 CSS 错误解析规则的差异及 CSS hack 为不同浏览器赋予不同样式。" },
-	"css_0092_suggestion": { "message": "坚持以字母开头命名选择器,这样可保证在所有浏览器下都能兼容。" },
-	"css_0093_suggestion": { "message": "如果页面需要精确到像素级的话,建议为宽高属性指定整型值。" },
-	"css_0094_suggestion": { "message": "尽量避免同时使用 'margin-left' 与 float:left,及 'margin-right' 与 float:right;" },
-	"css_0095_suggestion": { "message": "遵照 W3C 规范所描述的,为单元格元素设置 \"overflow:hidden\" ,在所有浏览器中均会裁切溢出单元格的内容。" },
-	"css_0096_suggestion": { "message": "明确地为 TD 的子元素设置 'white-space' 特性,避免使 TD 元素自动继承父元素的 'white-space' 特性。或者避免同时为 TD 元素设置宽度及 white-space:nowrap(或是 nowrap 属性)。" },
-	"css_0097_suggestion": { "message": "由于 TABLE 元素的 align 属性已经被 W3C 废弃,所以在考虑 TABLE 元素对齐问题上应避免使用 align 属性,而改用 CSS。" },
-	"css_0098_suggestion": { "message": "如果需要一个 A 元素能根据用户的行为改变样式,请添加 A 元素的 'href' 属性使伪类生效。" },
-	"css_0099_suggestion": { "message": "尽可能不为 BR 元素设定一个可能小于其继承值的值。" },
-	"css_0100_suggestion": { "message": "U、S 元素本身是废弃元素,应避免使用,而用 CSS 相关特性来替代这些元素产生的效果。" },
-	"css_0101_suggestion": { "message": "在使用 border-collapse:collapse 时应保证 TABLE 元素的 cellspacing 属性值为 0。" },
-	"css_0102_suggestion": { "message": "W3C 规范并没有说明 scrolling 属性应该控制子页面哪个元素的滚动条的生成或者 'overflow' 特性,为防止在某些情况下 Chrome Safari 的 IFRAME 子页面中出现多余滚动条,应避免为 HTML 或者 BODY 元素设置 overflow:scroll。" },
-	"css_0103_suggestion": { "message": "使用标准模式。" },
-	"css_0104_suggestion": { "message": "FONT 元素本身是废弃元素,并且其所有属性均已不推荐使用,应避免使用 FONT 元素。" },
-	"css_0105_suggestion": { "message": "若有页面需求是要求其他元素遮挡 Flash " },
-	"css_0106_suggestion": { "message": "align 属性已被废弃,应避免使用这类 HTML 属性。为 IMG、OBJECT、IFRAME、TABLE、APPLET、EMBED 元素使用 CSS 的 'float' 特性以达到相同的效果。" },
-	"css_0107_suggestion": { "message": "1. 明确为浮动元素设置一个宽度值,避免其在进行 \"shrink-to-fit\" 计算时在不同浏览器之间出现的宽度计算差异。" },
-	"css_0108_suggestion": {"message": "若需要在所有浏览器下元素图片不随元素内容滚动,则不给元素设置任何背景,并且在元素的父元素上设置背景图,例如:"},
-	"css_0109_suggestion": {"message": "给标签设置样式 -moz-user-select:none ;-webkit-user-select:none 同时标签设置 unselectable=\"on\" ,保证各浏览器都可以禁止内容选中。"},
-	"css_0110_suggestion": {"message": "'border-spacing' 不是所有浏览器都能很好的支持,若水平和垂直方向的空间相等,可以用 TABLE 的 cellspacing 属性代替 'border-spacing' 特性。"},
-	"css_0111_suggestion": { "message": "要对设置有百分比高度的块级元素的包含块设置明确的 height 属性值。" },
-	"css_0112_suggestion": { "message": "'border-spacing' 不是所有浏览器都能很好的支持,若水平和垂直方向的空间相等,可以用 TABLE 的 cellspacing 属性代替 'border-spacing' 特性。"},
-	"css_0113_suggestion": { "message": "避免出现空 TABLE ,保证各浏览器兼容。" },
-	"css_0114_suggestion": { "message": "不要将 'clear' 特性应用在浮动元素上,以免出现上述不兼容的问题。" },
-	"css_0115_suggestion": { "message": "如果希望一个浮动元素能阻挡与其向相同方向浮动的兄弟元素,请确保其高度不为零,以使页面布局在各浏览器中的表现一致。反之,如果不希望零高度的浮动元素阻挡其兄弟浮动元素,请隐藏该元素,如使用 'display:none'。但要注意,这样做也会使其可能存在的绝对定位的内容也不可见。" },
-	"css_0116_suggestion": { "message": "由于各浏览器对 'zoom' 的实现上存在差异,并且Firefox Opera 并不支持 'zoom',因此不建议为 'zoom' 设定值大于 1 的值来对元素进行缩放应用。" },
-	"css_0117_suggestion": { "message": "避免使用非法的 'float' 特性值。"},
-	"css_0118_suggestion": { "message": "在使用 \"marginwidth\" 和 \"marginheight\" 时应严格遵照规范中的描述,要对其设定大于等于零的整数值。"},
-	"css_0119_suggestion": { "message": "放弃使用 LAYER 元素,改用 CSS 中的绝对定位样式 'position:absloute' 处理相关情况。" },
-
-	"javascript_0001": { "message": "IE6 IE7 IE8 的函数声明和函数表达式的实现与其他浏览器有差异" },
-	"javascript_0002": { "message": "Firefox 对条件判断语句块内的函数声明的处理与其他浏览器有差异" },
-	"javascript_0003": { "message": "Safari Chrome 中用 for in 可以遍历出 Date Array String 对象中被更新的原型方法" },
-	"javascript_0004": { "message": "各浏览器中 Date 对象的 toLocalString 方法的返回值不一致" },
-	"javascript_0005": { "message": "IE6 IE7 IE8 会忽略 JavaScript 代码中大括号之后的第一个分号" },
-	"javascript_0006": { "message": "在 IE6 IE7 IE8(Q) 中不能在 JSON 直接量的最后一个键值对后加 ','" },
-	"javascript_0007": { "message": "IE6 IE7 IE8 不会忽略数组直接量的末尾空元素" },
-	"javascript_0008": { "message": "仅 IE 支持使用含中文标点符号的变量名" },
-	"javascript_0009": { "message": "元素的内联事件处理函数的特殊作用域在各浏览器中存在差异" },
-	"javascript_0010": { "message": "各浏览器中 Date 对象的 getYear 方法的返回值不一致" },
-	"javascript_0011": { "message": "IE6 IE7 IE8(Q) 中的 getElementById 方法能以 name 属性为参数获取某些元素" },
-	"javascript_0012": { "message": "IE6 IE7 IE8(Q) 中的 getElementById 方法的参数不区分大小写" },
-	"javascript_0013": { "message": "IE 在创建 DOM 树时会忽略某些空白字符" },
-	"javascript_0014": { "message": "各浏览器中的 NodeList 接口存在差异" },
-	"javascript_0015": { "message": "IE 中一个对象的 native 方法是跟该对象绑定的" },
-	"javascript_0016": { "message": "IE 混淆了 DOM 对象属性(property)及 HTML 标签属性(attribute),造成了对 setAttribute、getAttribute 的不正确实现" },
-	"javascript_0017": { "message": "IE 对 DOMImplementation 接口的支持程度停留在 DOM 1 Core 阶段" },
-	"javascript_0018": { "message": "已经被废弃的 DocumentLS 接口目前仅在 Firefox 和 Opera 下被部分支持" },
-	"javascript_0019": { "message": "Firefox 和 Opera 不支持 \"document.styleSheets\" 通过 STYLE 元素 id 获取 CSSStyleSheet 对象" },
-	"javascript_0020": { "message": "仅 IE 中的 createElement 方法支持传入 \"HTML String\" 做参数" },
-	"javascript_0021": { "message": "事件模型在各浏览器中存在差异" },
-	"javascript_0022": { "message": "IE6 IE7 IE8 中 getElementsByName 方法的参数不区分大小写" },
-	"javascript_0023": { "message": "各浏览器对于 document、document.body、document.documentElement 对象的 onscroll 事件的支持存在差异" },
-	"javascript_0024": { "message": "IE 标准模式中 BODY 元素的高度变化和 IE6(S) 中 BODY 元素的宽度变化会触发 window.onresize 事件" },
-	"javascript_0025": { "message": "各浏览器对于 DOM 对象的鼠标滚轮事件事件存在差异" },
-	"javascript_0026": { "message": "Firefox 不支持 DOM 对象的 insertAdjacentHTML 和 insertAdjacentText 方法" },
-	"javascript_0027": { "message": "Firefox 不支持 DOM 对象的 outerHTML、innerText、outerText 属性" },
-	"javascript_0028": { "message": "IE6 IE7 IE8(Q) 中 DOM 元素的 offsetParent 在某些情况下为距离其最近的触发了 hasLayout 的祖先级元素" },
-	"javascript_0029": { "message": "插入空白页面 IFRAME 元素时 Chrome Safari Opera 浏览器中会触发 load 事件" },
-	"javascript_0030": { "message": "仅 IE 和 Firefox 支持 window 对象的 onerror 事件" },
-	"javascript_0031": { "message": "各浏览器对元素在没有设置 tabindex 属性时触发 onfocus 事件以及通过其 focus() 方法获得焦点的情况有差异" },
-	"javascript_0032": { "message": "各浏览器对页面 onload 事件处理方式不一致" },
-	"javascript_0033": { "message": "IE Chrome Safari 在计算 'overflow' 特性值为 visible 的容器的 scrollHeight 的值时会考虑其内脱离了文本流的元素" },
-	"javascript_0034": { "message": "Firefox Safari 中对 cookie 中未经编码的中文汉字处理有问题" },
-	"javascript_0035": { "message": "不能保证带有 name 属性的 BUTTON / INPUT [ type = submit / button / image ] 元素的 value 属性值在所有浏览器中都可以被提交到服务端" },
-	"javascript_0036": { "message": "IE 未按预期方式处理 content-type 为 text/plain 的内容" },
-	"javascript_0037": { "message": "IE6 和 Chrome 未按预期方式处理 content-type 为 application/rss+xml 的内容" },
-	"javascript_0038": { "message": "WebKit 中依赖文本流定位的绝对定位元素某些情况下不会更新其位置" },
-	"javascript_0039": { "message": "Webkit 中 NOBR 标签与其他标签紧密相连在某些情况下会导致部分内容无法换行" },
-	"javascript_0040": { "message": "Webkit 浏览器会压缩 OPTION 元素中的全角空格" },
-	"javascript_0041": { "message": "Chrome 中文版配置文件中对最小字体限制为 12px" },
-	"javascript_0042": { "message": "Chrome Safari 中的表单在某些情况下不能够重复提交" },
-	"javascript_0043": { "message": "WebKit 中 MARQUEE 元素 的 behavior 属性值为 alternate 时如果其中包含块级元素则会影响其滚动效果" },
-	"javascript_0044": { "message": "WebKit 中 HR 元素 noshade 属性会影响其 'color' 特性" },
-	"javascript_0045": { "message": "只有 IE 的 TABLE、THEAD、TBODY、TFOOT 有 moveRow 方法" },
-	"javascript_0046": { "message": "只有 IE 支持 TABLE 元素的 'bordercolordark' 和 'bordercolorlight' 属性" },
-	"javascript_0047": { "message": "只有 IE 支持条件注释" },
-	"javascript_0048": { "message": "只有 IE 的脚本引擎支持 VBScript" },
-	"javascript_0049": { "message": "只有 IE 的脚本引擎支持 JScript.Encode" },
-	"javascript_0050": { "message": "Element.all 属性方法只有 IE 和 Opera 支持" },
-	"javascript_0051": { "message": "只有 IE 和 Opera 支持使用 currentStyle 获取 HTMLElement 的计算后的样式" },
-	"javascript_0052": { "message": "只有 IE 和 Opear 支持 FORM.item() 方法" },
-	"javascript_0053": { "message": "只有 IE 支持 CSS Expression" },
-	"javascript_0054": { "message": "只有 IE 支持 CSS Filter" },
-	"javascript_0055": { "message": "IE 的 external 对象提供的方法是 IE 特有的" },
-	"javascript_0056": { "message": "只有 IE 可以设置滚动条样式" },
-	"javascript_0057": { "message": "只有 IE 支持 'writing-mode' 特性" },
-	"javascript_0058": { "message": "只有 IE 和 Opera 支持 TABLE 元素的 cells 属性" },
-	"javascript_0059": { "message": "只有 IE 和 Opera 支持 document.frames" },
-	"javascript_0060": { "message": "只有 IE 支持 mouseenter 和 mouseleave 事件" },
-	"javascript_0061": { "message": "只有 IE 的脚本引擎支持 CollectGarbage ScriptEngine 等 JScript 特有的方法" },
-	"javascript_0062": { "message": "IE 中可以使用 ActiveXObject 创建 Automation 对象,同时该对象的方法及属性名称大小写不敏感" },
-	"javascript_0063": { "message": "只有 IE 支持 OBJECT 元素的 onerror 事件" },
-	"javascript_0064": { "message": "IE 中可以使用 classid 与 codebase 属性结合完成下载、安装和使用 ActiveX 插件" },
-	"javascript_0065": { "message": "IE 会忽略触发 hasLayout 的元素内尾部的全角空格" },
-	"javascript_0066": { "message": "只有 IE 支持 DHTML Behaviors 及相关方法" },
-	"javascript_0067": { "message": "只有 IE 支持 window.createPopup 方法" },
-	"javascript_0068": { "message": "在 IE 中被透明元素遮挡的元素仍能响应鼠标事件" },
-	"javascript_0069": { "message": "只有 IE 的 HTMLElement 有 mergeAttributes 与 clearAttributes 方法" },
-	"javascript_0070": { "message": "只有 IE 的 HTMLElement 有 applyElement 方法" },
-	"javascript_0071": { "message": "只有 IE 的 HTMLDOMNode 有 replaceNode 与 swapNode 方法" },
-	"javascript_0072": { "message": "只有 IE 支持 BGSOUND 标签" },
-	"javascript_0073": { "message": "仅 IE 和 Opera 支持 HTMLFrameElement 和 HTMLIFrameElement 的 document 属性" },
-	"javascript_0074": { "message": "只有 IE 和 Opera 的 HTMLDOMNode 有 removeNode 方法" },
-	"javascript_0075": { "message": "只有 IE 支持 XML 数据岛" },
-	"javascript_0076": { "message": "IE 中页面内 OBJECT 对象相对其他浏览器额外包含了其引入的 ActiveX 插件的部分私有属性" },
-	"javascript_0077": { "message": "Firefox 中块级元素高度或宽度过小会导致滚动条消失" },
-	"javascript_0078": { "message": "Firefox 不识别 type 或 language 被设置为 JScript 的 SCRIPT 标签" },
-	"javascript_0079": { "message": "Firefox 中 Date.now 方法被重写后 MARQUEE 元素不再滚动" },
-	"javascript_0080": { "message": "IE 支持使用 window.clipboardData 访问系统剪贴板,Chrome 和 Safari 中存在类似的 Clipboard 对象但尚未实现,Firefox 和 Opera 不支持这类对象" },
-	"javascript_0081": { "message": "document.all 在各浏览器中的支持不同" },
-	"javascript_0082": { "message": "特定的 URL 伪协议需安装提供该协议的特定软件才有效" },
-	"javascript_0083": { "message": "浏览器后退按钮在各浏览器中的行为在某种情况下不一致" },
-	"javascript_0084": { "message": "各浏览器对 TABLE、TH、TD 元素的 bordercolor 属性的处理有差异" },
-	"javascript_0085": { "message": "获取文档可视尺寸(视口)时在各浏览器中的参考元素有差异" },
-	"javascript_0086": { "message": "各浏览器对于获取文档水平及垂直方向滚动条位置(scrollLeft、scrollTop)时的参考元素存在差异" },
-	"javascript_0087": { "message": "各浏览器在宽度不够时不会对连续的全角空格进行折行处理存在差异" },
-	"javascript_0088": { "message": "各浏览器中对直接以 id 或者 name 属性值获取元素存在差异" },
-	"javascript_0089": { "message": "某些情况下除了 IE 和 Opera 之外的浏览器中 window.close 方法无法关闭由直接输入 URL 或 Ctrl + 点击链接方式打开的窗口" },
-	"javascript_0090": { "message": "动态引入的外部 JS 文件在各浏览器中的加载顺序不一致" },
-	"javascript_0091": { "message": "document.write 方式引入外部 JavaScript 文件导致脚本程序执行顺序不同以及 DOM 树更新延迟问题" },
-	"javascript_0092": { "message": "Webkit 浏览器中 TD 的 \"noWrap\" 属性会引起的它里面 MARQUEE 元素宽度计算错误" },
-	"javascript_0093": { "message": "非 IE 浏览器中为 MARQUEE 元素设置某些 CSS 特性会导致其失去滚动效果" },
-	"javascript_0094": { "message": "Chrome Safari 中设置了 'bordercolor' 属性的 TABLE 元素,会为其自动设置3px的边框宽度" },
-	"javascript_0095": { "message": "IE6 IE7 IE8 对 onreadystatechange 事件的扩充" },
-	"javascript_0096": { "message": "各浏览器对遇到中文标点符号时折行的处理有差异" },
-	"javascript_0097": { "message": "在 IE 中一些特殊字符的最终呈现字体不是设定值" },
-	"javascript_0098": { "message": "Firefox 不支持 DOM 元素 style 属性中的 pixel* 属性,并且某些情况下 Webkit 浏览器 pixel* 属性的返回值和 IE 中不同" },
-	"javascript_0099": { "message": "新版本的浏览器都已经不支持古老的 document.layers" },
-	"javascript_0100": { "message": "各浏览器对使用 document.id 和 document.name 获取对象的支持存在差异" },
-	"javascript_0101": { "message": "IE 和 Firefox 可以通过特定方法使 innerHTML 方法载入的 SCRIPT 标签中的 JavaScript 代码在页面加载后也可以执行" },
-	"javascript_0102": { "message": "IE8(S) Firefox Opera Chrome Safari 在某些情况下计算 MARQUEE 元素的宽度时会参考其子元素的宽度" },
-	"javascript_0103": { "message": "IE 和 Chrome 支持通过 EMBED 元素嵌入 MP3 格式文件" },
-	"javascript_0104": { "message": "判断浏览器类型或版本时使用的方法不当将导致代码不能按照预期的效果执行" },
-	"javascript_0105": { "message": "IE 中 location=\"\" 或 location.href=\"\" 将使页面跳转至当前页面所在根目录" },
-	"javascript_0106": { "message": "Opera 和 Chrome 对模态对话框(showModalDialog)的支持有缺陷,且非 IE 浏览器均不支持非模态对话框(showModelessDialog)" },
-	"javascript_0107": { "message": "溢出定位流的不可视元素,其包含块的滚动条生成差异" },
-	"javascript_0108": { "message": "IE8 标准模式及 Opera 不支持 WBR 元素" },
-	"javascript_0109": { "message": "各浏览器对 navigator 对象中几个与语言相关的属性的返回值存在差异" },
-	"javascript_0110": { "message": "各浏览器创建 XMLHttpRequest 对象的方式不同" },
-	"javascript_0111": { "message": "各浏览器对 window.execScript 方法的支持不同"},
-    "javascript_0112": { "message": "各浏览器下在向文档树中插入通过 cloneNode(true) 创建的节点时,其内的 SCRIPT 元素中的脚本执行有差异" },
-	"javascript_0113": { "message": "IE6 IE7 IE8 Opera 支持除 INPUT 和 BUTTON 元素以外的其他元素的 click 方法" },
-	"javascript_0114": {"message": "为 SELECT 对象增加或删除选项的方法在各浏览器中的支持情况不同"},
-	
-	
-	"javascript_0001_suggestion": { "message": "避免使用 IE 的这些“特性”,以保证兼容所有浏览器。" },
-	"javascript_0002_suggestion": { "message": "将条件语句中的函数声明替换为函数表达式,如:" },
-	"javascript_0003_suggestion": { "message": "对于数组,避免用 for...in 方式而采用索引即数字下标的形式枚举数组成员。" },
-	"javascript_0004_suggestion": { "message": "要获得相同格式的时间字符串,请不要使用 Date.prototype.toLocaleString() 方法,可以通过分别使用 getFullYear、getMonth、getDate 和 getDay 分别获得各关键字符串并拼装。" },
-	"javascript_0005_suggestion": { "message": "按照规范书写正确的代码。" },
-	"javascript_0006_suggestion": { "message": "即便规范没有强调最后一个键值对的后边不能出现 ',',也要确保最后一个键值对之后没有多余的 ',',以兼容各浏览器。" },
-	"javascript_0007_suggestion": { "message": "数组直接量的最后不要出现 ',',以保证兼容各浏览器。" },
-	"javascript_0008_suggestion": { "message": "避免在变量名(即标识符)中出现中文标点,以保证兼容各浏览器。" },
-	"javascript_0009_suggestion": { "message": "1. 尽量不要使用内联事件处理函数,使用 DOM 标准的事件注册方式为该元素注册事件处理函数,如:" },
-	"javascript_0010_suggestion": { "message": "要获得一个具体时间的年份,请不要使用 Date.prototype.getYear() 方法,使用 Date.prototype.getFullYear() 代替,以在各浏览器下获得相同的表现。" },
-	"javascript_0011_suggestion": { "message": "在使用 document.getElementById 方法获取页面元素时,应传入元素的 id 属性值,而不能使用元素的 name 属性值。" },
-	"javascript_0012_suggestion": { "message": "在使用 document.getElementById 获取页面元素时,应保证作为参数的 id 与目标元素的实际 id 值完全一致。" },
-	"javascript_0013_suggestion": { "message": "1. 没有必要时尽量去掉各标签之间的空白字符。" },
-	"javascript_0014_suggestion": { "message": "要从 NodeList 中获取元素,请使用 NodeList[index]、NodeList[name] 或 NodeList.item(index),以保证兼容各浏览器。" },
-	"javascript_0015_suggestion": { "message": "使用方式 1 达到简写一些 DOM 和 BOM 对象原生方法的目的。" },
-	"javascript_0016_suggestion": { "message": "避免使用 \"Element.setAttribute(\"style\", \"XXX\")\" 在所有浏览器中设置元素的 style 属性,可以改用符合规范的 \"Element.style.cssText = \"XXX\"\";" },
-	"javascript_0017_suggestion": { "message": "避免使用各浏览器支持程度不同的 DOMImplementation 的接口。" },
-	"javascript_0018_suggestion": { "message": "由于 W3C 推荐的标准中,已经放弃了 DocumentLS 接口,为更好的兼容各浏览器,建议采用 XMLHttpRequest 方式载入xml文件,示例代码如下:" },
-	"javascript_0019_suggestion": { "message": "避免使用 \"document.styleSheets\" 通过 STYLE 元素 id 获取 CSSStyleSheet 对象,使用 W3C 规范中的整数下标方式获取。" },
-	"javascript_0020_suggestion": { "message": "对于一般的非替换元素,在各浏览器中均使用 W3C 规范中的标准的为 createElement 方法传入标签名的做法。" },
-	"javascript_0021_suggestion": { "message": "1. 使用特性判断创建无兼容性问题的事件监听器绑定和解绑函数" },
-	"javascript_0022_suggestion": { "message": "在使用 document.getElementsByName 方法获取页面元素时,应保证作为参数的 name 与目标元素的实际 name 值完全一致。" },
-	"javascript_0023_suggestion": { "message": "在给整个浏览器窗口绑定滚动事件 (scroll) 的时候,绑定到 window 对象上。" },
-	"javascript_0024_suggestion": { "message": "1. 不期望触发 window.onresize 事件时:" },
-	"javascript_0025_suggestion": { "message": "利用浏览器类型判断,给各浏览器绑定各自支持的鼠标滚轮事件。如,res.html" },
-	"javascript_0026_suggestion": { "message": "在 Firefox 中,可通过扩展 HTMLElement 的原型 (prototype) 来实现这两个方法:" },
-	"javascript_0027_suggestion": { "message": "在 Firefox 中,可通过扩展 HTMLElement 的原型 (prototype) 来实现相关属性。" },
-	"javascript_0028_suggestion": { "message": "使得元素的 offsetParent 在各浏览器中一致。例如,对于以上测试样例,可考虑对于 DIV[id=\"div\"] 设置 position 为(absolute | relative | fixed)。" },
-	"javascript_0029_suggestion": { "message": "为 IFRAME 标签的 src 属性指定具体 URL 后再将节点插入 DOM 树中 。" },
-	"javascript_0030_suggestion": { "message": "放弃使用 window.onerror,通过合理使用 try-catch 来达到近似的效果。" },
-	"javascript_0031_suggestion": { "message": "对于一般常见的可视元素,若需要元素可触发 onfocus 事件以及通过其 focus() 方法获得焦点,则应为其设置 tabindex 属性。" },
-	"javascript_0032_suggestion": { "message": "统一为 window 对象的 onload 事件绑定函数,避免在 Firefox 中产生 document.body.onload 事件理解歧义。" },
-	"javascript_0033_suggestion": { "message": "确保读取 scrollHeight 属性的元素均创建了新的 block formatting context,或者此容器与内部子容器处于同一文档流中,以此避免各浏览器中读数不同。" },
-	"javascript_0034_suggestion": { "message": "在设置和读取 cookie 时,始终为字符进行编解码操作,推荐使用 \"encodeURIComponent\" 和 \"decodeURIComponent\" 方法做相应编解码工作。" },
-	"javascript_0035_suggestion": { "message": "通常情况下,服务器端不需要按钮的 key/value 信息,建议删除按钮的 name 属性,不使其成为 successful control。" },
-	"javascript_0036_suggestion": { "message": "这是由于 IE 浏览器的特有内容嗅探机制导致,故在不修改服务器端代码的情况下,无法通过常规办法解决此 IE 特性问题。更多关于此问题的资料参考官方信息:Internet Explorer 未按预期方式处理“Text/Plain”内容类型。" },
-	"javascript_0037_suggestion": { "message": "各浏览器对于 RSS 的支持及渲染方式为浏览器各自实现导致,故无法通过常规办法使各浏览器达到一致的效果,对于暂不支持 RSS 的浏览器应给予提示。Chrome 可通过安装扩展插件实现此功能。" },
-	"javascript_0038_suggestion": { "message": "在绝对定位元素的包含块可能发生改变时(即该绝对定位元素的“静态位置”可能发生变化时),不要让该绝对定位元素依赖其“静态位置”来定位,给该元素设定明确的 left、right、top 或 bottom 值。" },
-	"javascript_0039_suggestion": { "message": "&lt;div style=\"width:150px;background:gold\"&gt;" },
-	"javascript_0040_suggestion": { "message": "避免在 OPTION 元素中使用全角空格,必要时可使用两个 \" \" 代替。" },
-	"javascript_0041_suggestion": { "message": "避免使用小于 12px 的字号,过小的文字建议用图片代替。" },
-	"javascript_0042_suggestion": { "message": "每次提交表单后都修改 action 属性内的 URL(加入时间戳)。" },
-	"javascript_0043_suggestion": { "message": "在 MARQUEE 标记内避免使用普通流中的块级元素,或用脚本程序模拟 MARQUEE 标记的效果。" },
-	"javascript_0044_suggestion": { "message": "去除 HR 元素的 noshade 属性或者将 noshade 属性放置在 color 属性之前。" },
-	"javascript_0045_suggestion": { "message": "不要使用 IE 的特性设计页面代码。" },
-	"javascript_0046_suggestion": { "message": "这两个属性为 IE 私有属性,并且 MSDN 官方文档上也不再推荐使用它们。所以,若要达到这两个属性的效果,可以在 TABLE 和  TD 元素上使用 \"border-color\" 。" },
-	"javascript_0047_suggestion": { "message": "在没有特殊需求的情况下,尽量避免使用 IE 特有的条件注释。" },
-	"javascript_0048_suggestion": { "message": "避免使用 VBScript,使用 JavaScript 书写页面上的脚本。" },
-	"javascript_0049_suggestion": { "message": "避免使用 IE 特有脚本扩展方式书写代码。" },
-	"javascript_0050_suggestion": { "message": "使用 Node 接口的 'childNodes' 属性,注意在非 IE 浏览器中使用该属性会返回文本节点,使用 Node.nodeType 判断节点类型以获取想要的节点;" },
-	"javascript_0051_suggestion": { "message": "要获取元素的某种样式计算后的值,请考虑所有浏览器的兼容性情况。如使用以下代码给不支持 getComputedStyle 的 IE 提供与其他浏览器相同的函数:" },
-	"javascript_0052_suggestion": { "message": "当使用 item 方法遍历 HTMLCollection 时,只有在IE Opera 浏览器下可以直接获取 HTMLFormElement 元素内所有标记引用,其他浏览器并不支持这种方法。" },
-	"javascript_0053_suggestion": { "message": "CSS Expression 是一个已经过时的技术,微软官方日后可能不会再对其进行开发及支持。 除非为了利用 CSS hack 去弥补某些 IE 中不支持的 CSS 特性,否则应尽量避免使用 CSS Expression。" },
-	"javascript_0054_suggestion": { "message": "由于 CSS Filter 是 IE 特有的技术,其他浏览器均不支持,所以为了最大的兼容性及标准化,应尽量避免为 IE 单独使用 Filter,如需要其某些特效,应同时考虑其他浏览器,利用非 IE 浏览器对 CSS3 草案的良好支持保证最好的兼容性。" },
-	"javascript_0055_suggestion": { "message": "不要使用 IE 的特性设计页面代码。" },
-	"javascript_0056_suggestion": { "message": "尽量不要去修改滚动条的样式。以免造成 IE 跟其他浏览器之间的差异。" },
-	"javascript_0057_suggestion": { "message": "其他浏览器中不支持文字的垂直排列,所以,尽量避免使用 IE 中特有的 'writing-mode' 特性。" },
-	"javascript_0058_suggestion": { "message": "避免使用 TABLE 的 cells 属性获取元素,而对 table row(TR) 使用 cells 属性,或用 document.getElementsByTagName 等方式获取元素。" },
-	"javascript_0059_suggestion": { "message": "用 window.frames 代替 document.frames。" },
-	"javascript_0060_suggestion": { "message": "1. 避免使用 mouseenter 和 mouseleave 事件。" },
-	"javascript_0061_suggestion": { "message": "避免使用此类由浏览器厂商提供的私有方法和扩展。" },
-	"javascript_0062_suggestion": { "message": "为了最好的兼容性,应尽量避免使用这种技术,或者在非 IE 浏览器中使用其他的替代技术,如 NPAPI 插件。" },
-	"javascript_0063_suggestion": { "message": "避免使用非标准的 onerror 事件。对于 OBJECT 元素可以通过对客户端浏览器类型进行判断,来达到有好地提示错误的效果。" },
-	"javascript_0064_suggestion": { "message": "ActiveX 为微软专有技术,仅被 Windows 中的 IE 支持。所以若希望这类组件可以运行于多种浏览器,则需要使用其他非 IE 支持的 NPAPI 重新设计在这种接口下的插件。以保证最好的兼容性。" },
-	"javascript_0065_suggestion": { "message": "避免使用全角空格占位,使用“ ”代替全角空格。" },
-	"javascript_0066_suggestion": { "message": "1. 避免使用 IE 的特性。" },
-	"javascript_0067_suggestion": { "message": "尽量不要使用 IE 的特性,必须使用弹出窗口时,可以通过脚本使用兼容各浏览器的方式来实现。" },
-	"javascript_0068_suggestion": { "message": "如果想遮盖某些元素,请为其设置一个非 'transparent' 的背景色。如果需要让这个遮掩层“隐形”,使用 'opacity:0' 和 'filter:alpha(opacity=0)' 来实现。" },
-	"javascript_0069_suggestion": { "message": "尽量避免使用 IE 独有的这两个方法编写代码,改用标准方法 setAttribute 和 removeAttribute 单独设置和删除属性来实现需求。" },
-	"javascript_0070_suggestion": { "message": "尽量避免使用 applyElement 方法编写代码,可以使用标准方法实现同样功能,如 appendChild、insertBefore、removeChild、replaceChild、cloneChild 等。" },
-	"javascript_0071_suggestion": { "message": "不要使用 IE 的特性设计页面代码。" },
-	"javascript_0072_suggestion": { "message": "如果背景音乐是必须的,请考虑使用被广泛使用的 Flash 插件来实现,以兼容所有浏览器。" },
-	"javascript_0073_suggestion": { "message": "使用 HTMLFrameElement 或 HTMLIFrameElement 对象的 contentWindow 属性得到该框架页的 window 对象应用,再访问其下的 document 对象。" },
-	"javascript_0074_suggestion": { "message": "不要使用 IE 的特性设计页面代码。" },
-	"javascript_0075_suggestion": { "message": "应考虑其他标准的、符合 W3C 规范的、各浏览器均支持的 XML 相关技术解析 XML 文档。" },
-	"javascript_0076_suggestion": { "message": "ActiveX 技术为微软的专有技术,仅在Windows 下的 IE 浏览器中可以得到支持。" },
-	"javascript_0077_suggestion": { "message": "针对 Firefox 中的这种特有现象,在确定不需要滚动条时为元素设置 'overflow:hidden',并且合理地为需要携带滚动条元素设置其宽度及高度。" },
-	"javascript_0078_suggestion": { "message": "为了保证脚本程序可以正常执行,除非特意使用仅 IE 支持的 VBScript 和 Script Encoder 机制外,应当将 SCRIPT 标记的 \"type\" 属性设置为 \"javascript\",并且不要设置已经废弃的 \"Languange\" 属性。" },
-	"javascript_0079_suggestion": { "message": "MARQUEE 元素为非 W3C 标准元素,应尽量避免使用。同时应尽可能不对原生的 JavaScript 进行修改甚至删除。" },
-	"javascript_0080_suggestion": { "message": "判断浏览器类型,若不是 IE 则弹出提示,告诉用户当前浏览器不能访问剪贴板。如:" },
-	"javascript_0081_suggestion": { "message": "由于 document.all 方法存在支持程度问题,获取元素还是推荐用 W3C DOM 规范中提供的 document.getElementById、document.getElementsByTagName 等标准方法。" },
-	"javascript_0082_suggestion": { "message": "某些协议是由特定的厂商自定义的,如:\"tencent://\" 和 \"msnim:chat\" 之类,需安装特定的客户端软件以注册该类伪协议,方可正常使用。例如,安装 QQ 或 MSN 应用程序。" },
-	"javascript_0083_suggestion": { "message": "以上所提到的情况,我们应该尽量避免,我们期望随着各浏览器新版本的发布,相应的问题也能得到修复,如 Chrome 的新版本就修复了 IFRAME 地址改变不记录历史记录的问题。" },
-	"javascript_0084_suggestion": { "message": "在 W3C HTML4 属性表中没有找到 bordercolor 属性,可见这并不是 W3C 规范中的标准属性,各浏览器根据各自的理解实现了该属性的渲染方式,应避免使用这种非标准属性。" },
-	"javascript_0085_suggestion": { "message": "当出现页面垂直滚动条的时候尽量使用 'document.body.scrollHeight' 获取页面滚动条的高度。" },
-	"javascript_0086_suggestion": { "message": "使用 \"||\" 逻辑语句将这两种获取方式相连,以保证兼容性。如:" },
-	"javascript_0087_suggestion": { "message": "使用两个半角空格代替一个全角空格。" },
-	"javascript_0088_suggestion": { "message": "通过上面的测试可以看到,仅仅在通过 name 属性获取 IFRAME 和 FRAME 元素内子页面的 window 对象时,所有浏览器没有差异。" },
-	"javascript_0089_suggestion": { "message": "使用 window.close() 来关闭窗口时,需注意以下两点:" },
-	"javascript_0090_suggestion": { "message": "对于必须动态附加到文档的外部 js 文件,要保证动态引入的脚本全部执行完成后,才能执行后续代码。" },
-	"javascript_0091_suggestion": { "message": "如果外部引用的 JavaScript 文件内程序,要求在执行顺序上一致,请避免使用 document.write 语句引入的 JS 程序文件中再次使用他来加载外部 JavaScript 文件。" },
-	"javascript_0092_suggestion": { "message": "HTML 4.01 中表示 \"nowrap\" 属性已经被废弃,使用 'white-space' 样式代替他 。" },
-	"javascript_0093_suggestion": { "message": "首先 MARQUEE 元素为非 W3C 标准元素,应尽量避免使用。若必须使用,则应尽量避免为 MARQUEE 元素设置其默认值之外的 'overflow'、 'display'、'-moz-bind' 特性值。" },
-	"javascript_0094_suggestion": { "message": "避免给 TABLE 设置 'bordercolor' ,使用 CSS 中 'border' 实现其效果,保证各浏览器兼容。" },
-	"javascript_0095_suggestion": { "message": "在现行 W3C 标准规范中仅有 XmlHttpRequest 对象中存在 onreadystatechange 事件 ( 请参考  XMLHttpRequest 规范 )。" },
-	"javascript_0096_suggestion": { "message": "对段落文字排版时须谨慎,注意标点符号的位置。如果不好控制文字内容,可以使用Javascript根据文字内容所占的高度动态缩改文字内容。" },
-	"javascript_0097_suggestion": { "message": "针对问题 1,避免使用可以触发这种特殊现象的字体,如 \"宋体\" ,为特殊字符设置其他字体。" },
-	"javascript_0098_suggestion": { "message": "避免使用 IE6 IE7 IE8  浏览器私有 DOM 属性值,改用标准 DOM 规范中定义的有度量单位的 \"width \"、\"height\"、\"top\"、 \"right\"、 \"left\"、 \"bottom\" 属性来代替它们。" },
-	"javascript_0099_suggestion": { "message": "用其他方式判断浏览器类型,避免使用 document.layers 属性;" },
-	"javascript_0100_suggestion": { "message": "使用 W3C 标准中的 document.getElementById(id) 方法获取对象。" },
-	"javascript_0101_suggestion": { "message": "上面提到的 IE 及 Firefox 中使通过 innerHTML 方法动态插入的 SCRIPT 元素中脚本执行的方法均比较特殊,是利用了浏览器的 Bug,或者是利用了浏览器提供的特性。而 innerHTML 方法只是用来插入 HTML 代码,并不能使其中包含的脚本代码执行。" },
-	"javascript_0102_suggestion": { "message": "总是为 MARQUEE 元素显式地设定一个宽度。" },
-	"javascript_0103_suggestion": { "message": "在 HTML5 尚未制定完成且普及时,使用 Flash 播放 MP3 文件,以保证最大的兼容性。" },
-	"javascript_0104_suggestion": { "message": "浏览器类型或版本判别推荐采用分析 navigator.userAgent 属性的方式。" },
-	"javascript_0105_suggestion": { "message": "在为 location 或 location.href 赋值做页面跳转时必须保证所赋的字符串地址的合法性,不要使用空字符串。" },
-	"javascript_0106_suggestion": { "message": "showModalDialog 方法与 showModelessDialog 方法均不被 W3C 支持,虽然 showModalDialog 方法目前已比较广泛的被支持,但还是应避免使用它。因为模态对话框会阻塞父窗口的输入,使其是去焦点,这将对用户体验不利。" },
-	"javascript_0107_suggestion": { "message": "避免在定位流内出现不可视元素且溢出父容器。" },
-	"javascript_0108_suggestion": { "message": "1. 可以为WBR元素添加一个 :after 伪元素,强迫其后插入一个软换行符。" },
-	"javascript_0109_suggestion": { "message": "可以使用下面的代码获取当前浏览器语言:" },
-	"javascript_0110_suggestion": { "message": "判断浏览器版本,使用不同的 XMLHttpRequest 对象创建方式。如:" },
-	"javascript_0111_suggestion": { "message": "window.execScript 方法不是所有浏览器都支持,同时所支持的脚本语言种类并不尽相同,请确定在目标浏览器均支持此方法的情况下再使用它。"},
-	"javascript_0112_suggestion": { "message": "避免深度复制 cloneNode(true) 包含 SCRIPT 元素的节点。" },
-	"javascript_0113_suggestion": { "message": "建议尽量避免对除 INPUT 和 BUTTON 元素以外的其他元素通过 click 方法模拟鼠标点击事件。" },
-	"javascript_0114_suggestion": { "message": "1. 在添加 OPTION 元素时,如果需要向指定索引前插入 OPTION,可以使用 options.add(option, index)。" }
-	
-}

+ 0 - 63
output/fe-helper/manifest.json

@@ -1,63 +0,0 @@
-{
-    "name": "WEB前端助手(FeHelper)",
-    "version": "2.0",
-    "manifest_version": 2,
-
-    "default_locale": "zh_CN",
-
-    "description": "FE助手:包括编码规范检测、栅格检测、字符串编解码、页面性能检测、JSON查看器、QR码生成工具",
-	"icons": { 
-		"16": "static/img/fe-16.png",
-		"48": "static/img/fe-48.png",
-		"128": "static/img/fe-128.png"
-	 }, 
-	 
-	"browser_action": {
-		"default_icon" : "static/img/fe-16.png",
-		"default_title" : "WEB前端助手",
-		"default_popup" : "template/fehelper_popup.html"
-	},
-
-    "background": {
-        "persistent": false,
-        "page": "template/fehelper_background.html"
-    },
-	"options_page": "template/fehelper_options.html",
-
-    "permissions": [
-        "tabs",
-        "contextMenus",
-        "cookies",
-        "notifications",
-        "alarms",
-        "webNavigation",
-        "\u003Call_urls\u003E"
-    ],
-
-    "web_accessible_resources": [
-        "static/img/43.png",
-        "static/img/baidufe_bj.png",
-        "static/img/grid.png",
-        "static/img/fe-18.png",
-        "static/img/fe-48.png",
-        "static/img/fe-128.png",
-        "static/img/pbar-ani.gif",
-        "static/img/ui-icons_228ef1_256x240.png",
-        "static/css/fe-helper.css",
-        "static/vendor/jquery-ui-1.8/css/jquery-ui-1.8.16.custom.hot_datauri.css"
-    ],
-
-	"content_scripts": [{	
-		"matches":["http://*/*","https://*/*"],
-		"js":[
-			"static/js/core/jquery-1.5.min.js",
-			"static/vendor/jquery-ui-1.8/js/jquery-ui-1.8.11.custom.min.js",
-			
-			"static/js/mod/mod_manifest.js"
-		],
-		"run_at":"document_end",
-		"all_frames":false
-	}],
-    "content_security_policy": "script-src 'self' https://ssl.google-analytics.com 'unsafe-eval'; object-src 'self'",
-    "homepage_url": "http://www.baidufe.com/item/889639af23968ee688b9.html"
-}

+ 0 - 1
output/fe-helper/static/css/fe-endecode.css

@@ -1 +0,0 @@
-html{background:url(../img/baidufe_bj.gif);font-size:14px}body{font-family:Arial,"simsun";color:#666}.mod-endecode{width:980px;margin:0 auto}.mod-endecode fieldset{border:1px solid #bbb;padding:10px;width:960px;margin-bottom:10px}.mod-endecode fieldset legend{padding:0 5px;color:red}.mod-endecode fieldset>div{margin-bottom:10px}.-e-x-container{width:980px;margin:0 auto;padding:30px 0 50px 0;min-height:400px}.-e-x-radio label:hover{color:#333;cursor:pointer}.-e-zxl-ta-src{width:950px;height:100px}.-e-x-btn{padding:10px;padding-bottom:0;height:24px}.-e-x-btn .-e-x-radio{float:left;font-size:14px}.-e-x-btn .-e-btn{float:right;height:30px;width:70px;font-size:13px;padding:5px;cursor:pointer}.-e-x-btn .-e-clear-btn{margin-left:20px;font-weight:normal}.-e-x-rst{margin:20px 0;display:none}.zxl-ta-rst{width:980px;height:100px}.-e-x-footer{text-align:center;font-size:12px;margin-top:30px;color:#00c;padding:5px;display:none}

+ 0 - 1
output/fe-helper/static/css/fe-endecode_datauri.css

@@ -1 +0,0 @@
-html{background:url(data:image/gif;base64,R0lGODlhBgAGAIAAAPPz8+bm5iH5BAAAAAAALAAAAAAGAAYAAAIJRI52aroY2lsFADs=);font-size:14px}body{font-family:Arial,"simsun";color:#666}.mod-endecode{width:980px;margin:0 auto}.mod-endecode fieldset{border:1px solid #bbb;padding:10px;width:960px;margin-bottom:10px}.mod-endecode fieldset legend{padding:0 5px;color:red}.mod-endecode fieldset>div{margin-bottom:10px}.-e-x-container{width:980px;margin:0 auto;padding:30px 0 50px 0;min-height:400px}.-e-x-radio label:hover{color:#333;cursor:pointer}.-e-zxl-ta-src{width:950px;height:100px}.-e-x-btn{padding:10px;padding-bottom:0;height:24px}.-e-x-btn .-e-x-radio{float:left;font-size:14px}.-e-x-btn .-e-btn{float:right;height:30px;width:70px;font-size:13px;padding:5px;cursor:pointer}.-e-x-btn .-e-clear-btn{margin-left:20px;font-weight:normal}.-e-x-rst{margin:20px 0;display:none}.zxl-ta-rst{width:980px;height:100px}.-e-x-footer{text-align:center;font-size:12px;margin-top:30px;color:#00c;padding:5px;display:none}

+ 0 - 1
output/fe-helper/static/css/fe-fdp.css

@@ -1 +0,0 @@
-body{font-family:Arial,"simsun"}#fdp-doc-box{width:924px;margin:0 auto;padding:50px 0 50px 0;min-height:500px;text-align:center;background:-webkit-gradient(linear, left top, left bottom, from(#B0DDE5), to(#fefefe));-webkit-border-radius:8px}#fdp-doc-logo .fdp-logo-f{width:80px;margin-right:-30px}#fdp-doc-logo .fdp-logo-e{width:80px}#fdp-doc-nav{font-size:16px;text-align:center}#fdp-doc-nav .-d-list{margin:0;padding:0;list-style:none}#fdp-doc-nav .-d-normal{color:#333;display:inline;cursor:pointer;padding:5px}#fdp-doc-nav .-d-normal:hover{color:#f00}#fe-doc{margin-left:20px}#fdp-doc-nav .-d-sub{font-size:6px;color:#48b}#fdp-doc-nav .-d-sub span{color:#f00}#fdp-doc-nav .-d-selected{border:1px solid #555;-webkit-border-radius:5px 5px;background:#444;color:#ff0}#fdp-doc-form{padding:20px}#fdp-doc-form .fdp-search-input{width:400px;height:22px;line-height:22px;padding:2px 34px 2px 2px;border:2px solid #075;-webkit-border-radius:5px 5px}#fdp-doc-form .fdp-search-btn{width:24px;cursor:pointer;margin:0 0 -7px -40px;border-left:1px solid #bbb;padding-left:2px;-webkit-opacity:.5}#fdp-doc-form .fdp-search-btn:hover{-webkit-opacity:1}#fdp-doc-rst-list{text-align:left;margin:10px 25px 0;font-size:14px}#fdp-doc-rst-list dt{color:#084A4D;font-weight:bold;line-height:24px;height:24px}#fdp-doc-rst-list dd{display:block;line-height:26px;position:relative;padding:0;margin:0;text-indent:0;border:0}#fdp-doc-rst-list i{font-style:normal;color:#888}#fdp-doc-rst-list a{color:#37628B;text-decoration:none;height:26px}#fdp-doc-rst-list a:hover{text-decoration:underline}#fdp-doc-rst-list .-d-author{color:#777;font-style:normal;display:block;height:26px;overflow:hidden;position:absolute;right:0;top:0;width:250px}#fdp-doc-rst-list .-d-no-result{color:#b00;font-weight:bold}#fdp-doc-rst-list .-d-highlight{color:#f00}

Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/css/fe-helper.css


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/css/fe-jsonformat.css


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/css/fe-jsonformat_datauri.css


+ 0 - 1
output/fe-helper/static/css/fe-opt.css

@@ -1 +0,0 @@
-body{font-family:"MS Sans Serif";font-size:14px}.fe-opt-header{height:120px;width:100%;position:fixed;top:0;left:0}.fe-opt-header .top{padding:10px}.fe-opt-header .top img{width:60px}.fe-opt-header .top .text{font-size:20pt;position:absolute;top:30px;left:80px}.fe-opt-header .top .copy-right{font-size:12px;position:absolute;bottom:35px;right:10px;color:#77C}.fe-opt-header .bar{height:30px;width:100%;position:absolute;bottom:0;left:0;border-top:1px solid #78b;background:#def;clear:both}.fe-opt-header .bar:after{content:"\20"}.fe-opt-header .bar .text{float:left;padding:5px}.fe-opt-header .bar .btn{float:right;margin:5px 10px;font-weight:bold;color:#00b;cursor:pointer}.fe-opt-header .bar .btn.close{margin-left:0;margin-right:20px}.fe-opt-header .bar .btn:hover{color:#b00}.fe-opt-content{position:absolute;top:120px;left:0;bottom:0;right:0}.fe-opt-content .left{position:absolute;top:0;left:0;bottom:0;width:200px;border-right:5px solid #def}.fe-opt-content .left ul{margin:0;padding:5px}.fe-opt-content .left li{padding:6px 0 6px 20px;cursor:default;margin:4px 0;list-style:none}.fe-opt-content .left li:hover{background:#eee;color:#b00}.fe-opt-content .left li.selected{background:#eee;color:#b00}.fe-opt-content .right{position:absolute;left:210px}.fe-opt-content .right .title{margin:20px 0 10px;color:#48b;font-weight:bold}.fe-opt-content .right ul{margin:0;padding:5px}.fe-opt-content .right ul li{margin:0 0 0 20px;padding:5px}.fe-opt-content .right ul.no-list-style li{margin:0;list-style:none}.fe-opt-content .right ul li:hover{background:#f8f8f0}.fe-hide{display:none}.fe-opt-footer{}

+ 0 - 1
output/fe-helper/static/css/fe-popup.css

@@ -1 +0,0 @@
-body{font-size:14px;font-family:"arial","simsun";-webkit-user-select:none;padding:0;margin:0;width:150px;position:relative;overflow:hidden}.fe-hide{display:none}.fe-function-title{width:100%;padding:5px;color:#522;font-weight:bolder;cursor:default;border-bottom:1px dotted #aaa}ul.fe-function-list{padding:0;list-style:none}ul.fe-function-list li{padding:3px 3px 3px 10px;cursor:pointer;color:#555;-webkit-transition:all .4s ease}ul.fe-function-list li:hover{color:#ff3C11;background:#f1f1f1}ul.fe-function-list li>span{padding-left:24px}ul.fe-function-list li>b{width:14px;height:14px;background:url(../img/ui-icons_228ef1_256x240.png) no-repeat;-webkit-transition:all .5s ease;position:absolute}ul.fe-function-list li:hover>b{-webkit-transform:rotate(360deg)}ul.fe-function-list li.-x-fcp b{background-position:0 -145px}ul.fe-function-list li.-x-grid b{background-position:-113px -113px}ul.fe-function-list li.-x-fdp b{background-position:-162px -113px}ul.fe-function-list li.-x-endecode b{background-position:-113px -81px}ul.fe-function-list li.-x-loadtime b{background-position:-81px -113px}ul.fe-function-list li.-x-jsonformat b{background-position:-224px -113px}ul.fe-function-list li.-x-qrcode b{background-position:-81px -209px}.fe-feedback{font-size:12px;border-top:1px dotted #ddd;padding:5px 15px 5px 5px;text-align:right}.fe-feedback  a{text-decoration:none;color:#888}.fe-feedback  a:hover{color:#a00}

+ 0 - 1
output/fe-helper/static/css/fe-qrcode.css

@@ -1 +0,0 @@
-html{background:url(../img/baidufe_bj.gif);font-size:14px;color:#333}.mod-qrcode{width:980px;margin:0 auto}.mod-qrcode fieldset{border:1px solid #bbb;padding:10px;width:960px;margin-bottom:10px}.mod-qrcode fieldset legend{padding:0 5px;color:red}.mod-qrcode fieldset>div{margin-bottom:10px}.mod-qrcode .qr-item{line-height:16px}#source,#size{width:30px;height:22px;padding:2px 5px}#source{width:800px;height:50px}.mod-qrcode .qr-item button{width:80px;height:30px;float:right;margin-right:17px}.mod-qrcode a{color:#009}#demo .item{border-bottom:1px solid #ccc;font-size:12px;margin:10px 80px 10px 70px}#demo .item .title{color:red;font-weight:bold;margin-right:10px;float:left}#demo .item .test{}

+ 0 - 1
output/fe-helper/static/css/fe-qrcode_datauri.css

@@ -1 +0,0 @@
-html{background:url(data:image/gif;base64,R0lGODlhBgAGAIAAAPPz8+bm5iH5BAAAAAAALAAAAAAGAAYAAAIJRI52aroY2lsFADs=);font-size:14px;color:#333}.mod-qrcode{width:980px;margin:0 auto}.mod-qrcode fieldset{border:1px solid #bbb;padding:10px;width:960px;margin-bottom:10px}.mod-qrcode fieldset legend{padding:0 5px;color:red}.mod-qrcode fieldset>div{margin-bottom:10px}.mod-qrcode .qr-item{line-height:16px}#source,#size{width:30px;height:22px;padding:2px 5px}#source{width:800px;height:50px}.mod-qrcode .qr-item button{width:80px;height:30px;float:right;margin-right:17px}.mod-qrcode a{color:#009}#demo .item{border-bottom:1px solid #ccc;font-size:12px;margin:10px 80px 10px 70px}#demo .item .title{color:red;font-weight:bold;margin-right:10px;float:left}#demo .item .test{}

BIN
output/fe-helper/static/img/43.png


BIN
output/fe-helper/static/img/baidufe_bj.gif


BIN
output/fe-helper/static/img/fe-128.png


BIN
output/fe-helper/static/img/fe-16.png


BIN
output/fe-helper/static/img/fe-48.png


BIN
output/fe-helper/static/img/grid.png


BIN
output/fe-helper/static/img/pbar-ani.gif


BIN
output/fe-helper/static/img/ui-icons_228ef1_256x240.png


+ 0 - 1
output/fe-helper/static/js/core/core.js

@@ -1 +0,0 @@
-var baidu=function(){this.version="1.3.5"};baidu.namespace=new Object();baidu.namespace.register=function(fullNS){var reg=/^[_$a-z]+[_$a-z0-9]*/i;var nsArray=fullNS.split(".");var sEval="";var sNS="";for(var i=0;i<nsArray.length;i++){if(!reg.test(nsArray[i])){throw new Error("Invalid namespace:"+nsArray[i]+"");return}if(i!=0){sNS+="."}sNS+=nsArray[i];sEval+="if (typeof("+sNS+") == 'undefined') "+sNS+" = new Object();"}if(sEval!=""){eval(sEval)}};String.prototype.trim=function(){return this.replace(/^\s*|\s*$/g,"")};String.prototype.format=function(){var b=arguments.length,a=this;while(b--){a=a.replace(new RegExp("\\{"+b+"\\}","g"),arguments[b])}return a};Date.prototype.format=function(e){var a=function(m,l){var n="",k=(m<0),j=String(Math.abs(m));if(j.length<l){n=(new Array(l-j.length+1)).join("0")}return(k?"-":"")+n+j};if("string"!=typeof e){return this.toString()}var b=function(k,j){e=e.replace(k,j)};var f=this.getFullYear(),d=this.getMonth()+1,i=this.getDate(),g=this.getHours(),c=this.getMinutes(),h=this.getSeconds();b(/yyyy/g,a(f,4));b(/yy/g,a(parseInt(f.toString().slice(2),10),2));b(/MM/g,a(d,2));b(/M/g,d);b(/dd/g,a(i,2));b(/d/g,i);b(/HH/g,a(g,2));b(/H/g,g);b(/hh/g,a(g%12,2));b(/h/g,g%12);b(/mm/g,a(c,2));b(/m/g,c);b(/ss/g,a(h,2));b(/s/g,h);return e};String.prototype.getBytes=function(){var b=this.replace(/\n/g,"xx").replace(/\t/g,"x");var a=encodeURIComponent(b);return a.replace(/%[A-Z0-9][A-Z0-9]/g,"x").length};var getOuterHtmlEllipsis=function(d){var b=/(<[^>]+>)/g;var a=b.exec(d.outerHTML);var c=a?a[1]:d.outerHTML;c=c.length>40?c.substr(0,40)+"...":c;return c.replace(/</g,"&lt;").replace(/>/g,"&gt;")};var getOuterAndInnerHtmlEllipsis=function(b){var a=jQuery("<div></div>").append(b).html()};(function(){baidu.i18n={};baidu.i18n.getMessage=function(d,b){if(b){for(var c=0,a=b.length;c<a;c++){b[c]=""+b[c]}return chrome.i18n.getMessage(d,b)}else{return chrome.i18n.getMessage(d)}}})();

Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/core/fe-const.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 15
output/fe-helper/static/js/core/jquery-1.5.min.js


+ 0 - 1
output/fe-helper/static/js/core/log.js

@@ -1 +0,0 @@
-baidu.namespace.register("baidu.log");baidu.log=(function(){var a=function(b,e){var d=109,f=2009,g="http://nsclick.baidu.com/v.gif?pid="+d+"&url="+encodeURIComponent(e)+"&type="+f+"&m="+b+"&_t="+Math.random();var i="imglog__"+(new Date()).getTime(),h=window[i]=new Image();h.onload=(h.onerror=function(){window[i]=null});h.src=g;h=null};return{track:a}})();

+ 0 - 1
output/fe-helper/static/js/core/network.js

@@ -1 +0,0 @@
-baidu.namespace.register("baidu.network");baidu.network=(function(){var d=function(f,h){var g=new XMLHttpRequest();g.onreadystatechange=function(){if(g.readyState===4){var i;if(g.status===200&&g.responseText){i={success:true,type:FILE.LINK,path:f,content:g.responseText}}else{i={success:false,type:FILE.LINK,path:f,content:"FcpHelper can't load such file."}}h(i)}};g.open("GET",f,true);g.setRequestHeader("Content-Type","text/plain;charset=UTF-8");g.setRequestHeader("Access-Control-Allow-Origin","*");g.send()};var a=function(f){return"http"+(f.secure?"s":"")+"://"+f.domain+f.path};var c=function(g,h){var f=[];chrome.cookies.getAll({},function(l){for(var k=0,j=l.length;k<j;k++){if(g.url.indexOf(l[k].domain.substring(1))>-1){l[k].url=a(l[k]);f.push(l[k])}}l.sort(function(m,i){return m.domain.localeCompare(i.domain)});h.call(null,{cookie:f})})};var e=function(f,g){chrome.cookies.getAll({},function(m){for(var l=0,k=m.length;l<k;l++){var j=a(m[l]);var h=m[l].name;if(j==f.url&&h==f.name){chrome.cookies.remove({url:j,name:h});if(g&&typeof g=="function"){g.call(null)}return}}})};var b=function(f,g){chrome.cookies.getAll({},function(m){for(var l=0,k=m.length;l<k;l++){var j=a(m[l]);var h=m[l].name;if(j==f.url&&h==f.name){chrome.cookies.set(f);if(g&&typeof g=="function"){g.call(null)}return}}})};return{readFileContent:d,getCookies:c,removeCookie:e,setCookie:b}})();

Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/endecode/endecode-lib.js


+ 0 - 1
output/fe-helper/static/js/endecode/endecode.js

@@ -1 +0,0 @@
-baidu.namespace.register("baidu.ed");baidu.ed=(function(){var d=function(){var f=jQuery("#srcText").val();jQuery("#rst").show();var g=jQuery("#rstCode");if(jQuery("#uniEncode").attr("checked")==true){g.val(baidu.endecode.uniEncode(f))}else{if(jQuery("#uniDecode").attr("checked")==true){g.val(baidu.endecode.uniDecode(f))}else{if(jQuery("#utf8Encode").attr("checked")==true){g.val(encodeURIComponent(f))}else{if(jQuery("#utf8Decode").attr("checked")==true){g.val(decodeURIComponent(f))}else{if(jQuery("#base64Encode").attr("checked")==true){g.val(baidu.endecode.base64Encode(baidu.endecode.utf8Encode(f)))}else{if(jQuery("#base64Decode").attr("checked")==true){g.val(baidu.endecode.utf8Decode(baidu.endecode.base64Decode(f)))}else{g.val(hex_md5(f))}}}}}}};var c=function(){jQuery("#btnCodeChange").click(function(){baidu.log.track(LOG.endecode_page_btnchange);d()});jQuery("#btnCodeClear").click(function(){baidu.log.track(LOG.endecode_page_btnclear);jQuery("#srcText,#rstCode").val("")})};var b=function(){jQuery("input[type=radio],label[for]").click(function(f){$this=jQuery(this);setTimeout(function(){baidu.log.track(LOG["endecode_page_"+$this.attr("id")]);d()},150)})};var a=function(){jQuery("#rstCode").mouseover(function(){this.selectionStart=0;this.selectionEnd=this.value.length;this.select()})};var e=function(){jQuery(function(){baidu.log.track(LOG.endecode_page_opened);jQuery("#srcText").focus();c();a();b()})};return{init:e}})();baidu.ed.init();

Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/endecode/md5.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/fcp/css/fcp-css-analytic.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/fcp/css/fcp-css.js


+ 0 - 1
output/fe-helper/static/js/fcp/fcp-fl.js

@@ -1 +0,0 @@
-baidu.namespace.register("baidu.FL");baidu.FL=new (function(){this.FL_EOF=1;this.FL_TPL_DELIMITER=2;this.FL_NEW_LINE=3;this.FL_NORMAL=4;this.HTML_CONTENT=111;this.HTML_TAG=112;this.HTML_JS_START=113;this.HTML_JS_CONTENT=114;this.HTML_JS_END=115;this.HTML_CSS_START=116;this.HTML_CSS_CONTENT=117;this.HTML_CSS_END=118;this.HTML_IE_HACK_START=119;this.HTML_IE_HACK_EDN=120;this.HTML_DOC_TYPE=121;this.HTML_COMMENT=122;this.HTML_STATUS_OK=123;this.HTML_TAG_START=124;this.HTML_TAG_END=125;this.HTML_TPL_ATTR_NAME=126;this.HTML_XML=127;this.HTML_TEXTAREA_START=128;this.HTML_TEXTAREA_CONTENT=129;this.HTML_TEXTAREA_END=130;this.HTML_PRE_START=131;this.HTML_PRE_CONTENT=132;this.HTML_PRE_END=133;this.JS_START_EXPR=211;this.JS_END_EXPR=212;this.JS_START_BLOCK=213;this.JS_END_BLOCK=214;this.JS_SEMICOLON=215;this.JS_WORD=216;this.JS_OPERATOR=217;this.JS_EQUALS=218;this.JS_INLINE_COMMENT=219;this.JS_BLOCK_COMMENT=220;this.JS_COMMENT=221;this.JS_STRING=222;this.JS_IE_CC=223;this.JS_REGEXP=224;this.JS_MODE_EXPRESSION=250;this.JS_MODE_INDENT_EXPRESSION=251;this.JS_MODE_DO_BLOCK=252;this.JS_MODE_BLOCK=253;this.JS_MODE_ARRAY=254;this.CSS_AT=311;this.CSS_NORMAL=312;this.CSS_DEVICE_DESC=313;this.CSS_DEVICE_START=314;this.CSS_DEVICE_END=315;this.CSS_SELECTOER=316;this.CSS_SELECTOER_START=317;this.CSS_SELECTOER_END=318;this.CSS_COMMENT=319;this.CSS_PROPERTY=320;this.CSS_VALUE=321;this.CSS_SEMICOLON=322;this.CSS_COLON=323})();

Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/fcp/fcp-main.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/fcp/fcp-tabs.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/fcp/html/fcp-html-analytic.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/fcp/html/fcp-html-doctype.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/fcp/html/fcp-html.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/fcp/js/fcp-js-analytic.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/fcp/js/fcp-js.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/fdp/fdp-main.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/fe-background.js


+ 0 - 1
output/fe-helper/static/js/fe-helper.js

@@ -1 +0,0 @@
-baidu.namespace.register("baidu.fehelper");baidu.fehelper=(function(){var b=function(){if(!jQuery("#_fehelper_jq_ui_css_")[0]){var f=chrome.extension.getURL("static/vendor/jquery-ui-1.8/css/jquery-ui-1.8.16.custom.hot_datauri.css");jQuery('<link id="_fehelper_jq_ui_css_" href="'+f+'" rel="stylesheet" type="text/css" />').appendTo("head");var e=chrome.extension.getURL("static/css/fe-helper.css");jQuery('<link id="_fehelper_fcp_css_" href="'+e+'" rel="stylesheet" type="text/css" />').appendTo("head")}};var a=function(){baidu.fcphelper.initStaticFile();chrome.extension.onMessage.addListener(function(f,e,g){if(f.type==MSG_TYPE.BROWSER_CLICKED&&f.event==MSG_TYPE.FCP_HELPER_DETECT){b();baidu.fcphelper.initHtml(function(){baidu.fcphelper.detect()})}})};var c=function(){chrome.extension.onMessage.addListener(function(f,e,g){if(f.type==MSG_TYPE.BROWSER_CLICKED&&f.event==MSG_TYPE.GRID_DETECT){b();baidu.grid.detect()}})};var d=function(){a();c()};return{main:d}})();baidu.fehelper.main();

+ 0 - 1
output/fe-helper/static/js/fe-option.js

@@ -1 +0,0 @@
-baidu.feOption=(function(){var d=function(o){for(var p in o){window.localStorage.setItem(p,o[p])}};var f=function(p){var r={};for(var q=0,o=p.length;q<o;q++){r[p[q]]=window.localStorage.getItem(p[q])}return r};var l=function(o,p){chrome.extension.sendMessage({type:MSG_TYPE.GET_OPTIONS,items:o},p)};var j=function(o){chrome.extension.sendMessage({type:MSG_TYPE.SET_OPTIONS,items:o})};var a=function(o,p){if(p&&typeof p=="function"){p.call(null,f(o))}};var n=function(o){d(o)};var b=function(o){return f([o])[o]};var c=function(){var o={};o.opt_item_contextMenus=$("#opt_item_contextMenus").attr("checked");o.opt_item_showfdpmenu=$("#opt_item_showfdpmenu").attr("checked");o.opt_item_notification=$("#opt_item_notification").val();j(o)};var k=function(){var o=["opt_item_contextMenus","opt_item_showfdpmenu","opt_item_notification"];l(o,function(p){$.each(o,function(q,r){if(q==2){$("#"+r).val(p[r])}else{if(p[r]==="true"){$("#"+r).attr("checked","checked")}}})})};var e=function(o){switch(o){case"opt_form_start":c();break;case"":break}};var i=function(){chrome.tabs.getSelected(null,function(o){chrome.tabs.remove(o.id)})};var h=function(){$("#fe-opt-list-item>li").click(function(p){var o=$(this).siblings().removeClass("selected").end().addClass("selected");$(o.attr("data-content")).siblings().removeClass("selected").addClass("fe-hide").end().removeClass("fe-hide").addClass("selected")});$(".right form").submit(function(o){e($(this).attr("id"));i();o.preventDefault();o.stopPropagation()});$("#btn_close").click(function(){baidu.log.track(LOG.options_page_btnclose);i()});$("#btn_save").click(function(){baidu.log.track(LOG.options_page_btnsave);$(".right div.selected form").submit()})};var m=function(){k()};var g=function(){baidu.log.track(LOG.options_page_opened);h();m()};return{init:g,doSetOptions:n,doGetOptions:a,getOptionItem:b}})();

+ 0 - 1
output/fe-helper/static/js/fe-popup.js

@@ -1 +0,0 @@
-baidu.fePopup=(function(){var a=null;var e=function(){jQuery(".fe-function-list .-x-fcp").click(function(l){baidu.log.track(LOG.popup_page_fcp);window.close();a.BgPageInstance.runHelperByType(MSG_TYPE.FCP_HELPER_DETECT)})};var g=function(){jQuery(".fe-function-list .-x-grid").click(function(l){baidu.log.track(LOG.popup_page_grid);window.close();a.BgPageInstance.runHelperByType(MSG_TYPE.GRID_DETECT)})};var d=function(){jQuery(".fe-function-list .-x-fdp").click(function(l){baidu.log.track(LOG.popup_page_fdp);window.close();a.BgPageInstance.runHelperByType(MSG_TYPE.FDP_HELPER)})};var j=function(){jQuery(".fe-function-list .-x-endecode").click(function(l){baidu.log.track(LOG.popup_page_endecode);window.close();a.BgPageInstance.runHelperByType(MSG_TYPE.EN_DECODE)})};var b=function(){jQuery(".fe-function-list .-x-jsonformat").click(function(l){window.close();a.BgPageInstance.runHelperByType(MSG_TYPE.JSON_FORMAT)})};var k=function(){jQuery(".fe-function-list .-x-qrcode").click(function(l){window.close();a.BgPageInstance.runHelperByType(MSG_TYPE.QR_CODE)})};var f=function(){if(a.baidu.feOption.getOptionItem("opt_item_showfdpmenu")=="true"){jQuery("li.-x-fdp").removeClass("fe-hide");d()}};var i=function(){jQuery(".fe-function-list .-x-loadtime").click(function(l){baidu.log.track(LOG.popup_page_loadtime);window.close();a.BgPageInstance.runHelperByType(MSG_TYPE.SHOW_PAGE_LOAD_TIME)})};var h=function(){e();g();f();j();i();b();k()};var c=function(){chrome.runtime.getBackgroundPage(function(l){a=l;h()})};return{init:c}})();$(function(){baidu.fePopup.init()});

+ 0 - 1
output/fe-helper/static/js/google_analytics.js

@@ -1 +0,0 @@
-var _gaq=_gaq||[];_gaq.push(["_setAccount","UA-32516930-1"]);_gaq.push(["_trackPageview"]);(function(){var b=document.createElement("script");b.type="text/javascript";b.async=true;b.src="https://ssl.google-analytics.com/ga.js";var a=document.getElementsByTagName("script")[0];a.parentNode.insertBefore(b,a)})();

Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/grid/grid-main.js


+ 0 - 1
output/fe-helper/static/js/jsonformat/fe-jsonformat.js

@@ -1 +0,0 @@
-baidu.jsonformat=(function(){var a=function(){$("#btnFormat").click(function(d){var c=$.trim($("#jsonSource").val());JsonFormatEntrance.clear();JsonFormatEntrance.format(c)})};var b=function(){$(function(){a()})};return{init:b}})();baidu.jsonformat.init();

Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/jsonformat/json-format-dealer.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/jsonformat/json-format-ent.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/mod/mod_background.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/mod/mod_endecode.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/mod/mod_fdp.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/mod/mod_jsonformat.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/mod/mod_manifest.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/mod/mod_options.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/mod/mod_popup.js


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/js/mod/mod_qrcode.js


+ 0 - 1
output/fe-helper/static/js/notification/fe-notification.js

@@ -1 +0,0 @@
-baidu.feNotification=(function(){var a=function(c){var d=encodeURIComponent;var e=webkitNotifications.createHTMLNotification(chrome.extension.getURL(c));e.show();return e};var b=function(c){if(!c.icon){c.icon="static/img/fe-48.png"}if(!c.title){c.title="\u5C0F\u63D0\u793A"}var d=webkitNotifications.createNotification(chrome.extension.getURL(c.icon),c.title,c.message);d.show();if(c.autoClose!==false){d.ondisplay=function(g){var f=localStorage.getItem("opt_item_notification");setTimeout(function(){d.cancel()},f||5000)}}return d};return{notifyHtml:a,notifyText:b}})();

+ 0 - 1
output/fe-helper/static/js/qrcode/fe-qrcode.js

@@ -1 +0,0 @@
-baidu.qrcode=(function(){var a=function(){$("#btnQR").click(function(g){var d=$.trim($("#source").val().replace(/\n/gm," "));var f=parseInt($("#size").val(),10)||4;var c=new Image();var h="http://www.baidufe.com/qrcode?url="+encodeURIComponent(d)+"&size="+f;c.onload=function(){$("#qrResult").html('<img src="'+h+'" alt="QR" title="QR码">')};c.src=h;$("#qrResult").html("QR码生成中,请稍后...")});$("#btnDemo").click(function(c){$("#demo").toggle();c.preventDefault()});$("#demo a.test").click(function(c){$("#source").val($(this).prev(".content").html().trim());c.preventDefault()})};var b=function(){$(function(){a()})};return{init:b}})();baidu.qrcode.init();

+ 0 - 1
output/fe-helper/static/js/wpo/fe-calc-wpo.js

@@ -1 +0,0 @@
-baidu.calcPageLoadTime=(function(){var b={};var c=function(){if(b.header&&b.time){a()}else{$.ajax({type:"GET",url:window.location.href,complete:function(g,f){b.header={date:g.getResponseHeader("Date"),contentEncoding:g.getResponseHeader("Content-Encoding"),connection:g.getResponseHeader("Connection"),contentLength:g.getResponseHeader("Content-Length"),server:g.getResponseHeader("Server"),vary:g.getResponseHeader("Vary"),transferEncoding:g.getResponseHeader("Transfer-Encoding"),contentType:g.getResponseHeader("Content-Type"),cacheControl:g.getResponseHeader("Cache-Control"),exprires:g.getResponseHeader("Exprires"),lastModified:g.getResponseHeader("Last-Modified")};e();a()}})}};var e=function(){b.time=performance.timing};var a=function(){chrome.extension.sendMessage({type:MSG_TYPE.CALC_PAGE_LOAD_TIME,wpo:b})};var d=function(){chrome.extension.onMessage.addListener(function(h,g,i){if(h.type==MSG_TYPE.GET_PAGE_WPO_INFO){(function f(){(document.readyState=="complete")?c():setTimeout(f,1000)})()}})};return{init:d}})();baidu.calcPageLoadTime.init();

+ 0 - 1
output/fe-helper/static/js/wpo/fe-wpo.js

@@ -1 +0,0 @@
-baidu.namespace.register("baidu.pageLoadTime");baidu.pageLoadTime=(function(){var a=function(){function k(m,h){try{document.getElementById(m).innerHTML=h+" ms"}catch(l){}}var f=decodeURIComponent(location.search.substring(1));var j=JSON.parse(f);var c=j.time;var i=c.redirectStart==0?c.fetchStart:c.redirectStart;k("dns",c.domainLookupEnd-c.domainLookupStart);k("dnsTotal",c.domainLookupEnd-i);k("connect",c.connectEnd-c.connectStart);k("requestTotal",c.requestStart-i);k("response",c.responseStart-c.requestStart);k("responseTotal",c.responseStart-i);k("responseEnd",c.responseEnd-c.responseStart);k("responseEndTotal",c.responseEnd-i);k("contentLoaded",c.domContentLoadedEventEnd-c.domLoading);k("contentLoadedTotal",c.domContentLoadedEventEnd-i);k("domComplete",c.domComplete-c.domContentLoadedEventEnd);k("domCompleteTotal",c.domComplete-i);k("loadTotal",c.loadEventEnd-i);var d=j.header;for(var b in d){try{document.getElementById(b).innerHTML=d[b]||" - "}catch(g){}}};return{init:a}})();baidu.pageLoadTime.init();

Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/vendor/jquery-ui-1.8/css/jquery-ui-1.8.16.custom.blue_datauri.css


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/vendor/jquery-ui-1.8/css/jquery-ui-1.8.16.custom.color_datauri.css


Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/static/vendor/jquery-ui-1.8/css/jquery-ui-1.8.16.custom.hot_datauri.css


+ 0 - 783
output/fe-helper/static/vendor/jquery-ui-1.8/js/jquery-ui-1.8.11.custom.min.js

@@ -1,783 +0,0 @@
-/*!
- * jQuery UI 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI
- */
-(function(c,j){function k(a){return!c(a).parents().andSelf().filter(function(){return c.curCSS(this,"visibility")==="hidden"||c.expr.filters.hidden(this)}).length}c.ui=c.ui||{};if(!c.ui.version){c.extend(c.ui,{version:"1.8.11",keyCode:{ALT:18,BACKSPACE:8,CAPS_LOCK:20,COMMA:188,COMMAND:91,COMMAND_LEFT:91,COMMAND_RIGHT:93,CONTROL:17,DELETE:46,DOWN:40,END:35,ENTER:13,ESCAPE:27,HOME:36,INSERT:45,LEFT:37,MENU:93,NUMPAD_ADD:107,NUMPAD_DECIMAL:110,NUMPAD_DIVIDE:111,NUMPAD_ENTER:108,NUMPAD_MULTIPLY:106,
-NUMPAD_SUBTRACT:109,PAGE_DOWN:34,PAGE_UP:33,PERIOD:190,RIGHT:39,SHIFT:16,SPACE:32,TAB:9,UP:38,WINDOWS:91}});c.fn.extend({_focus:c.fn.focus,focus:function(a,b){return typeof a==="number"?this.each(function(){var d=this;setTimeout(function(){c(d).focus();b&&b.call(d)},a)}):this._focus.apply(this,arguments)},scrollParent:function(){var a;a=c.browser.msie&&/(static|relative)/.test(this.css("position"))||/absolute/.test(this.css("position"))?this.parents().filter(function(){return/(relative|absolute|fixed)/.test(c.curCSS(this,
-"position",1))&&/(auto|scroll)/.test(c.curCSS(this,"overflow",1)+c.curCSS(this,"overflow-y",1)+c.curCSS(this,"overflow-x",1))}).eq(0):this.parents().filter(function(){return/(auto|scroll)/.test(c.curCSS(this,"overflow",1)+c.curCSS(this,"overflow-y",1)+c.curCSS(this,"overflow-x",1))}).eq(0);return/fixed/.test(this.css("position"))||!a.length?c(document):a},zIndex:function(a){if(a!==j)return this.css("zIndex",a);if(this.length){a=c(this[0]);for(var b;a.length&&a[0]!==document;){b=a.css("position");
-if(b==="absolute"||b==="relative"||b==="fixed"){b=parseInt(a.css("zIndex"),10);if(!isNaN(b)&&b!==0)return b}a=a.parent()}}return 0},disableSelection:function(){return this.bind((c.support.selectstart?"selectstart":"mousedown")+".ui-disableSelection",function(a){a.preventDefault()})},enableSelection:function(){return this.unbind(".ui-disableSelection")}});c.each(["Width","Height"],function(a,b){function d(f,g,l,m){c.each(e,function(){g-=parseFloat(c.curCSS(f,"padding"+this,true))||0;if(l)g-=parseFloat(c.curCSS(f,
-"border"+this+"Width",true))||0;if(m)g-=parseFloat(c.curCSS(f,"margin"+this,true))||0});return g}var e=b==="Width"?["Left","Right"]:["Top","Bottom"],h=b.toLowerCase(),i={innerWidth:c.fn.innerWidth,innerHeight:c.fn.innerHeight,outerWidth:c.fn.outerWidth,outerHeight:c.fn.outerHeight};c.fn["inner"+b]=function(f){if(f===j)return i["inner"+b].call(this);return this.each(function(){c(this).css(h,d(this,f)+"px")})};c.fn["outer"+b]=function(f,g){if(typeof f!=="number")return i["outer"+b].call(this,f);return this.each(function(){c(this).css(h,
-d(this,f,true,g)+"px")})}});c.extend(c.expr[":"],{data:function(a,b,d){return!!c.data(a,d[3])},focusable:function(a){var b=a.nodeName.toLowerCase(),d=c.attr(a,"tabindex");if("area"===b){b=a.parentNode;d=b.name;if(!a.href||!d||b.nodeName.toLowerCase()!=="map")return false;a=c("img[usemap=#"+d+"]")[0];return!!a&&k(a)}return(/input|select|textarea|button|object/.test(b)?!a.disabled:"a"==b?a.href||!isNaN(d):!isNaN(d))&&k(a)},tabbable:function(a){var b=c.attr(a,"tabindex");return(isNaN(b)||b>=0)&&c(a).is(":focusable")}});
-c(function(){var a=document.body,b=a.appendChild(b=document.createElement("div"));c.extend(b.style,{minHeight:"100px",height:"auto",padding:0,borderWidth:0});c.support.minHeight=b.offsetHeight===100;c.support.selectstart="onselectstart"in b;a.removeChild(b).style.display="none"});c.extend(c.ui,{plugin:{add:function(a,b,d){a=c.ui[a].prototype;for(var e in d){a.plugins[e]=a.plugins[e]||[];a.plugins[e].push([b,d[e]])}},call:function(a,b,d){if((b=a.plugins[b])&&a.element[0].parentNode)for(var e=0;e<b.length;e++)a.options[b[e][0]]&&
-b[e][1].apply(a.element,d)}},contains:function(a,b){return document.compareDocumentPosition?a.compareDocumentPosition(b)&16:a!==b&&a.contains(b)},hasScroll:function(a,b){if(c(a).css("overflow")==="hidden")return false;b=b&&b==="left"?"scrollLeft":"scrollTop";var d=false;if(a[b]>0)return true;a[b]=1;d=a[b]>0;a[b]=0;return d},isOverAxis:function(a,b,d){return a>b&&a<b+d},isOver:function(a,b,d,e,h,i){return c.ui.isOverAxis(a,d,h)&&c.ui.isOverAxis(b,e,i)}})}})(jQuery);
-;/*!
- * jQuery UI Widget 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Widget
- */
-(function(b,j){if(b.cleanData){var k=b.cleanData;b.cleanData=function(a){for(var c=0,d;(d=a[c])!=null;c++)b(d).triggerHandler("remove");k(a)}}else{var l=b.fn.remove;b.fn.remove=function(a,c){return this.each(function(){if(!c)if(!a||b.filter(a,[this]).length)b("*",this).add([this]).each(function(){b(this).triggerHandler("remove")});return l.call(b(this),a,c)})}}b.widget=function(a,c,d){var e=a.split(".")[0],f;a=a.split(".")[1];f=e+"-"+a;if(!d){d=c;c=b.Widget}b.expr[":"][f]=function(h){return!!b.data(h,
-a)};b[e]=b[e]||{};b[e][a]=function(h,g){arguments.length&&this._createWidget(h,g)};c=new c;c.options=b.extend(true,{},c.options);b[e][a].prototype=b.extend(true,c,{namespace:e,widgetName:a,widgetEventPrefix:b[e][a].prototype.widgetEventPrefix||a,widgetBaseClass:f},d);b.widget.bridge(a,b[e][a])};b.widget.bridge=function(a,c){b.fn[a]=function(d){var e=typeof d==="string",f=Array.prototype.slice.call(arguments,1),h=this;d=!e&&f.length?b.extend.apply(null,[true,d].concat(f)):d;if(e&&d.charAt(0)==="_")return h;
-e?this.each(function(){var g=b.data(this,a),i=g&&b.isFunction(g[d])?g[d].apply(g,f):g;if(i!==g&&i!==j){h=i;return false}}):this.each(function(){var g=b.data(this,a);g?g.option(d||{})._init():b.data(this,a,new c(d,this))});return h}};b.Widget=function(a,c){arguments.length&&this._createWidget(a,c)};b.Widget.prototype={widgetName:"widget",widgetEventPrefix:"",options:{disabled:false},_createWidget:function(a,c){b.data(c,this.widgetName,this);this.element=b(c);this.options=b.extend(true,{},this.options,
-this._getCreateOptions(),a);var d=this;this.element.bind("remove."+this.widgetName,function(){d.destroy()});this._create();this._trigger("create");this._init()},_getCreateOptions:function(){return b.metadata&&b.metadata.get(this.element[0])[this.widgetName]},_create:function(){},_init:function(){},destroy:function(){this.element.unbind("."+this.widgetName).removeData(this.widgetName);this.widget().unbind("."+this.widgetName).removeAttr("aria-disabled").removeClass(this.widgetBaseClass+"-disabled ui-state-disabled")},
-widget:function(){return this.element},option:function(a,c){var d=a;if(arguments.length===0)return b.extend({},this.options);if(typeof a==="string"){if(c===j)return this.options[a];d={};d[a]=c}this._setOptions(d);return this},_setOptions:function(a){var c=this;b.each(a,function(d,e){c._setOption(d,e)});return this},_setOption:function(a,c){this.options[a]=c;if(a==="disabled")this.widget()[c?"addClass":"removeClass"](this.widgetBaseClass+"-disabled ui-state-disabled").attr("aria-disabled",c);return this},
-enable:function(){return this._setOption("disabled",false)},disable:function(){return this._setOption("disabled",true)},_trigger:function(a,c,d){var e=this.options[a];c=b.Event(c);c.type=(a===this.widgetEventPrefix?a:this.widgetEventPrefix+a).toLowerCase();d=d||{};if(c.originalEvent){a=b.event.props.length;for(var f;a;){f=b.event.props[--a];c[f]=c.originalEvent[f]}}this.element.trigger(c,d);return!(b.isFunction(e)&&e.call(this.element[0],c,d)===false||c.isDefaultPrevented())}}})(jQuery);
-;/*!
- * jQuery UI Mouse 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Mouse
- *
- * Depends:
- *	jquery.ui.widget.js
- */
-(function(b){b.widget("ui.mouse",{options:{cancel:":input,option",distance:1,delay:0},_mouseInit:function(){var a=this;this.element.bind("mousedown."+this.widgetName,function(c){return a._mouseDown(c)}).bind("click."+this.widgetName,function(c){if(true===b.data(c.target,a.widgetName+".preventClickEvent")){b.removeData(c.target,a.widgetName+".preventClickEvent");c.stopImmediatePropagation();return false}});this.started=false},_mouseDestroy:function(){this.element.unbind("."+this.widgetName)},_mouseDown:function(a){a.originalEvent=
-a.originalEvent||{};if(!a.originalEvent.mouseHandled){this._mouseStarted&&this._mouseUp(a);this._mouseDownEvent=a;var c=this,e=a.which==1,f=typeof this.options.cancel=="string"?b(a.target).parents().add(a.target).filter(this.options.cancel).length:false;if(!e||f||!this._mouseCapture(a))return true;this.mouseDelayMet=!this.options.delay;if(!this.mouseDelayMet)this._mouseDelayTimer=setTimeout(function(){c.mouseDelayMet=true},this.options.delay);if(this._mouseDistanceMet(a)&&this._mouseDelayMet(a)){this._mouseStarted=
-this._mouseStart(a)!==false;if(!this._mouseStarted){a.preventDefault();return true}}true===b.data(a.target,this.widgetName+".preventClickEvent")&&b.removeData(a.target,this.widgetName+".preventClickEvent");this._mouseMoveDelegate=function(d){return c._mouseMove(d)};this._mouseUpDelegate=function(d){return c._mouseUp(d)};b(document).bind("mousemove."+this.widgetName,this._mouseMoveDelegate).bind("mouseup."+this.widgetName,this._mouseUpDelegate);a.preventDefault();return a.originalEvent.mouseHandled=
-true}},_mouseMove:function(a){if(b.browser.msie&&!(document.documentMode>=9)&&!a.button)return this._mouseUp(a);if(this._mouseStarted){this._mouseDrag(a);return a.preventDefault()}if(this._mouseDistanceMet(a)&&this._mouseDelayMet(a))(this._mouseStarted=this._mouseStart(this._mouseDownEvent,a)!==false)?this._mouseDrag(a):this._mouseUp(a);return!this._mouseStarted},_mouseUp:function(a){b(document).unbind("mousemove."+this.widgetName,this._mouseMoveDelegate).unbind("mouseup."+this.widgetName,this._mouseUpDelegate);
-if(this._mouseStarted){this._mouseStarted=false;a.target==this._mouseDownEvent.target&&b.data(a.target,this.widgetName+".preventClickEvent",true);this._mouseStop(a)}return false},_mouseDistanceMet:function(a){return Math.max(Math.abs(this._mouseDownEvent.pageX-a.pageX),Math.abs(this._mouseDownEvent.pageY-a.pageY))>=this.options.distance},_mouseDelayMet:function(){return this.mouseDelayMet},_mouseStart:function(){},_mouseDrag:function(){},_mouseStop:function(){},_mouseCapture:function(){return true}})})(jQuery);
-;/*
- * jQuery UI Position 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Position
- */
-(function(c){c.ui=c.ui||{};var n=/left|center|right/,o=/top|center|bottom/,t=c.fn.position,u=c.fn.offset;c.fn.position=function(b){if(!b||!b.of)return t.apply(this,arguments);b=c.extend({},b);var a=c(b.of),d=a[0],g=(b.collision||"flip").split(" "),e=b.offset?b.offset.split(" "):[0,0],h,k,j;if(d.nodeType===9){h=a.width();k=a.height();j={top:0,left:0}}else if(d.setTimeout){h=a.width();k=a.height();j={top:a.scrollTop(),left:a.scrollLeft()}}else if(d.preventDefault){b.at="left top";h=k=0;j={top:b.of.pageY,
-left:b.of.pageX}}else{h=a.outerWidth();k=a.outerHeight();j=a.offset()}c.each(["my","at"],function(){var f=(b[this]||"").split(" ");if(f.length===1)f=n.test(f[0])?f.concat(["center"]):o.test(f[0])?["center"].concat(f):["center","center"];f[0]=n.test(f[0])?f[0]:"center";f[1]=o.test(f[1])?f[1]:"center";b[this]=f});if(g.length===1)g[1]=g[0];e[0]=parseInt(e[0],10)||0;if(e.length===1)e[1]=e[0];e[1]=parseInt(e[1],10)||0;if(b.at[0]==="right")j.left+=h;else if(b.at[0]==="center")j.left+=h/2;if(b.at[1]==="bottom")j.top+=
-k;else if(b.at[1]==="center")j.top+=k/2;j.left+=e[0];j.top+=e[1];return this.each(function(){var f=c(this),l=f.outerWidth(),m=f.outerHeight(),p=parseInt(c.curCSS(this,"marginLeft",true))||0,q=parseInt(c.curCSS(this,"marginTop",true))||0,v=l+p+(parseInt(c.curCSS(this,"marginRight",true))||0),w=m+q+(parseInt(c.curCSS(this,"marginBottom",true))||0),i=c.extend({},j),r;if(b.my[0]==="right")i.left-=l;else if(b.my[0]==="center")i.left-=l/2;if(b.my[1]==="bottom")i.top-=m;else if(b.my[1]==="center")i.top-=
-m/2;i.left=Math.round(i.left);i.top=Math.round(i.top);r={left:i.left-p,top:i.top-q};c.each(["left","top"],function(s,x){c.ui.position[g[s]]&&c.ui.position[g[s]][x](i,{targetWidth:h,targetHeight:k,elemWidth:l,elemHeight:m,collisionPosition:r,collisionWidth:v,collisionHeight:w,offset:e,my:b.my,at:b.at})});c.fn.bgiframe&&f.bgiframe();f.offset(c.extend(i,{using:b.using}))})};c.ui.position={fit:{left:function(b,a){var d=c(window);d=a.collisionPosition.left+a.collisionWidth-d.width()-d.scrollLeft();b.left=
-d>0?b.left-d:Math.max(b.left-a.collisionPosition.left,b.left)},top:function(b,a){var d=c(window);d=a.collisionPosition.top+a.collisionHeight-d.height()-d.scrollTop();b.top=d>0?b.top-d:Math.max(b.top-a.collisionPosition.top,b.top)}},flip:{left:function(b,a){if(a.at[0]!=="center"){var d=c(window);d=a.collisionPosition.left+a.collisionWidth-d.width()-d.scrollLeft();var g=a.my[0]==="left"?-a.elemWidth:a.my[0]==="right"?a.elemWidth:0,e=a.at[0]==="left"?a.targetWidth:-a.targetWidth,h=-2*a.offset[0];b.left+=
-a.collisionPosition.left<0?g+e+h:d>0?g+e+h:0}},top:function(b,a){if(a.at[1]!=="center"){var d=c(window);d=a.collisionPosition.top+a.collisionHeight-d.height()-d.scrollTop();var g=a.my[1]==="top"?-a.elemHeight:a.my[1]==="bottom"?a.elemHeight:0,e=a.at[1]==="top"?a.targetHeight:-a.targetHeight,h=-2*a.offset[1];b.top+=a.collisionPosition.top<0?g+e+h:d>0?g+e+h:0}}}};if(!c.offset.setOffset){c.offset.setOffset=function(b,a){if(/static/.test(c.curCSS(b,"position")))b.style.position="relative";var d=c(b),
-g=d.offset(),e=parseInt(c.curCSS(b,"top",true),10)||0,h=parseInt(c.curCSS(b,"left",true),10)||0;g={top:a.top-g.top+e,left:a.left-g.left+h};"using"in a?a.using.call(b,g):d.css(g)};c.fn.offset=function(b){var a=this[0];if(!a||!a.ownerDocument)return null;if(b)return this.each(function(){c.offset.setOffset(this,b)});return u.call(this)}}})(jQuery);
-;/*
- * jQuery UI Draggable 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Draggables
- *
- * Depends:
- *	jquery.ui.core.js
- *	jquery.ui.mouse.js
- *	jquery.ui.widget.js
- */
-(function(d){d.widget("ui.draggable",d.ui.mouse,{widgetEventPrefix:"drag",options:{addClasses:true,appendTo:"parent",axis:false,connectToSortable:false,containment:false,cursor:"auto",cursorAt:false,grid:false,handle:false,helper:"original",iframeFix:false,opacity:false,refreshPositions:false,revert:false,revertDuration:500,scope:"default",scroll:true,scrollSensitivity:20,scrollSpeed:20,snap:false,snapMode:"both",snapTolerance:20,stack:false,zIndex:false},_create:function(){if(this.options.helper==
-"original"&&!/^(?:r|a|f)/.test(this.element.css("position")))this.element[0].style.position="relative";this.options.addClasses&&this.element.addClass("ui-draggable");this.options.disabled&&this.element.addClass("ui-draggable-disabled");this._mouseInit()},destroy:function(){if(this.element.data("draggable")){this.element.removeData("draggable").unbind(".draggable").removeClass("ui-draggable ui-draggable-dragging ui-draggable-disabled");this._mouseDestroy();return this}},_mouseCapture:function(a){var b=
-this.options;if(this.helper||b.disabled||d(a.target).is(".ui-resizable-handle"))return false;this.handle=this._getHandle(a);if(!this.handle)return false;return true},_mouseStart:function(a){var b=this.options;this.helper=this._createHelper(a);this._cacheHelperProportions();if(d.ui.ddmanager)d.ui.ddmanager.current=this;this._cacheMargins();this.cssPosition=this.helper.css("position");this.scrollParent=this.helper.scrollParent();this.offset=this.positionAbs=this.element.offset();this.offset={top:this.offset.top-
-this.margins.top,left:this.offset.left-this.margins.left};d.extend(this.offset,{click:{left:a.pageX-this.offset.left,top:a.pageY-this.offset.top},parent:this._getParentOffset(),relative:this._getRelativeOffset()});this.originalPosition=this.position=this._generatePosition(a);this.originalPageX=a.pageX;this.originalPageY=a.pageY;b.cursorAt&&this._adjustOffsetFromHelper(b.cursorAt);b.containment&&this._setContainment();if(this._trigger("start",a)===false){this._clear();return false}this._cacheHelperProportions();
-d.ui.ddmanager&&!b.dropBehaviour&&d.ui.ddmanager.prepareOffsets(this,a);this.helper.addClass("ui-draggable-dragging");this._mouseDrag(a,true);return true},_mouseDrag:function(a,b){this.position=this._generatePosition(a);this.positionAbs=this._convertPositionTo("absolute");if(!b){b=this._uiHash();if(this._trigger("drag",a,b)===false){this._mouseUp({});return false}this.position=b.position}if(!this.options.axis||this.options.axis!="y")this.helper[0].style.left=this.position.left+"px";if(!this.options.axis||
-this.options.axis!="x")this.helper[0].style.top=this.position.top+"px";d.ui.ddmanager&&d.ui.ddmanager.drag(this,a);return false},_mouseStop:function(a){var b=false;if(d.ui.ddmanager&&!this.options.dropBehaviour)b=d.ui.ddmanager.drop(this,a);if(this.dropped){b=this.dropped;this.dropped=false}if((!this.element[0]||!this.element[0].parentNode)&&this.options.helper=="original")return false;if(this.options.revert=="invalid"&&!b||this.options.revert=="valid"&&b||this.options.revert===true||d.isFunction(this.options.revert)&&
-this.options.revert.call(this.element,b)){var c=this;d(this.helper).animate(this.originalPosition,parseInt(this.options.revertDuration,10),function(){c._trigger("stop",a)!==false&&c._clear()})}else this._trigger("stop",a)!==false&&this._clear();return false},cancel:function(){this.helper.is(".ui-draggable-dragging")?this._mouseUp({}):this._clear();return this},_getHandle:function(a){var b=!this.options.handle||!d(this.options.handle,this.element).length?true:false;d(this.options.handle,this.element).find("*").andSelf().each(function(){if(this==
-a.target)b=true});return b},_createHelper:function(a){var b=this.options;a=d.isFunction(b.helper)?d(b.helper.apply(this.element[0],[a])):b.helper=="clone"?this.element.clone():this.element;a.parents("body").length||a.appendTo(b.appendTo=="parent"?this.element[0].parentNode:b.appendTo);a[0]!=this.element[0]&&!/(fixed|absolute)/.test(a.css("position"))&&a.css("position","absolute");return a},_adjustOffsetFromHelper:function(a){if(typeof a=="string")a=a.split(" ");if(d.isArray(a))a={left:+a[0],top:+a[1]||
-0};if("left"in a)this.offset.click.left=a.left+this.margins.left;if("right"in a)this.offset.click.left=this.helperProportions.width-a.right+this.margins.left;if("top"in a)this.offset.click.top=a.top+this.margins.top;if("bottom"in a)this.offset.click.top=this.helperProportions.height-a.bottom+this.margins.top},_getParentOffset:function(){this.offsetParent=this.helper.offsetParent();var a=this.offsetParent.offset();if(this.cssPosition=="absolute"&&this.scrollParent[0]!=document&&d.ui.contains(this.scrollParent[0],
-this.offsetParent[0])){a.left+=this.scrollParent.scrollLeft();a.top+=this.scrollParent.scrollTop()}if(this.offsetParent[0]==document.body||this.offsetParent[0].tagName&&this.offsetParent[0].tagName.toLowerCase()=="html"&&d.browser.msie)a={top:0,left:0};return{top:a.top+(parseInt(this.offsetParent.css("borderTopWidth"),10)||0),left:a.left+(parseInt(this.offsetParent.css("borderLeftWidth"),10)||0)}},_getRelativeOffset:function(){if(this.cssPosition=="relative"){var a=this.element.position();return{top:a.top-
-(parseInt(this.helper.css("top"),10)||0)+this.scrollParent.scrollTop(),left:a.left-(parseInt(this.helper.css("left"),10)||0)+this.scrollParent.scrollLeft()}}else return{top:0,left:0}},_cacheMargins:function(){this.margins={left:parseInt(this.element.css("marginLeft"),10)||0,top:parseInt(this.element.css("marginTop"),10)||0,right:parseInt(this.element.css("marginRight"),10)||0,bottom:parseInt(this.element.css("marginBottom"),10)||0}},_cacheHelperProportions:function(){this.helperProportions={width:this.helper.outerWidth(),
-height:this.helper.outerHeight()}},_setContainment:function(){var a=this.options;if(a.containment=="parent")a.containment=this.helper[0].parentNode;if(a.containment=="document"||a.containment=="window")this.containment=[(a.containment=="document"?0:d(window).scrollLeft())-this.offset.relative.left-this.offset.parent.left,(a.containment=="document"?0:d(window).scrollTop())-this.offset.relative.top-this.offset.parent.top,(a.containment=="document"?0:d(window).scrollLeft())+d(a.containment=="document"?
-document:window).width()-this.helperProportions.width-this.margins.left,(a.containment=="document"?0:d(window).scrollTop())+(d(a.containment=="document"?document:window).height()||document.body.parentNode.scrollHeight)-this.helperProportions.height-this.margins.top];if(!/^(document|window|parent)$/.test(a.containment)&&a.containment.constructor!=Array){var b=d(a.containment)[0];if(b){a=d(a.containment).offset();var c=d(b).css("overflow")!="hidden";this.containment=[a.left+(parseInt(d(b).css("borderLeftWidth"),
-10)||0)+(parseInt(d(b).css("paddingLeft"),10)||0),a.top+(parseInt(d(b).css("borderTopWidth"),10)||0)+(parseInt(d(b).css("paddingTop"),10)||0),a.left+(c?Math.max(b.scrollWidth,b.offsetWidth):b.offsetWidth)-(parseInt(d(b).css("borderLeftWidth"),10)||0)-(parseInt(d(b).css("paddingRight"),10)||0)-this.helperProportions.width-this.margins.left-this.margins.right,a.top+(c?Math.max(b.scrollHeight,b.offsetHeight):b.offsetHeight)-(parseInt(d(b).css("borderTopWidth"),10)||0)-(parseInt(d(b).css("paddingBottom"),
-10)||0)-this.helperProportions.height-this.margins.top-this.margins.bottom]}}else if(a.containment.constructor==Array)this.containment=a.containment},_convertPositionTo:function(a,b){if(!b)b=this.position;a=a=="absolute"?1:-1;var c=this.cssPosition=="absolute"&&!(this.scrollParent[0]!=document&&d.ui.contains(this.scrollParent[0],this.offsetParent[0]))?this.offsetParent:this.scrollParent,f=/(html|body)/i.test(c[0].tagName);return{top:b.top+this.offset.relative.top*a+this.offset.parent.top*a-(d.browser.safari&&
-d.browser.version<526&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollTop():f?0:c.scrollTop())*a),left:b.left+this.offset.relative.left*a+this.offset.parent.left*a-(d.browser.safari&&d.browser.version<526&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollLeft():f?0:c.scrollLeft())*a)}},_generatePosition:function(a){var b=this.options,c=this.cssPosition=="absolute"&&!(this.scrollParent[0]!=document&&d.ui.contains(this.scrollParent[0],
-this.offsetParent[0]))?this.offsetParent:this.scrollParent,f=/(html|body)/i.test(c[0].tagName),e=a.pageX,g=a.pageY;if(this.originalPosition){if(this.containment){if(a.pageX-this.offset.click.left<this.containment[0])e=this.containment[0]+this.offset.click.left;if(a.pageY-this.offset.click.top<this.containment[1])g=this.containment[1]+this.offset.click.top;if(a.pageX-this.offset.click.left>this.containment[2])e=this.containment[2]+this.offset.click.left;if(a.pageY-this.offset.click.top>this.containment[3])g=
-this.containment[3]+this.offset.click.top}if(b.grid){g=this.originalPageY+Math.round((g-this.originalPageY)/b.grid[1])*b.grid[1];g=this.containment?!(g-this.offset.click.top<this.containment[1]||g-this.offset.click.top>this.containment[3])?g:!(g-this.offset.click.top<this.containment[1])?g-b.grid[1]:g+b.grid[1]:g;e=this.originalPageX+Math.round((e-this.originalPageX)/b.grid[0])*b.grid[0];e=this.containment?!(e-this.offset.click.left<this.containment[0]||e-this.offset.click.left>this.containment[2])?
-e:!(e-this.offset.click.left<this.containment[0])?e-b.grid[0]:e+b.grid[0]:e}}return{top:g-this.offset.click.top-this.offset.relative.top-this.offset.parent.top+(d.browser.safari&&d.browser.version<526&&this.cssPosition=="fixed"?0:this.cssPosition=="fixed"?-this.scrollParent.scrollTop():f?0:c.scrollTop()),left:e-this.offset.click.left-this.offset.relative.left-this.offset.parent.left+(d.browser.safari&&d.browser.version<526&&this.cssPosition=="fixed"?0:this.cssPosition=="fixed"?-this.scrollParent.scrollLeft():
-f?0:c.scrollLeft())}},_clear:function(){this.helper.removeClass("ui-draggable-dragging");this.helper[0]!=this.element[0]&&!this.cancelHelperRemoval&&this.helper.remove();this.helper=null;this.cancelHelperRemoval=false},_trigger:function(a,b,c){c=c||this._uiHash();d.ui.plugin.call(this,a,[b,c]);if(a=="drag")this.positionAbs=this._convertPositionTo("absolute");return d.Widget.prototype._trigger.call(this,a,b,c)},plugins:{},_uiHash:function(){return{helper:this.helper,position:this.position,originalPosition:this.originalPosition,
-offset:this.positionAbs}}});d.extend(d.ui.draggable,{version:"1.8.11"});d.ui.plugin.add("draggable","connectToSortable",{start:function(a,b){var c=d(this).data("draggable"),f=c.options,e=d.extend({},b,{item:c.element});c.sortables=[];d(f.connectToSortable).each(function(){var g=d.data(this,"sortable");if(g&&!g.options.disabled){c.sortables.push({instance:g,shouldRevert:g.options.revert});g.refreshPositions();g._trigger("activate",a,e)}})},stop:function(a,b){var c=d(this).data("draggable"),f=d.extend({},
-b,{item:c.element});d.each(c.sortables,function(){if(this.instance.isOver){this.instance.isOver=0;c.cancelHelperRemoval=true;this.instance.cancelHelperRemoval=false;if(this.shouldRevert)this.instance.options.revert=true;this.instance._mouseStop(a);this.instance.options.helper=this.instance.options._helper;c.options.helper=="original"&&this.instance.currentItem.css({top:"auto",left:"auto"})}else{this.instance.cancelHelperRemoval=false;this.instance._trigger("deactivate",a,f)}})},drag:function(a,b){var c=
-d(this).data("draggable"),f=this;d.each(c.sortables,function(){this.instance.positionAbs=c.positionAbs;this.instance.helperProportions=c.helperProportions;this.instance.offset.click=c.offset.click;if(this.instance._intersectsWith(this.instance.containerCache)){if(!this.instance.isOver){this.instance.isOver=1;this.instance.currentItem=d(f).clone().appendTo(this.instance.element).data("sortable-item",true);this.instance.options._helper=this.instance.options.helper;this.instance.options.helper=function(){return b.helper[0]};
-a.target=this.instance.currentItem[0];this.instance._mouseCapture(a,true);this.instance._mouseStart(a,true,true);this.instance.offset.click.top=c.offset.click.top;this.instance.offset.click.left=c.offset.click.left;this.instance.offset.parent.left-=c.offset.parent.left-this.instance.offset.parent.left;this.instance.offset.parent.top-=c.offset.parent.top-this.instance.offset.parent.top;c._trigger("toSortable",a);c.dropped=this.instance.element;c.currentItem=c.element;this.instance.fromOutside=c}this.instance.currentItem&&
-this.instance._mouseDrag(a)}else if(this.instance.isOver){this.instance.isOver=0;this.instance.cancelHelperRemoval=true;this.instance.options.revert=false;this.instance._trigger("out",a,this.instance._uiHash(this.instance));this.instance._mouseStop(a,true);this.instance.options.helper=this.instance.options._helper;this.instance.currentItem.remove();this.instance.placeholder&&this.instance.placeholder.remove();c._trigger("fromSortable",a);c.dropped=false}})}});d.ui.plugin.add("draggable","cursor",
-{start:function(){var a=d("body"),b=d(this).data("draggable").options;if(a.css("cursor"))b._cursor=a.css("cursor");a.css("cursor",b.cursor)},stop:function(){var a=d(this).data("draggable").options;a._cursor&&d("body").css("cursor",a._cursor)}});d.ui.plugin.add("draggable","iframeFix",{start:function(){var a=d(this).data("draggable").options;d(a.iframeFix===true?"iframe":a.iframeFix).each(function(){d('<div class="ui-draggable-iframeFix" style="background: #fff;"></div>').css({width:this.offsetWidth+
-"px",height:this.offsetHeight+"px",position:"absolute",opacity:"0.001",zIndex:1E3}).css(d(this).offset()).appendTo("body")})},stop:function(){d("div.ui-draggable-iframeFix").each(function(){this.parentNode.removeChild(this)})}});d.ui.plugin.add("draggable","opacity",{start:function(a,b){a=d(b.helper);b=d(this).data("draggable").options;if(a.css("opacity"))b._opacity=a.css("opacity");a.css("opacity",b.opacity)},stop:function(a,b){a=d(this).data("draggable").options;a._opacity&&d(b.helper).css("opacity",
-a._opacity)}});d.ui.plugin.add("draggable","scroll",{start:function(){var a=d(this).data("draggable");if(a.scrollParent[0]!=document&&a.scrollParent[0].tagName!="HTML")a.overflowOffset=a.scrollParent.offset()},drag:function(a){var b=d(this).data("draggable"),c=b.options,f=false;if(b.scrollParent[0]!=document&&b.scrollParent[0].tagName!="HTML"){if(!c.axis||c.axis!="x")if(b.overflowOffset.top+b.scrollParent[0].offsetHeight-a.pageY<c.scrollSensitivity)b.scrollParent[0].scrollTop=f=b.scrollParent[0].scrollTop+
-c.scrollSpeed;else if(a.pageY-b.overflowOffset.top<c.scrollSensitivity)b.scrollParent[0].scrollTop=f=b.scrollParent[0].scrollTop-c.scrollSpeed;if(!c.axis||c.axis!="y")if(b.overflowOffset.left+b.scrollParent[0].offsetWidth-a.pageX<c.scrollSensitivity)b.scrollParent[0].scrollLeft=f=b.scrollParent[0].scrollLeft+c.scrollSpeed;else if(a.pageX-b.overflowOffset.left<c.scrollSensitivity)b.scrollParent[0].scrollLeft=f=b.scrollParent[0].scrollLeft-c.scrollSpeed}else{if(!c.axis||c.axis!="x")if(a.pageY-d(document).scrollTop()<
-c.scrollSensitivity)f=d(document).scrollTop(d(document).scrollTop()-c.scrollSpeed);else if(d(window).height()-(a.pageY-d(document).scrollTop())<c.scrollSensitivity)f=d(document).scrollTop(d(document).scrollTop()+c.scrollSpeed);if(!c.axis||c.axis!="y")if(a.pageX-d(document).scrollLeft()<c.scrollSensitivity)f=d(document).scrollLeft(d(document).scrollLeft()-c.scrollSpeed);else if(d(window).width()-(a.pageX-d(document).scrollLeft())<c.scrollSensitivity)f=d(document).scrollLeft(d(document).scrollLeft()+
-c.scrollSpeed)}f!==false&&d.ui.ddmanager&&!c.dropBehaviour&&d.ui.ddmanager.prepareOffsets(b,a)}});d.ui.plugin.add("draggable","snap",{start:function(){var a=d(this).data("draggable"),b=a.options;a.snapElements=[];d(b.snap.constructor!=String?b.snap.items||":data(draggable)":b.snap).each(function(){var c=d(this),f=c.offset();this!=a.element[0]&&a.snapElements.push({item:this,width:c.outerWidth(),height:c.outerHeight(),top:f.top,left:f.left})})},drag:function(a,b){for(var c=d(this).data("draggable"),
-f=c.options,e=f.snapTolerance,g=b.offset.left,n=g+c.helperProportions.width,m=b.offset.top,o=m+c.helperProportions.height,h=c.snapElements.length-1;h>=0;h--){var i=c.snapElements[h].left,k=i+c.snapElements[h].width,j=c.snapElements[h].top,l=j+c.snapElements[h].height;if(i-e<g&&g<k+e&&j-e<m&&m<l+e||i-e<g&&g<k+e&&j-e<o&&o<l+e||i-e<n&&n<k+e&&j-e<m&&m<l+e||i-e<n&&n<k+e&&j-e<o&&o<l+e){if(f.snapMode!="inner"){var p=Math.abs(j-o)<=e,q=Math.abs(l-m)<=e,r=Math.abs(i-n)<=e,s=Math.abs(k-g)<=e;if(p)b.position.top=
-c._convertPositionTo("relative",{top:j-c.helperProportions.height,left:0}).top-c.margins.top;if(q)b.position.top=c._convertPositionTo("relative",{top:l,left:0}).top-c.margins.top;if(r)b.position.left=c._convertPositionTo("relative",{top:0,left:i-c.helperProportions.width}).left-c.margins.left;if(s)b.position.left=c._convertPositionTo("relative",{top:0,left:k}).left-c.margins.left}var t=p||q||r||s;if(f.snapMode!="outer"){p=Math.abs(j-m)<=e;q=Math.abs(l-o)<=e;r=Math.abs(i-g)<=e;s=Math.abs(k-n)<=e;if(p)b.position.top=
-c._convertPositionTo("relative",{top:j,left:0}).top-c.margins.top;if(q)b.position.top=c._convertPositionTo("relative",{top:l-c.helperProportions.height,left:0}).top-c.margins.top;if(r)b.position.left=c._convertPositionTo("relative",{top:0,left:i}).left-c.margins.left;if(s)b.position.left=c._convertPositionTo("relative",{top:0,left:k-c.helperProportions.width}).left-c.margins.left}if(!c.snapElements[h].snapping&&(p||q||r||s||t))c.options.snap.snap&&c.options.snap.snap.call(c.element,a,d.extend(c._uiHash(),
-{snapItem:c.snapElements[h].item}));c.snapElements[h].snapping=p||q||r||s||t}else{c.snapElements[h].snapping&&c.options.snap.release&&c.options.snap.release.call(c.element,a,d.extend(c._uiHash(),{snapItem:c.snapElements[h].item}));c.snapElements[h].snapping=false}}}});d.ui.plugin.add("draggable","stack",{start:function(){var a=d(this).data("draggable").options;a=d.makeArray(d(a.stack)).sort(function(c,f){return(parseInt(d(c).css("zIndex"),10)||0)-(parseInt(d(f).css("zIndex"),10)||0)});if(a.length){var b=
-parseInt(a[0].style.zIndex)||0;d(a).each(function(c){this.style.zIndex=b+c});this[0].style.zIndex=b+a.length}}});d.ui.plugin.add("draggable","zIndex",{start:function(a,b){a=d(b.helper);b=d(this).data("draggable").options;if(a.css("zIndex"))b._zIndex=a.css("zIndex");a.css("zIndex",b.zIndex)},stop:function(a,b){a=d(this).data("draggable").options;a._zIndex&&d(b.helper).css("zIndex",a._zIndex)}})})(jQuery);
-;/*
- * jQuery UI Droppable 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Droppables
- *
- * Depends:
- *	jquery.ui.core.js
- *	jquery.ui.widget.js
- *	jquery.ui.mouse.js
- *	jquery.ui.draggable.js
- */
-(function(d){d.widget("ui.droppable",{widgetEventPrefix:"drop",options:{accept:"*",activeClass:false,addClasses:true,greedy:false,hoverClass:false,scope:"default",tolerance:"intersect"},_create:function(){var a=this.options,b=a.accept;this.isover=0;this.isout=1;this.accept=d.isFunction(b)?b:function(c){return c.is(b)};this.proportions={width:this.element[0].offsetWidth,height:this.element[0].offsetHeight};d.ui.ddmanager.droppables[a.scope]=d.ui.ddmanager.droppables[a.scope]||[];d.ui.ddmanager.droppables[a.scope].push(this);
-a.addClasses&&this.element.addClass("ui-droppable")},destroy:function(){for(var a=d.ui.ddmanager.droppables[this.options.scope],b=0;b<a.length;b++)a[b]==this&&a.splice(b,1);this.element.removeClass("ui-droppable ui-droppable-disabled").removeData("droppable").unbind(".droppable");return this},_setOption:function(a,b){if(a=="accept")this.accept=d.isFunction(b)?b:function(c){return c.is(b)};d.Widget.prototype._setOption.apply(this,arguments)},_activate:function(a){var b=d.ui.ddmanager.current;this.options.activeClass&&
-this.element.addClass(this.options.activeClass);b&&this._trigger("activate",a,this.ui(b))},_deactivate:function(a){var b=d.ui.ddmanager.current;this.options.activeClass&&this.element.removeClass(this.options.activeClass);b&&this._trigger("deactivate",a,this.ui(b))},_over:function(a){var b=d.ui.ddmanager.current;if(!(!b||(b.currentItem||b.element)[0]==this.element[0]))if(this.accept.call(this.element[0],b.currentItem||b.element)){this.options.hoverClass&&this.element.addClass(this.options.hoverClass);
-this._trigger("over",a,this.ui(b))}},_out:function(a){var b=d.ui.ddmanager.current;if(!(!b||(b.currentItem||b.element)[0]==this.element[0]))if(this.accept.call(this.element[0],b.currentItem||b.element)){this.options.hoverClass&&this.element.removeClass(this.options.hoverClass);this._trigger("out",a,this.ui(b))}},_drop:function(a,b){var c=b||d.ui.ddmanager.current;if(!c||(c.currentItem||c.element)[0]==this.element[0])return false;var e=false;this.element.find(":data(droppable)").not(".ui-draggable-dragging").each(function(){var g=
-d.data(this,"droppable");if(g.options.greedy&&!g.options.disabled&&g.options.scope==c.options.scope&&g.accept.call(g.element[0],c.currentItem||c.element)&&d.ui.intersect(c,d.extend(g,{offset:g.element.offset()}),g.options.tolerance)){e=true;return false}});if(e)return false;if(this.accept.call(this.element[0],c.currentItem||c.element)){this.options.activeClass&&this.element.removeClass(this.options.activeClass);this.options.hoverClass&&this.element.removeClass(this.options.hoverClass);this._trigger("drop",
-a,this.ui(c));return this.element}return false},ui:function(a){return{draggable:a.currentItem||a.element,helper:a.helper,position:a.position,offset:a.positionAbs}}});d.extend(d.ui.droppable,{version:"1.8.11"});d.ui.intersect=function(a,b,c){if(!b.offset)return false;var e=(a.positionAbs||a.position.absolute).left,g=e+a.helperProportions.width,f=(a.positionAbs||a.position.absolute).top,h=f+a.helperProportions.height,i=b.offset.left,k=i+b.proportions.width,j=b.offset.top,l=j+b.proportions.height;
-switch(c){case "fit":return i<=e&&g<=k&&j<=f&&h<=l;case "intersect":return i<e+a.helperProportions.width/2&&g-a.helperProportions.width/2<k&&j<f+a.helperProportions.height/2&&h-a.helperProportions.height/2<l;case "pointer":return d.ui.isOver((a.positionAbs||a.position.absolute).top+(a.clickOffset||a.offset.click).top,(a.positionAbs||a.position.absolute).left+(a.clickOffset||a.offset.click).left,j,i,b.proportions.height,b.proportions.width);case "touch":return(f>=j&&f<=l||h>=j&&h<=l||f<j&&h>l)&&(e>=
-i&&e<=k||g>=i&&g<=k||e<i&&g>k);default:return false}};d.ui.ddmanager={current:null,droppables:{"default":[]},prepareOffsets:function(a,b){var c=d.ui.ddmanager.droppables[a.options.scope]||[],e=b?b.type:null,g=(a.currentItem||a.element).find(":data(droppable)").andSelf(),f=0;a:for(;f<c.length;f++)if(!(c[f].options.disabled||a&&!c[f].accept.call(c[f].element[0],a.currentItem||a.element))){for(var h=0;h<g.length;h++)if(g[h]==c[f].element[0]){c[f].proportions.height=0;continue a}c[f].visible=c[f].element.css("display")!=
-"none";if(c[f].visible){e=="mousedown"&&c[f]._activate.call(c[f],b);c[f].offset=c[f].element.offset();c[f].proportions={width:c[f].element[0].offsetWidth,height:c[f].element[0].offsetHeight}}}},drop:function(a,b){var c=false;d.each(d.ui.ddmanager.droppables[a.options.scope]||[],function(){if(this.options){if(!this.options.disabled&&this.visible&&d.ui.intersect(a,this,this.options.tolerance))c=c||this._drop.call(this,b);if(!this.options.disabled&&this.visible&&this.accept.call(this.element[0],a.currentItem||
-a.element)){this.isout=1;this.isover=0;this._deactivate.call(this,b)}}});return c},drag:function(a,b){a.options.refreshPositions&&d.ui.ddmanager.prepareOffsets(a,b);d.each(d.ui.ddmanager.droppables[a.options.scope]||[],function(){if(!(this.options.disabled||this.greedyChild||!this.visible)){var c=d.ui.intersect(a,this,this.options.tolerance);if(c=!c&&this.isover==1?"isout":c&&this.isover==0?"isover":null){var e;if(this.options.greedy){var g=this.element.parents(":data(droppable):eq(0)");if(g.length){e=
-d.data(g[0],"droppable");e.greedyChild=c=="isover"?1:0}}if(e&&c=="isover"){e.isover=0;e.isout=1;e._out.call(e,b)}this[c]=1;this[c=="isout"?"isover":"isout"]=0;this[c=="isover"?"_over":"_out"].call(this,b);if(e&&c=="isout"){e.isout=0;e.isover=1;e._over.call(e,b)}}}})}}})(jQuery);
-;/*
- * jQuery UI Resizable 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Resizables
- *
- * Depends:
- *	jquery.ui.core.js
- *	jquery.ui.mouse.js
- *	jquery.ui.widget.js
- */
-(function(e){e.widget("ui.resizable",e.ui.mouse,{widgetEventPrefix:"resize",options:{alsoResize:false,animate:false,animateDuration:"slow",animateEasing:"swing",aspectRatio:false,autoHide:false,containment:false,ghost:false,grid:false,handles:"e,s,se",helper:false,maxHeight:null,maxWidth:null,minHeight:10,minWidth:10,zIndex:1E3},_create:function(){var b=this,a=this.options;this.element.addClass("ui-resizable");e.extend(this,{_aspectRatio:!!a.aspectRatio,aspectRatio:a.aspectRatio,originalElement:this.element,
-_proportionallyResizeElements:[],_helper:a.helper||a.ghost||a.animate?a.helper||"ui-resizable-helper":null});if(this.element[0].nodeName.match(/canvas|textarea|input|select|button|img/i)){/relative/.test(this.element.css("position"))&&e.browser.opera&&this.element.css({position:"relative",top:"auto",left:"auto"});this.element.wrap(e('<div class="ui-wrapper" style="overflow: hidden;"></div>').css({position:this.element.css("position"),width:this.element.outerWidth(),height:this.element.outerHeight(),
-top:this.element.css("top"),left:this.element.css("left")}));this.element=this.element.parent().data("resizable",this.element.data("resizable"));this.elementIsWrapper=true;this.element.css({marginLeft:this.originalElement.css("marginLeft"),marginTop:this.originalElement.css("marginTop"),marginRight:this.originalElement.css("marginRight"),marginBottom:this.originalElement.css("marginBottom")});this.originalElement.css({marginLeft:0,marginTop:0,marginRight:0,marginBottom:0});this.originalResizeStyle=
-this.originalElement.css("resize");this.originalElement.css("resize","none");this._proportionallyResizeElements.push(this.originalElement.css({position:"static",zoom:1,display:"block"}));this.originalElement.css({margin:this.originalElement.css("margin")});this._proportionallyResize()}this.handles=a.handles||(!e(".ui-resizable-handle",this.element).length?"e,s,se":{n:".ui-resizable-n",e:".ui-resizable-e",s:".ui-resizable-s",w:".ui-resizable-w",se:".ui-resizable-se",sw:".ui-resizable-sw",ne:".ui-resizable-ne",
-nw:".ui-resizable-nw"});if(this.handles.constructor==String){if(this.handles=="all")this.handles="n,e,s,w,se,sw,ne,nw";var c=this.handles.split(",");this.handles={};for(var d=0;d<c.length;d++){var f=e.trim(c[d]),g=e('<div class="ui-resizable-handle '+("ui-resizable-"+f)+'"></div>');/sw|se|ne|nw/.test(f)&&g.css({zIndex:++a.zIndex});"se"==f&&g.addClass("ui-icon ui-icon-gripsmall-diagonal-se");this.handles[f]=".ui-resizable-"+f;this.element.append(g)}}this._renderAxis=function(h){h=h||this.element;for(var i in this.handles){if(this.handles[i].constructor==
-String)this.handles[i]=e(this.handles[i],this.element).show();if(this.elementIsWrapper&&this.originalElement[0].nodeName.match(/textarea|input|select|button/i)){var j=e(this.handles[i],this.element),k=0;k=/sw|ne|nw|se|n|s/.test(i)?j.outerHeight():j.outerWidth();j=["padding",/ne|nw|n/.test(i)?"Top":/se|sw|s/.test(i)?"Bottom":/^e$/.test(i)?"Right":"Left"].join("");h.css(j,k);this._proportionallyResize()}e(this.handles[i])}};this._renderAxis(this.element);this._handles=e(".ui-resizable-handle",this.element).disableSelection();
-this._handles.mouseover(function(){if(!b.resizing){if(this.className)var h=this.className.match(/ui-resizable-(se|sw|ne|nw|n|e|s|w)/i);b.axis=h&&h[1]?h[1]:"se"}});if(a.autoHide){this._handles.hide();e(this.element).addClass("ui-resizable-autohide").hover(function(){e(this).removeClass("ui-resizable-autohide");b._handles.show()},function(){if(!b.resizing){e(this).addClass("ui-resizable-autohide");b._handles.hide()}})}this._mouseInit()},destroy:function(){this._mouseDestroy();var b=function(c){e(c).removeClass("ui-resizable ui-resizable-disabled ui-resizable-resizing").removeData("resizable").unbind(".resizable").find(".ui-resizable-handle").remove()};
-if(this.elementIsWrapper){b(this.element);var a=this.element;a.after(this.originalElement.css({position:a.css("position"),width:a.outerWidth(),height:a.outerHeight(),top:a.css("top"),left:a.css("left")})).remove()}this.originalElement.css("resize",this.originalResizeStyle);b(this.originalElement);return this},_mouseCapture:function(b){var a=false;for(var c in this.handles)if(e(this.handles[c])[0]==b.target)a=true;return!this.options.disabled&&a},_mouseStart:function(b){var a=this.options,c=this.element.position(),
-d=this.element;this.resizing=true;this.documentScroll={top:e(document).scrollTop(),left:e(document).scrollLeft()};if(d.is(".ui-draggable")||/absolute/.test(d.css("position")))d.css({position:"absolute",top:c.top,left:c.left});e.browser.opera&&/relative/.test(d.css("position"))&&d.css({position:"relative",top:"auto",left:"auto"});this._renderProxy();c=m(this.helper.css("left"));var f=m(this.helper.css("top"));if(a.containment){c+=e(a.containment).scrollLeft()||0;f+=e(a.containment).scrollTop()||0}this.offset=
-this.helper.offset();this.position={left:c,top:f};this.size=this._helper?{width:d.outerWidth(),height:d.outerHeight()}:{width:d.width(),height:d.height()};this.originalSize=this._helper?{width:d.outerWidth(),height:d.outerHeight()}:{width:d.width(),height:d.height()};this.originalPosition={left:c,top:f};this.sizeDiff={width:d.outerWidth()-d.width(),height:d.outerHeight()-d.height()};this.originalMousePosition={left:b.pageX,top:b.pageY};this.aspectRatio=typeof a.aspectRatio=="number"?a.aspectRatio:
-this.originalSize.width/this.originalSize.height||1;a=e(".ui-resizable-"+this.axis).css("cursor");e("body").css("cursor",a=="auto"?this.axis+"-resize":a);d.addClass("ui-resizable-resizing");this._propagate("start",b);return true},_mouseDrag:function(b){var a=this.helper,c=this.originalMousePosition,d=this._change[this.axis];if(!d)return false;c=d.apply(this,[b,b.pageX-c.left||0,b.pageY-c.top||0]);if(this._aspectRatio||b.shiftKey)c=this._updateRatio(c,b);c=this._respectSize(c,b);this._propagate("resize",
-b);a.css({top:this.position.top+"px",left:this.position.left+"px",width:this.size.width+"px",height:this.size.height+"px"});!this._helper&&this._proportionallyResizeElements.length&&this._proportionallyResize();this._updateCache(c);this._trigger("resize",b,this.ui());return false},_mouseStop:function(b){this.resizing=false;var a=this.options,c=this;if(this._helper){var d=this._proportionallyResizeElements,f=d.length&&/textarea/i.test(d[0].nodeName);d=f&&e.ui.hasScroll(d[0],"left")?0:c.sizeDiff.height;
-f=f?0:c.sizeDiff.width;f={width:c.helper.width()-f,height:c.helper.height()-d};d=parseInt(c.element.css("left"),10)+(c.position.left-c.originalPosition.left)||null;var g=parseInt(c.element.css("top"),10)+(c.position.top-c.originalPosition.top)||null;a.animate||this.element.css(e.extend(f,{top:g,left:d}));c.helper.height(c.size.height);c.helper.width(c.size.width);this._helper&&!a.animate&&this._proportionallyResize()}e("body").css("cursor","auto");this.element.removeClass("ui-resizable-resizing");
-this._propagate("stop",b);this._helper&&this.helper.remove();return false},_updateCache:function(b){this.offset=this.helper.offset();if(l(b.left))this.position.left=b.left;if(l(b.top))this.position.top=b.top;if(l(b.height))this.size.height=b.height;if(l(b.width))this.size.width=b.width},_updateRatio:function(b){var a=this.position,c=this.size,d=this.axis;if(b.height)b.width=c.height*this.aspectRatio;else if(b.width)b.height=c.width/this.aspectRatio;if(d=="sw"){b.left=a.left+(c.width-b.width);b.top=
-null}if(d=="nw"){b.top=a.top+(c.height-b.height);b.left=a.left+(c.width-b.width)}return b},_respectSize:function(b){var a=this.options,c=this.axis,d=l(b.width)&&a.maxWidth&&a.maxWidth<b.width,f=l(b.height)&&a.maxHeight&&a.maxHeight<b.height,g=l(b.width)&&a.minWidth&&a.minWidth>b.width,h=l(b.height)&&a.minHeight&&a.minHeight>b.height;if(g)b.width=a.minWidth;if(h)b.height=a.minHeight;if(d)b.width=a.maxWidth;if(f)b.height=a.maxHeight;var i=this.originalPosition.left+this.originalSize.width,j=this.position.top+
-this.size.height,k=/sw|nw|w/.test(c);c=/nw|ne|n/.test(c);if(g&&k)b.left=i-a.minWidth;if(d&&k)b.left=i-a.maxWidth;if(h&&c)b.top=j-a.minHeight;if(f&&c)b.top=j-a.maxHeight;if((a=!b.width&&!b.height)&&!b.left&&b.top)b.top=null;else if(a&&!b.top&&b.left)b.left=null;return b},_proportionallyResize:function(){if(this._proportionallyResizeElements.length)for(var b=this.helper||this.element,a=0;a<this._proportionallyResizeElements.length;a++){var c=this._proportionallyResizeElements[a];if(!this.borderDif){var d=
-[c.css("borderTopWidth"),c.css("borderRightWidth"),c.css("borderBottomWidth"),c.css("borderLeftWidth")],f=[c.css("paddingTop"),c.css("paddingRight"),c.css("paddingBottom"),c.css("paddingLeft")];this.borderDif=e.map(d,function(g,h){g=parseInt(g,10)||0;h=parseInt(f[h],10)||0;return g+h})}e.browser.msie&&(e(b).is(":hidden")||e(b).parents(":hidden").length)||c.css({height:b.height()-this.borderDif[0]-this.borderDif[2]||0,width:b.width()-this.borderDif[1]-this.borderDif[3]||0})}},_renderProxy:function(){var b=
-this.options;this.elementOffset=this.element.offset();if(this._helper){this.helper=this.helper||e('<div style="overflow:hidden;"></div>');var a=e.browser.msie&&e.browser.version<7,c=a?1:0;a=a?2:-1;this.helper.addClass(this._helper).css({width:this.element.outerWidth()+a,height:this.element.outerHeight()+a,position:"absolute",left:this.elementOffset.left-c+"px",top:this.elementOffset.top-c+"px",zIndex:++b.zIndex});this.helper.appendTo("body").disableSelection()}else this.helper=this.element},_change:{e:function(b,
-a){return{width:this.originalSize.width+a}},w:function(b,a){return{left:this.originalPosition.left+a,width:this.originalSize.width-a}},n:function(b,a,c){return{top:this.originalPosition.top+c,height:this.originalSize.height-c}},s:function(b,a,c){return{height:this.originalSize.height+c}},se:function(b,a,c){return e.extend(this._change.s.apply(this,arguments),this._change.e.apply(this,[b,a,c]))},sw:function(b,a,c){return e.extend(this._change.s.apply(this,arguments),this._change.w.apply(this,[b,a,
-c]))},ne:function(b,a,c){return e.extend(this._change.n.apply(this,arguments),this._change.e.apply(this,[b,a,c]))},nw:function(b,a,c){return e.extend(this._change.n.apply(this,arguments),this._change.w.apply(this,[b,a,c]))}},_propagate:function(b,a){e.ui.plugin.call(this,b,[a,this.ui()]);b!="resize"&&this._trigger(b,a,this.ui())},plugins:{},ui:function(){return{originalElement:this.originalElement,element:this.element,helper:this.helper,position:this.position,size:this.size,originalSize:this.originalSize,
-originalPosition:this.originalPosition}}});e.extend(e.ui.resizable,{version:"1.8.11"});e.ui.plugin.add("resizable","alsoResize",{start:function(){var b=e(this).data("resizable").options,a=function(c){e(c).each(function(){var d=e(this);d.data("resizable-alsoresize",{width:parseInt(d.width(),10),height:parseInt(d.height(),10),left:parseInt(d.css("left"),10),top:parseInt(d.css("top"),10),position:d.css("position")})})};if(typeof b.alsoResize=="object"&&!b.alsoResize.parentNode)if(b.alsoResize.length){b.alsoResize=
-b.alsoResize[0];a(b.alsoResize)}else e.each(b.alsoResize,function(c){a(c)});else a(b.alsoResize)},resize:function(b,a){var c=e(this).data("resizable");b=c.options;var d=c.originalSize,f=c.originalPosition,g={height:c.size.height-d.height||0,width:c.size.width-d.width||0,top:c.position.top-f.top||0,left:c.position.left-f.left||0},h=function(i,j){e(i).each(function(){var k=e(this),q=e(this).data("resizable-alsoresize"),p={},r=j&&j.length?j:k.parents(a.originalElement[0]).length?["width","height"]:["width",
-"height","top","left"];e.each(r,function(n,o){if((n=(q[o]||0)+(g[o]||0))&&n>=0)p[o]=n||null});if(e.browser.opera&&/relative/.test(k.css("position"))){c._revertToRelativePosition=true;k.css({position:"absolute",top:"auto",left:"auto"})}k.css(p)})};typeof b.alsoResize=="object"&&!b.alsoResize.nodeType?e.each(b.alsoResize,function(i,j){h(i,j)}):h(b.alsoResize)},stop:function(){var b=e(this).data("resizable"),a=b.options,c=function(d){e(d).each(function(){var f=e(this);f.css({position:f.data("resizable-alsoresize").position})})};
-if(b._revertToRelativePosition){b._revertToRelativePosition=false;typeof a.alsoResize=="object"&&!a.alsoResize.nodeType?e.each(a.alsoResize,function(d){c(d)}):c(a.alsoResize)}e(this).removeData("resizable-alsoresize")}});e.ui.plugin.add("resizable","animate",{stop:function(b){var a=e(this).data("resizable"),c=a.options,d=a._proportionallyResizeElements,f=d.length&&/textarea/i.test(d[0].nodeName),g=f&&e.ui.hasScroll(d[0],"left")?0:a.sizeDiff.height;f={width:a.size.width-(f?0:a.sizeDiff.width),height:a.size.height-
-g};g=parseInt(a.element.css("left"),10)+(a.position.left-a.originalPosition.left)||null;var h=parseInt(a.element.css("top"),10)+(a.position.top-a.originalPosition.top)||null;a.element.animate(e.extend(f,h&&g?{top:h,left:g}:{}),{duration:c.animateDuration,easing:c.animateEasing,step:function(){var i={width:parseInt(a.element.css("width"),10),height:parseInt(a.element.css("height"),10),top:parseInt(a.element.css("top"),10),left:parseInt(a.element.css("left"),10)};d&&d.length&&e(d[0]).css({width:i.width,
-height:i.height});a._updateCache(i);a._propagate("resize",b)}})}});e.ui.plugin.add("resizable","containment",{start:function(){var b=e(this).data("resizable"),a=b.element,c=b.options.containment;if(a=c instanceof e?c.get(0):/parent/.test(c)?a.parent().get(0):c){b.containerElement=e(a);if(/document/.test(c)||c==document){b.containerOffset={left:0,top:0};b.containerPosition={left:0,top:0};b.parentData={element:e(document),left:0,top:0,width:e(document).width(),height:e(document).height()||document.body.parentNode.scrollHeight}}else{var d=
-e(a),f=[];e(["Top","Right","Left","Bottom"]).each(function(i,j){f[i]=m(d.css("padding"+j))});b.containerOffset=d.offset();b.containerPosition=d.position();b.containerSize={height:d.innerHeight()-f[3],width:d.innerWidth()-f[1]};c=b.containerOffset;var g=b.containerSize.height,h=b.containerSize.width;h=e.ui.hasScroll(a,"left")?a.scrollWidth:h;g=e.ui.hasScroll(a)?a.scrollHeight:g;b.parentData={element:a,left:c.left,top:c.top,width:h,height:g}}}},resize:function(b){var a=e(this).data("resizable"),c=a.options,
-d=a.containerOffset,f=a.position;b=a._aspectRatio||b.shiftKey;var g={top:0,left:0},h=a.containerElement;if(h[0]!=document&&/static/.test(h.css("position")))g=d;if(f.left<(a._helper?d.left:0)){a.size.width+=a._helper?a.position.left-d.left:a.position.left-g.left;if(b)a.size.height=a.size.width/c.aspectRatio;a.position.left=c.helper?d.left:0}if(f.top<(a._helper?d.top:0)){a.size.height+=a._helper?a.position.top-d.top:a.position.top;if(b)a.size.width=a.size.height*c.aspectRatio;a.position.top=a._helper?
-d.top:0}a.offset.left=a.parentData.left+a.position.left;a.offset.top=a.parentData.top+a.position.top;c=Math.abs((a._helper?a.offset.left-g.left:a.offset.left-g.left)+a.sizeDiff.width);d=Math.abs((a._helper?a.offset.top-g.top:a.offset.top-d.top)+a.sizeDiff.height);f=a.containerElement.get(0)==a.element.parent().get(0);g=/relative|absolute/.test(a.containerElement.css("position"));if(f&&g)c-=a.parentData.left;if(c+a.size.width>=a.parentData.width){a.size.width=a.parentData.width-c;if(b)a.size.height=
-a.size.width/a.aspectRatio}if(d+a.size.height>=a.parentData.height){a.size.height=a.parentData.height-d;if(b)a.size.width=a.size.height*a.aspectRatio}},stop:function(){var b=e(this).data("resizable"),a=b.options,c=b.containerOffset,d=b.containerPosition,f=b.containerElement,g=e(b.helper),h=g.offset(),i=g.outerWidth()-b.sizeDiff.width;g=g.outerHeight()-b.sizeDiff.height;b._helper&&!a.animate&&/relative/.test(f.css("position"))&&e(this).css({left:h.left-d.left-c.left,width:i,height:g});b._helper&&!a.animate&&
-/static/.test(f.css("position"))&&e(this).css({left:h.left-d.left-c.left,width:i,height:g})}});e.ui.plugin.add("resizable","ghost",{start:function(){var b=e(this).data("resizable"),a=b.options,c=b.size;b.ghost=b.originalElement.clone();b.ghost.css({opacity:0.25,display:"block",position:"relative",height:c.height,width:c.width,margin:0,left:0,top:0}).addClass("ui-resizable-ghost").addClass(typeof a.ghost=="string"?a.ghost:"");b.ghost.appendTo(b.helper)},resize:function(){var b=e(this).data("resizable");
-b.ghost&&b.ghost.css({position:"relative",height:b.size.height,width:b.size.width})},stop:function(){var b=e(this).data("resizable");b.ghost&&b.helper&&b.helper.get(0).removeChild(b.ghost.get(0))}});e.ui.plugin.add("resizable","grid",{resize:function(){var b=e(this).data("resizable"),a=b.options,c=b.size,d=b.originalSize,f=b.originalPosition,g=b.axis;a.grid=typeof a.grid=="number"?[a.grid,a.grid]:a.grid;var h=Math.round((c.width-d.width)/(a.grid[0]||1))*(a.grid[0]||1);a=Math.round((c.height-d.height)/
-(a.grid[1]||1))*(a.grid[1]||1);if(/^(se|s|e)$/.test(g)){b.size.width=d.width+h;b.size.height=d.height+a}else if(/^(ne)$/.test(g)){b.size.width=d.width+h;b.size.height=d.height+a;b.position.top=f.top-a}else{if(/^(sw)$/.test(g)){b.size.width=d.width+h;b.size.height=d.height+a}else{b.size.width=d.width+h;b.size.height=d.height+a;b.position.top=f.top-a}b.position.left=f.left-h}}});var m=function(b){return parseInt(b,10)||0},l=function(b){return!isNaN(parseInt(b,10))}})(jQuery);
-;/*
- * jQuery UI Selectable 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Selectables
- *
- * Depends:
- *	jquery.ui.core.js
- *	jquery.ui.mouse.js
- *	jquery.ui.widget.js
- */
-(function(e){e.widget("ui.selectable",e.ui.mouse,{options:{appendTo:"body",autoRefresh:true,distance:0,filter:"*",tolerance:"touch"},_create:function(){var c=this;this.element.addClass("ui-selectable");this.dragged=false;var f;this.refresh=function(){f=e(c.options.filter,c.element[0]);f.each(function(){var d=e(this),b=d.offset();e.data(this,"selectable-item",{element:this,$element:d,left:b.left,top:b.top,right:b.left+d.outerWidth(),bottom:b.top+d.outerHeight(),startselected:false,selected:d.hasClass("ui-selected"),
-selecting:d.hasClass("ui-selecting"),unselecting:d.hasClass("ui-unselecting")})})};this.refresh();this.selectees=f.addClass("ui-selectee");this._mouseInit();this.helper=e("<div class='ui-selectable-helper'></div>")},destroy:function(){this.selectees.removeClass("ui-selectee").removeData("selectable-item");this.element.removeClass("ui-selectable ui-selectable-disabled").removeData("selectable").unbind(".selectable");this._mouseDestroy();return this},_mouseStart:function(c){var f=this;this.opos=[c.pageX,
-c.pageY];if(!this.options.disabled){var d=this.options;this.selectees=e(d.filter,this.element[0]);this._trigger("start",c);e(d.appendTo).append(this.helper);this.helper.css({left:c.clientX,top:c.clientY,width:0,height:0});d.autoRefresh&&this.refresh();this.selectees.filter(".ui-selected").each(function(){var b=e.data(this,"selectable-item");b.startselected=true;if(!c.metaKey){b.$element.removeClass("ui-selected");b.selected=false;b.$element.addClass("ui-unselecting");b.unselecting=true;f._trigger("unselecting",
-c,{unselecting:b.element})}});e(c.target).parents().andSelf().each(function(){var b=e.data(this,"selectable-item");if(b){var g=!c.metaKey||!b.$element.hasClass("ui-selected");b.$element.removeClass(g?"ui-unselecting":"ui-selected").addClass(g?"ui-selecting":"ui-unselecting");b.unselecting=!g;b.selecting=g;(b.selected=g)?f._trigger("selecting",c,{selecting:b.element}):f._trigger("unselecting",c,{unselecting:b.element});return false}})}},_mouseDrag:function(c){var f=this;this.dragged=true;if(!this.options.disabled){var d=
-this.options,b=this.opos[0],g=this.opos[1],h=c.pageX,i=c.pageY;if(b>h){var j=h;h=b;b=j}if(g>i){j=i;i=g;g=j}this.helper.css({left:b,top:g,width:h-b,height:i-g});this.selectees.each(function(){var a=e.data(this,"selectable-item");if(!(!a||a.element==f.element[0])){var k=false;if(d.tolerance=="touch")k=!(a.left>h||a.right<b||a.top>i||a.bottom<g);else if(d.tolerance=="fit")k=a.left>b&&a.right<h&&a.top>g&&a.bottom<i;if(k){if(a.selected){a.$element.removeClass("ui-selected");a.selected=false}if(a.unselecting){a.$element.removeClass("ui-unselecting");
-a.unselecting=false}if(!a.selecting){a.$element.addClass("ui-selecting");a.selecting=true;f._trigger("selecting",c,{selecting:a.element})}}else{if(a.selecting)if(c.metaKey&&a.startselected){a.$element.removeClass("ui-selecting");a.selecting=false;a.$element.addClass("ui-selected");a.selected=true}else{a.$element.removeClass("ui-selecting");a.selecting=false;if(a.startselected){a.$element.addClass("ui-unselecting");a.unselecting=true}f._trigger("unselecting",c,{unselecting:a.element})}if(a.selected)if(!c.metaKey&&
-!a.startselected){a.$element.removeClass("ui-selected");a.selected=false;a.$element.addClass("ui-unselecting");a.unselecting=true;f._trigger("unselecting",c,{unselecting:a.element})}}}});return false}},_mouseStop:function(c){var f=this;this.dragged=false;e(".ui-unselecting",this.element[0]).each(function(){var d=e.data(this,"selectable-item");d.$element.removeClass("ui-unselecting");d.unselecting=false;d.startselected=false;f._trigger("unselected",c,{unselected:d.element})});e(".ui-selecting",this.element[0]).each(function(){var d=
-e.data(this,"selectable-item");d.$element.removeClass("ui-selecting").addClass("ui-selected");d.selecting=false;d.selected=true;d.startselected=true;f._trigger("selected",c,{selected:d.element})});this._trigger("stop",c);this.helper.remove();return false}});e.extend(e.ui.selectable,{version:"1.8.11"})})(jQuery);
-;/*
- * jQuery UI Sortable 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Sortables
- *
- * Depends:
- *	jquery.ui.core.js
- *	jquery.ui.mouse.js
- *	jquery.ui.widget.js
- */
-(function(d){d.widget("ui.sortable",d.ui.mouse,{widgetEventPrefix:"sort",options:{appendTo:"parent",axis:false,connectWith:false,containment:false,cursor:"auto",cursorAt:false,dropOnEmpty:true,forcePlaceholderSize:false,forceHelperSize:false,grid:false,handle:false,helper:"original",items:"> *",opacity:false,placeholder:false,revert:false,scroll:true,scrollSensitivity:20,scrollSpeed:20,scope:"default",tolerance:"intersect",zIndex:1E3},_create:function(){this.containerCache={};this.element.addClass("ui-sortable");
-this.refresh();this.floating=this.items.length?/left|right/.test(this.items[0].item.css("float"))||/inline|table-cell/.test(this.items[0].item.css("display")):false;this.offset=this.element.offset();this._mouseInit()},destroy:function(){this.element.removeClass("ui-sortable ui-sortable-disabled").removeData("sortable").unbind(".sortable");this._mouseDestroy();for(var a=this.items.length-1;a>=0;a--)this.items[a].item.removeData("sortable-item");return this},_setOption:function(a,b){if(a==="disabled"){this.options[a]=
-b;this.widget()[b?"addClass":"removeClass"]("ui-sortable-disabled")}else d.Widget.prototype._setOption.apply(this,arguments)},_mouseCapture:function(a,b){if(this.reverting)return false;if(this.options.disabled||this.options.type=="static")return false;this._refreshItems(a);var c=null,e=this;d(a.target).parents().each(function(){if(d.data(this,"sortable-item")==e){c=d(this);return false}});if(d.data(a.target,"sortable-item")==e)c=d(a.target);if(!c)return false;if(this.options.handle&&!b){var f=false;
-d(this.options.handle,c).find("*").andSelf().each(function(){if(this==a.target)f=true});if(!f)return false}this.currentItem=c;this._removeCurrentsFromItems();return true},_mouseStart:function(a,b,c){b=this.options;var e=this;this.currentContainer=this;this.refreshPositions();this.helper=this._createHelper(a);this._cacheHelperProportions();this._cacheMargins();this.scrollParent=this.helper.scrollParent();this.offset=this.currentItem.offset();this.offset={top:this.offset.top-this.margins.top,left:this.offset.left-
-this.margins.left};this.helper.css("position","absolute");this.cssPosition=this.helper.css("position");d.extend(this.offset,{click:{left:a.pageX-this.offset.left,top:a.pageY-this.offset.top},parent:this._getParentOffset(),relative:this._getRelativeOffset()});this.originalPosition=this._generatePosition(a);this.originalPageX=a.pageX;this.originalPageY=a.pageY;b.cursorAt&&this._adjustOffsetFromHelper(b.cursorAt);this.domPosition={prev:this.currentItem.prev()[0],parent:this.currentItem.parent()[0]};
-this.helper[0]!=this.currentItem[0]&&this.currentItem.hide();this._createPlaceholder();b.containment&&this._setContainment();if(b.cursor){if(d("body").css("cursor"))this._storedCursor=d("body").css("cursor");d("body").css("cursor",b.cursor)}if(b.opacity){if(this.helper.css("opacity"))this._storedOpacity=this.helper.css("opacity");this.helper.css("opacity",b.opacity)}if(b.zIndex){if(this.helper.css("zIndex"))this._storedZIndex=this.helper.css("zIndex");this.helper.css("zIndex",b.zIndex)}if(this.scrollParent[0]!=
-document&&this.scrollParent[0].tagName!="HTML")this.overflowOffset=this.scrollParent.offset();this._trigger("start",a,this._uiHash());this._preserveHelperProportions||this._cacheHelperProportions();if(!c)for(c=this.containers.length-1;c>=0;c--)this.containers[c]._trigger("activate",a,e._uiHash(this));if(d.ui.ddmanager)d.ui.ddmanager.current=this;d.ui.ddmanager&&!b.dropBehaviour&&d.ui.ddmanager.prepareOffsets(this,a);this.dragging=true;this.helper.addClass("ui-sortable-helper");this._mouseDrag(a);
-return true},_mouseDrag:function(a){this.position=this._generatePosition(a);this.positionAbs=this._convertPositionTo("absolute");if(!this.lastPositionAbs)this.lastPositionAbs=this.positionAbs;if(this.options.scroll){var b=this.options,c=false;if(this.scrollParent[0]!=document&&this.scrollParent[0].tagName!="HTML"){if(this.overflowOffset.top+this.scrollParent[0].offsetHeight-a.pageY<b.scrollSensitivity)this.scrollParent[0].scrollTop=c=this.scrollParent[0].scrollTop+b.scrollSpeed;else if(a.pageY-this.overflowOffset.top<
-b.scrollSensitivity)this.scrollParent[0].scrollTop=c=this.scrollParent[0].scrollTop-b.scrollSpeed;if(this.overflowOffset.left+this.scrollParent[0].offsetWidth-a.pageX<b.scrollSensitivity)this.scrollParent[0].scrollLeft=c=this.scrollParent[0].scrollLeft+b.scrollSpeed;else if(a.pageX-this.overflowOffset.left<b.scrollSensitivity)this.scrollParent[0].scrollLeft=c=this.scrollParent[0].scrollLeft-b.scrollSpeed}else{if(a.pageY-d(document).scrollTop()<b.scrollSensitivity)c=d(document).scrollTop(d(document).scrollTop()-
-b.scrollSpeed);else if(d(window).height()-(a.pageY-d(document).scrollTop())<b.scrollSensitivity)c=d(document).scrollTop(d(document).scrollTop()+b.scrollSpeed);if(a.pageX-d(document).scrollLeft()<b.scrollSensitivity)c=d(document).scrollLeft(d(document).scrollLeft()-b.scrollSpeed);else if(d(window).width()-(a.pageX-d(document).scrollLeft())<b.scrollSensitivity)c=d(document).scrollLeft(d(document).scrollLeft()+b.scrollSpeed)}c!==false&&d.ui.ddmanager&&!b.dropBehaviour&&d.ui.ddmanager.prepareOffsets(this,
-a)}this.positionAbs=this._convertPositionTo("absolute");if(!this.options.axis||this.options.axis!="y")this.helper[0].style.left=this.position.left+"px";if(!this.options.axis||this.options.axis!="x")this.helper[0].style.top=this.position.top+"px";for(b=this.items.length-1;b>=0;b--){c=this.items[b];var e=c.item[0],f=this._intersectsWithPointer(c);if(f)if(e!=this.currentItem[0]&&this.placeholder[f==1?"next":"prev"]()[0]!=e&&!d.ui.contains(this.placeholder[0],e)&&(this.options.type=="semi-dynamic"?!d.ui.contains(this.element[0],
-e):true)){this.direction=f==1?"down":"up";if(this.options.tolerance=="pointer"||this._intersectsWithSides(c))this._rearrange(a,c);else break;this._trigger("change",a,this._uiHash());break}}this._contactContainers(a);d.ui.ddmanager&&d.ui.ddmanager.drag(this,a);this._trigger("sort",a,this._uiHash());this.lastPositionAbs=this.positionAbs;return false},_mouseStop:function(a,b){if(a){d.ui.ddmanager&&!this.options.dropBehaviour&&d.ui.ddmanager.drop(this,a);if(this.options.revert){var c=this;b=c.placeholder.offset();
-c.reverting=true;d(this.helper).animate({left:b.left-this.offset.parent.left-c.margins.left+(this.offsetParent[0]==document.body?0:this.offsetParent[0].scrollLeft),top:b.top-this.offset.parent.top-c.margins.top+(this.offsetParent[0]==document.body?0:this.offsetParent[0].scrollTop)},parseInt(this.options.revert,10)||500,function(){c._clear(a)})}else this._clear(a,b);return false}},cancel:function(){var a=this;if(this.dragging){this._mouseUp({target:null});this.options.helper=="original"?this.currentItem.css(this._storedCSS).removeClass("ui-sortable-helper"):
-this.currentItem.show();for(var b=this.containers.length-1;b>=0;b--){this.containers[b]._trigger("deactivate",null,a._uiHash(this));if(this.containers[b].containerCache.over){this.containers[b]._trigger("out",null,a._uiHash(this));this.containers[b].containerCache.over=0}}}if(this.placeholder){this.placeholder[0].parentNode&&this.placeholder[0].parentNode.removeChild(this.placeholder[0]);this.options.helper!="original"&&this.helper&&this.helper[0].parentNode&&this.helper.remove();d.extend(this,{helper:null,
-dragging:false,reverting:false,_noFinalSort:null});this.domPosition.prev?d(this.domPosition.prev).after(this.currentItem):d(this.domPosition.parent).prepend(this.currentItem)}return this},serialize:function(a){var b=this._getItemsAsjQuery(a&&a.connected),c=[];a=a||{};d(b).each(function(){var e=(d(a.item||this).attr(a.attribute||"id")||"").match(a.expression||/(.+)[-=_](.+)/);if(e)c.push((a.key||e[1]+"[]")+"="+(a.key&&a.expression?e[1]:e[2]))});!c.length&&a.key&&c.push(a.key+"=");return c.join("&")},
-toArray:function(a){var b=this._getItemsAsjQuery(a&&a.connected),c=[];a=a||{};b.each(function(){c.push(d(a.item||this).attr(a.attribute||"id")||"")});return c},_intersectsWith:function(a){var b=this.positionAbs.left,c=b+this.helperProportions.width,e=this.positionAbs.top,f=e+this.helperProportions.height,g=a.left,h=g+a.width,i=a.top,k=i+a.height,j=this.offset.click.top,l=this.offset.click.left;j=e+j>i&&e+j<k&&b+l>g&&b+l<h;return this.options.tolerance=="pointer"||this.options.forcePointerForContainers||
-this.options.tolerance!="pointer"&&this.helperProportions[this.floating?"width":"height"]>a[this.floating?"width":"height"]?j:g<b+this.helperProportions.width/2&&c-this.helperProportions.width/2<h&&i<e+this.helperProportions.height/2&&f-this.helperProportions.height/2<k},_intersectsWithPointer:function(a){var b=d.ui.isOverAxis(this.positionAbs.top+this.offset.click.top,a.top,a.height);a=d.ui.isOverAxis(this.positionAbs.left+this.offset.click.left,a.left,a.width);b=b&&a;a=this._getDragVerticalDirection();
-var c=this._getDragHorizontalDirection();if(!b)return false;return this.floating?c&&c=="right"||a=="down"?2:1:a&&(a=="down"?2:1)},_intersectsWithSides:function(a){var b=d.ui.isOverAxis(this.positionAbs.top+this.offset.click.top,a.top+a.height/2,a.height);a=d.ui.isOverAxis(this.positionAbs.left+this.offset.click.left,a.left+a.width/2,a.width);var c=this._getDragVerticalDirection(),e=this._getDragHorizontalDirection();return this.floating&&e?e=="right"&&a||e=="left"&&!a:c&&(c=="down"&&b||c=="up"&&!b)},
-_getDragVerticalDirection:function(){var a=this.positionAbs.top-this.lastPositionAbs.top;return a!=0&&(a>0?"down":"up")},_getDragHorizontalDirection:function(){var a=this.positionAbs.left-this.lastPositionAbs.left;return a!=0&&(a>0?"right":"left")},refresh:function(a){this._refreshItems(a);this.refreshPositions();return this},_connectWith:function(){var a=this.options;return a.connectWith.constructor==String?[a.connectWith]:a.connectWith},_getItemsAsjQuery:function(a){var b=[],c=[],e=this._connectWith();
-if(e&&a)for(a=e.length-1;a>=0;a--)for(var f=d(e[a]),g=f.length-1;g>=0;g--){var h=d.data(f[g],"sortable");if(h&&h!=this&&!h.options.disabled)c.push([d.isFunction(h.options.items)?h.options.items.call(h.element):d(h.options.items,h.element).not(".ui-sortable-helper").not(".ui-sortable-placeholder"),h])}c.push([d.isFunction(this.options.items)?this.options.items.call(this.element,null,{options:this.options,item:this.currentItem}):d(this.options.items,this.element).not(".ui-sortable-helper").not(".ui-sortable-placeholder"),
-this]);for(a=c.length-1;a>=0;a--)c[a][0].each(function(){b.push(this)});return d(b)},_removeCurrentsFromItems:function(){for(var a=this.currentItem.find(":data(sortable-item)"),b=0;b<this.items.length;b++)for(var c=0;c<a.length;c++)a[c]==this.items[b].item[0]&&this.items.splice(b,1)},_refreshItems:function(a){this.items=[];this.containers=[this];var b=this.items,c=[[d.isFunction(this.options.items)?this.options.items.call(this.element[0],a,{item:this.currentItem}):d(this.options.items,this.element),
-this]],e=this._connectWith();if(e)for(var f=e.length-1;f>=0;f--)for(var g=d(e[f]),h=g.length-1;h>=0;h--){var i=d.data(g[h],"sortable");if(i&&i!=this&&!i.options.disabled){c.push([d.isFunction(i.options.items)?i.options.items.call(i.element[0],a,{item:this.currentItem}):d(i.options.items,i.element),i]);this.containers.push(i)}}for(f=c.length-1;f>=0;f--){a=c[f][1];e=c[f][0];h=0;for(g=e.length;h<g;h++){i=d(e[h]);i.data("sortable-item",a);b.push({item:i,instance:a,width:0,height:0,left:0,top:0})}}},refreshPositions:function(a){if(this.offsetParent&&
-this.helper)this.offset.parent=this._getParentOffset();for(var b=this.items.length-1;b>=0;b--){var c=this.items[b],e=this.options.toleranceElement?d(this.options.toleranceElement,c.item):c.item;if(!a){c.width=e.outerWidth();c.height=e.outerHeight()}e=e.offset();c.left=e.left;c.top=e.top}if(this.options.custom&&this.options.custom.refreshContainers)this.options.custom.refreshContainers.call(this);else for(b=this.containers.length-1;b>=0;b--){e=this.containers[b].element.offset();this.containers[b].containerCache.left=
-e.left;this.containers[b].containerCache.top=e.top;this.containers[b].containerCache.width=this.containers[b].element.outerWidth();this.containers[b].containerCache.height=this.containers[b].element.outerHeight()}return this},_createPlaceholder:function(a){var b=a||this,c=b.options;if(!c.placeholder||c.placeholder.constructor==String){var e=c.placeholder;c.placeholder={element:function(){var f=d(document.createElement(b.currentItem[0].nodeName)).addClass(e||b.currentItem[0].className+" ui-sortable-placeholder").removeClass("ui-sortable-helper")[0];
-if(!e)f.style.visibility="hidden";return f},update:function(f,g){if(!(e&&!c.forcePlaceholderSize)){g.height()||g.height(b.currentItem.innerHeight()-parseInt(b.currentItem.css("paddingTop")||0,10)-parseInt(b.currentItem.css("paddingBottom")||0,10));g.width()||g.width(b.currentItem.innerWidth()-parseInt(b.currentItem.css("paddingLeft")||0,10)-parseInt(b.currentItem.css("paddingRight")||0,10))}}}}b.placeholder=d(c.placeholder.element.call(b.element,b.currentItem));b.currentItem.after(b.placeholder);
-c.placeholder.update(b,b.placeholder)},_contactContainers:function(a){for(var b=null,c=null,e=this.containers.length-1;e>=0;e--)if(!d.ui.contains(this.currentItem[0],this.containers[e].element[0]))if(this._intersectsWith(this.containers[e].containerCache)){if(!(b&&d.ui.contains(this.containers[e].element[0],b.element[0]))){b=this.containers[e];c=e}}else if(this.containers[e].containerCache.over){this.containers[e]._trigger("out",a,this._uiHash(this));this.containers[e].containerCache.over=0}if(b)if(this.containers.length===
-1){this.containers[c]._trigger("over",a,this._uiHash(this));this.containers[c].containerCache.over=1}else if(this.currentContainer!=this.containers[c]){b=1E4;e=null;for(var f=this.positionAbs[this.containers[c].floating?"left":"top"],g=this.items.length-1;g>=0;g--)if(d.ui.contains(this.containers[c].element[0],this.items[g].item[0])){var h=this.items[g][this.containers[c].floating?"left":"top"];if(Math.abs(h-f)<b){b=Math.abs(h-f);e=this.items[g]}}if(e||this.options.dropOnEmpty){this.currentContainer=
-this.containers[c];e?this._rearrange(a,e,null,true):this._rearrange(a,null,this.containers[c].element,true);this._trigger("change",a,this._uiHash());this.containers[c]._trigger("change",a,this._uiHash(this));this.options.placeholder.update(this.currentContainer,this.placeholder);this.containers[c]._trigger("over",a,this._uiHash(this));this.containers[c].containerCache.over=1}}},_createHelper:function(a){var b=this.options;a=d.isFunction(b.helper)?d(b.helper.apply(this.element[0],[a,this.currentItem])):
-b.helper=="clone"?this.currentItem.clone():this.currentItem;a.parents("body").length||d(b.appendTo!="parent"?b.appendTo:this.currentItem[0].parentNode)[0].appendChild(a[0]);if(a[0]==this.currentItem[0])this._storedCSS={width:this.currentItem[0].style.width,height:this.currentItem[0].style.height,position:this.currentItem.css("position"),top:this.currentItem.css("top"),left:this.currentItem.css("left")};if(a[0].style.width==""||b.forceHelperSize)a.width(this.currentItem.width());if(a[0].style.height==
-""||b.forceHelperSize)a.height(this.currentItem.height());return a},_adjustOffsetFromHelper:function(a){if(typeof a=="string")a=a.split(" ");if(d.isArray(a))a={left:+a[0],top:+a[1]||0};if("left"in a)this.offset.click.left=a.left+this.margins.left;if("right"in a)this.offset.click.left=this.helperProportions.width-a.right+this.margins.left;if("top"in a)this.offset.click.top=a.top+this.margins.top;if("bottom"in a)this.offset.click.top=this.helperProportions.height-a.bottom+this.margins.top},_getParentOffset:function(){this.offsetParent=
-this.helper.offsetParent();var a=this.offsetParent.offset();if(this.cssPosition=="absolute"&&this.scrollParent[0]!=document&&d.ui.contains(this.scrollParent[0],this.offsetParent[0])){a.left+=this.scrollParent.scrollLeft();a.top+=this.scrollParent.scrollTop()}if(this.offsetParent[0]==document.body||this.offsetParent[0].tagName&&this.offsetParent[0].tagName.toLowerCase()=="html"&&d.browser.msie)a={top:0,left:0};return{top:a.top+(parseInt(this.offsetParent.css("borderTopWidth"),10)||0),left:a.left+(parseInt(this.offsetParent.css("borderLeftWidth"),
-10)||0)}},_getRelativeOffset:function(){if(this.cssPosition=="relative"){var a=this.currentItem.position();return{top:a.top-(parseInt(this.helper.css("top"),10)||0)+this.scrollParent.scrollTop(),left:a.left-(parseInt(this.helper.css("left"),10)||0)+this.scrollParent.scrollLeft()}}else return{top:0,left:0}},_cacheMargins:function(){this.margins={left:parseInt(this.currentItem.css("marginLeft"),10)||0,top:parseInt(this.currentItem.css("marginTop"),10)||0}},_cacheHelperProportions:function(){this.helperProportions=
-{width:this.helper.outerWidth(),height:this.helper.outerHeight()}},_setContainment:function(){var a=this.options;if(a.containment=="parent")a.containment=this.helper[0].parentNode;if(a.containment=="document"||a.containment=="window")this.containment=[0-this.offset.relative.left-this.offset.parent.left,0-this.offset.relative.top-this.offset.parent.top,d(a.containment=="document"?document:window).width()-this.helperProportions.width-this.margins.left,(d(a.containment=="document"?document:window).height()||
-document.body.parentNode.scrollHeight)-this.helperProportions.height-this.margins.top];if(!/^(document|window|parent)$/.test(a.containment)){var b=d(a.containment)[0];a=d(a.containment).offset();var c=d(b).css("overflow")!="hidden";this.containment=[a.left+(parseInt(d(b).css("borderLeftWidth"),10)||0)+(parseInt(d(b).css("paddingLeft"),10)||0)-this.margins.left,a.top+(parseInt(d(b).css("borderTopWidth"),10)||0)+(parseInt(d(b).css("paddingTop"),10)||0)-this.margins.top,a.left+(c?Math.max(b.scrollWidth,
-b.offsetWidth):b.offsetWidth)-(parseInt(d(b).css("borderLeftWidth"),10)||0)-(parseInt(d(b).css("paddingRight"),10)||0)-this.helperProportions.width-this.margins.left,a.top+(c?Math.max(b.scrollHeight,b.offsetHeight):b.offsetHeight)-(parseInt(d(b).css("borderTopWidth"),10)||0)-(parseInt(d(b).css("paddingBottom"),10)||0)-this.helperProportions.height-this.margins.top]}},_convertPositionTo:function(a,b){if(!b)b=this.position;a=a=="absolute"?1:-1;var c=this.cssPosition=="absolute"&&!(this.scrollParent[0]!=
-document&&d.ui.contains(this.scrollParent[0],this.offsetParent[0]))?this.offsetParent:this.scrollParent,e=/(html|body)/i.test(c[0].tagName);return{top:b.top+this.offset.relative.top*a+this.offset.parent.top*a-(d.browser.safari&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollTop():e?0:c.scrollTop())*a),left:b.left+this.offset.relative.left*a+this.offset.parent.left*a-(d.browser.safari&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollLeft():
-e?0:c.scrollLeft())*a)}},_generatePosition:function(a){var b=this.options,c=this.cssPosition=="absolute"&&!(this.scrollParent[0]!=document&&d.ui.contains(this.scrollParent[0],this.offsetParent[0]))?this.offsetParent:this.scrollParent,e=/(html|body)/i.test(c[0].tagName);if(this.cssPosition=="relative"&&!(this.scrollParent[0]!=document&&this.scrollParent[0]!=this.offsetParent[0]))this.offset.relative=this._getRelativeOffset();var f=a.pageX,g=a.pageY;if(this.originalPosition){if(this.containment){if(a.pageX-
-this.offset.click.left<this.containment[0])f=this.containment[0]+this.offset.click.left;if(a.pageY-this.offset.click.top<this.containment[1])g=this.containment[1]+this.offset.click.top;if(a.pageX-this.offset.click.left>this.containment[2])f=this.containment[2]+this.offset.click.left;if(a.pageY-this.offset.click.top>this.containment[3])g=this.containment[3]+this.offset.click.top}if(b.grid){g=this.originalPageY+Math.round((g-this.originalPageY)/b.grid[1])*b.grid[1];g=this.containment?!(g-this.offset.click.top<
-this.containment[1]||g-this.offset.click.top>this.containment[3])?g:!(g-this.offset.click.top<this.containment[1])?g-b.grid[1]:g+b.grid[1]:g;f=this.originalPageX+Math.round((f-this.originalPageX)/b.grid[0])*b.grid[0];f=this.containment?!(f-this.offset.click.left<this.containment[0]||f-this.offset.click.left>this.containment[2])?f:!(f-this.offset.click.left<this.containment[0])?f-b.grid[0]:f+b.grid[0]:f}}return{top:g-this.offset.click.top-this.offset.relative.top-this.offset.parent.top+(d.browser.safari&&
-this.cssPosition=="fixed"?0:this.cssPosition=="fixed"?-this.scrollParent.scrollTop():e?0:c.scrollTop()),left:f-this.offset.click.left-this.offset.relative.left-this.offset.parent.left+(d.browser.safari&&this.cssPosition=="fixed"?0:this.cssPosition=="fixed"?-this.scrollParent.scrollLeft():e?0:c.scrollLeft())}},_rearrange:function(a,b,c,e){c?c[0].appendChild(this.placeholder[0]):b.item[0].parentNode.insertBefore(this.placeholder[0],this.direction=="down"?b.item[0]:b.item[0].nextSibling);this.counter=
-this.counter?++this.counter:1;var f=this,g=this.counter;window.setTimeout(function(){g==f.counter&&f.refreshPositions(!e)},0)},_clear:function(a,b){this.reverting=false;var c=[];!this._noFinalSort&&this.currentItem[0].parentNode&&this.placeholder.before(this.currentItem);this._noFinalSort=null;if(this.helper[0]==this.currentItem[0]){for(var e in this._storedCSS)if(this._storedCSS[e]=="auto"||this._storedCSS[e]=="static")this._storedCSS[e]="";this.currentItem.css(this._storedCSS).removeClass("ui-sortable-helper")}else this.currentItem.show();
-this.fromOutside&&!b&&c.push(function(f){this._trigger("receive",f,this._uiHash(this.fromOutside))});if((this.fromOutside||this.domPosition.prev!=this.currentItem.prev().not(".ui-sortable-helper")[0]||this.domPosition.parent!=this.currentItem.parent()[0])&&!b)c.push(function(f){this._trigger("update",f,this._uiHash())});if(!d.ui.contains(this.element[0],this.currentItem[0])){b||c.push(function(f){this._trigger("remove",f,this._uiHash())});for(e=this.containers.length-1;e>=0;e--)if(d.ui.contains(this.containers[e].element[0],
-this.currentItem[0])&&!b){c.push(function(f){return function(g){f._trigger("receive",g,this._uiHash(this))}}.call(this,this.containers[e]));c.push(function(f){return function(g){f._trigger("update",g,this._uiHash(this))}}.call(this,this.containers[e]))}}for(e=this.containers.length-1;e>=0;e--){b||c.push(function(f){return function(g){f._trigger("deactivate",g,this._uiHash(this))}}.call(this,this.containers[e]));if(this.containers[e].containerCache.over){c.push(function(f){return function(g){f._trigger("out",
-g,this._uiHash(this))}}.call(this,this.containers[e]));this.containers[e].containerCache.over=0}}this._storedCursor&&d("body").css("cursor",this._storedCursor);this._storedOpacity&&this.helper.css("opacity",this._storedOpacity);if(this._storedZIndex)this.helper.css("zIndex",this._storedZIndex=="auto"?"":this._storedZIndex);this.dragging=false;if(this.cancelHelperRemoval){if(!b){this._trigger("beforeStop",a,this._uiHash());for(e=0;e<c.length;e++)c[e].call(this,a);this._trigger("stop",a,this._uiHash())}return false}b||
-this._trigger("beforeStop",a,this._uiHash());this.placeholder[0].parentNode.removeChild(this.placeholder[0]);this.helper[0]!=this.currentItem[0]&&this.helper.remove();this.helper=null;if(!b){for(e=0;e<c.length;e++)c[e].call(this,a);this._trigger("stop",a,this._uiHash())}this.fromOutside=false;return true},_trigger:function(){d.Widget.prototype._trigger.apply(this,arguments)===false&&this.cancel()},_uiHash:function(a){var b=a||this;return{helper:b.helper,placeholder:b.placeholder||d([]),position:b.position,
-originalPosition:b.originalPosition,offset:b.positionAbs,item:b.currentItem,sender:a?a.element:null}}});d.extend(d.ui.sortable,{version:"1.8.11"})})(jQuery);
-;/*
- * jQuery UI Accordion 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Accordion
- *
- * Depends:
- *	jquery.ui.core.js
- *	jquery.ui.widget.js
- */
-(function(c){c.widget("ui.accordion",{options:{active:0,animated:"slide",autoHeight:true,clearStyle:false,collapsible:false,event:"click",fillSpace:false,header:"> li > :first-child,> :not(li):even",icons:{header:"ui-icon-triangle-1-e",headerSelected:"ui-icon-triangle-1-s"},navigation:false,navigationFilter:function(){return this.href.toLowerCase()===location.href.toLowerCase()}},_create:function(){var a=this,b=a.options;a.running=0;a.element.addClass("ui-accordion ui-widget ui-helper-reset").children("li").addClass("ui-accordion-li-fix");
-a.headers=a.element.find(b.header).addClass("ui-accordion-header ui-helper-reset ui-state-default ui-corner-all").bind("mouseenter.accordion",function(){b.disabled||c(this).addClass("ui-state-hover")}).bind("mouseleave.accordion",function(){b.disabled||c(this).removeClass("ui-state-hover")}).bind("focus.accordion",function(){b.disabled||c(this).addClass("ui-state-focus")}).bind("blur.accordion",function(){b.disabled||c(this).removeClass("ui-state-focus")});a.headers.next().addClass("ui-accordion-content ui-helper-reset ui-widget-content ui-corner-bottom");
-if(b.navigation){var d=a.element.find("a").filter(b.navigationFilter).eq(0);if(d.length){var h=d.closest(".ui-accordion-header");a.active=h.length?h:d.closest(".ui-accordion-content").prev()}}a.active=a._findActive(a.active||b.active).addClass("ui-state-default ui-state-active").toggleClass("ui-corner-all").toggleClass("ui-corner-top");a.active.next().addClass("ui-accordion-content-active");a._createIcons();a.resize();a.element.attr("role","tablist");a.headers.attr("role","tab").bind("keydown.accordion",
-function(f){return a._keydown(f)}).next().attr("role","tabpanel");a.headers.not(a.active||"").attr({"aria-expanded":"false","aria-selected":"false",tabIndex:-1}).next().hide();a.active.length?a.active.attr({"aria-expanded":"true","aria-selected":"true",tabIndex:0}):a.headers.eq(0).attr("tabIndex",0);c.browser.safari||a.headers.find("a").attr("tabIndex",-1);b.event&&a.headers.bind(b.event.split(" ").join(".accordion ")+".accordion",function(f){a._clickHandler.call(a,f,this);f.preventDefault()})},_createIcons:function(){var a=
-this.options;if(a.icons){c("<span></span>").addClass("ui-icon "+a.icons.header).prependTo(this.headers);this.active.children(".ui-icon").toggleClass(a.icons.header).toggleClass(a.icons.headerSelected);this.element.addClass("ui-accordion-icons")}},_destroyIcons:function(){this.headers.children(".ui-icon").remove();this.element.removeClass("ui-accordion-icons")},destroy:function(){var a=this.options;this.element.removeClass("ui-accordion ui-widget ui-helper-reset").removeAttr("role");this.headers.unbind(".accordion").removeClass("ui-accordion-header ui-accordion-disabled ui-helper-reset ui-state-default ui-corner-all ui-state-active ui-state-disabled ui-corner-top").removeAttr("role").removeAttr("aria-expanded").removeAttr("aria-selected").removeAttr("tabIndex");
-this.headers.find("a").removeAttr("tabIndex");this._destroyIcons();var b=this.headers.next().css("display","").removeAttr("role").removeClass("ui-helper-reset ui-widget-content ui-corner-bottom ui-accordion-content ui-accordion-content-active ui-accordion-disabled ui-state-disabled");if(a.autoHeight||a.fillHeight)b.css("height","");return c.Widget.prototype.destroy.call(this)},_setOption:function(a,b){c.Widget.prototype._setOption.apply(this,arguments);a=="active"&&this.activate(b);if(a=="icons"){this._destroyIcons();
-b&&this._createIcons()}if(a=="disabled")this.headers.add(this.headers.next())[b?"addClass":"removeClass"]("ui-accordion-disabled ui-state-disabled")},_keydown:function(a){if(!(this.options.disabled||a.altKey||a.ctrlKey)){var b=c.ui.keyCode,d=this.headers.length,h=this.headers.index(a.target),f=false;switch(a.keyCode){case b.RIGHT:case b.DOWN:f=this.headers[(h+1)%d];break;case b.LEFT:case b.UP:f=this.headers[(h-1+d)%d];break;case b.SPACE:case b.ENTER:this._clickHandler({target:a.target},a.target);
-a.preventDefault()}if(f){c(a.target).attr("tabIndex",-1);c(f).attr("tabIndex",0);f.focus();return false}return true}},resize:function(){var a=this.options,b;if(a.fillSpace){if(c.browser.msie){var d=this.element.parent().css("overflow");this.element.parent().css("overflow","hidden")}b=this.element.parent().height();c.browser.msie&&this.element.parent().css("overflow",d);this.headers.each(function(){b-=c(this).outerHeight(true)});this.headers.next().each(function(){c(this).height(Math.max(0,b-c(this).innerHeight()+
-c(this).height()))}).css("overflow","auto")}else if(a.autoHeight){b=0;this.headers.next().each(function(){b=Math.max(b,c(this).height("").height())}).height(b)}return this},activate:function(a){this.options.active=a;a=this._findActive(a)[0];this._clickHandler({target:a},a);return this},_findActive:function(a){return a?typeof a==="number"?this.headers.filter(":eq("+a+")"):this.headers.not(this.headers.not(a)):a===false?c([]):this.headers.filter(":eq(0)")},_clickHandler:function(a,b){var d=this.options;
-if(!d.disabled)if(a.target){a=c(a.currentTarget||b);b=a[0]===this.active[0];d.active=d.collapsible&&b?false:this.headers.index(a);if(!(this.running||!d.collapsible&&b)){var h=this.active;j=a.next();g=this.active.next();e={options:d,newHeader:b&&d.collapsible?c([]):a,oldHeader:this.active,newContent:b&&d.collapsible?c([]):j,oldContent:g};var f=this.headers.index(this.active[0])>this.headers.index(a[0]);this.active=b?c([]):a;this._toggle(j,g,e,b,f);h.removeClass("ui-state-active ui-corner-top").addClass("ui-state-default ui-corner-all").children(".ui-icon").removeClass(d.icons.headerSelected).addClass(d.icons.header);
-if(!b){a.removeClass("ui-state-default ui-corner-all").addClass("ui-state-active ui-corner-top").children(".ui-icon").removeClass(d.icons.header).addClass(d.icons.headerSelected);a.next().addClass("ui-accordion-content-active")}}}else if(d.collapsible){this.active.removeClass("ui-state-active ui-corner-top").addClass("ui-state-default ui-corner-all").children(".ui-icon").removeClass(d.icons.headerSelected).addClass(d.icons.header);this.active.next().addClass("ui-accordion-content-active");var g=this.active.next(),
-e={options:d,newHeader:c([]),oldHeader:d.active,newContent:c([]),oldContent:g},j=this.active=c([]);this._toggle(j,g,e)}},_toggle:function(a,b,d,h,f){var g=this,e=g.options;g.toShow=a;g.toHide=b;g.data=d;var j=function(){if(g)return g._completed.apply(g,arguments)};g._trigger("changestart",null,g.data);g.running=b.size()===0?a.size():b.size();if(e.animated){d={};d=e.collapsible&&h?{toShow:c([]),toHide:b,complete:j,down:f,autoHeight:e.autoHeight||e.fillSpace}:{toShow:a,toHide:b,complete:j,down:f,autoHeight:e.autoHeight||
-e.fillSpace};if(!e.proxied)e.proxied=e.animated;if(!e.proxiedDuration)e.proxiedDuration=e.duration;e.animated=c.isFunction(e.proxied)?e.proxied(d):e.proxied;e.duration=c.isFunction(e.proxiedDuration)?e.proxiedDuration(d):e.proxiedDuration;h=c.ui.accordion.animations;var i=e.duration,k=e.animated;if(k&&!h[k]&&!c.easing[k])k="slide";h[k]||(h[k]=function(l){this.slide(l,{easing:k,duration:i||700})});h[k](d)}else{if(e.collapsible&&h)a.toggle();else{b.hide();a.show()}j(true)}b.prev().attr({"aria-expanded":"false",
-"aria-selected":"false",tabIndex:-1}).blur();a.prev().attr({"aria-expanded":"true","aria-selected":"true",tabIndex:0}).focus()},_completed:function(a){this.running=a?0:--this.running;if(!this.running){this.options.clearStyle&&this.toShow.add(this.toHide).css({height:"",overflow:""});this.toHide.removeClass("ui-accordion-content-active");if(this.toHide.length)this.toHide.parent()[0].className=this.toHide.parent()[0].className;this._trigger("change",null,this.data)}}});c.extend(c.ui.accordion,{version:"1.8.11",
-animations:{slide:function(a,b){a=c.extend({easing:"swing",duration:300},a,b);if(a.toHide.size())if(a.toShow.size()){var d=a.toShow.css("overflow"),h=0,f={},g={},e;b=a.toShow;e=b[0].style.width;b.width(parseInt(b.parent().width(),10)-parseInt(b.css("paddingLeft"),10)-parseInt(b.css("paddingRight"),10)-(parseInt(b.css("borderLeftWidth"),10)||0)-(parseInt(b.css("borderRightWidth"),10)||0));c.each(["height","paddingTop","paddingBottom"],function(j,i){g[i]="hide";j=(""+c.css(a.toShow[0],i)).match(/^([\d+-.]+)(.*)$/);
-f[i]={value:j[1],unit:j[2]||"px"}});a.toShow.css({height:0,overflow:"hidden"}).show();a.toHide.filter(":hidden").each(a.complete).end().filter(":visible").animate(g,{step:function(j,i){if(i.prop=="height")h=i.end-i.start===0?0:(i.now-i.start)/(i.end-i.start);a.toShow[0].style[i.prop]=h*f[i.prop].value+f[i.prop].unit},duration:a.duration,easing:a.easing,complete:function(){a.autoHeight||a.toShow.css("height","");a.toShow.css({width:e,overflow:d});a.complete()}})}else a.toHide.animate({height:"hide",
-paddingTop:"hide",paddingBottom:"hide"},a);else a.toShow.animate({height:"show",paddingTop:"show",paddingBottom:"show"},a)},bounceslide:function(a){this.slide(a,{easing:a.down?"easeOutBounce":"swing",duration:a.down?1E3:200})}}})})(jQuery);
-;/*
- * jQuery UI Autocomplete 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Autocomplete
- *
- * Depends:
- *	jquery.ui.core.js
- *	jquery.ui.widget.js
- *	jquery.ui.position.js
- */
-(function(d){var e=0;d.widget("ui.autocomplete",{options:{appendTo:"body",autoFocus:false,delay:300,minLength:1,position:{my:"left top",at:"left bottom",collision:"none"},source:null},pending:0,_create:function(){var a=this,b=this.element[0].ownerDocument,g;this.element.addClass("ui-autocomplete-input").attr("autocomplete","off").attr({role:"textbox","aria-autocomplete":"list","aria-haspopup":"true"}).bind("keydown.autocomplete",function(c){if(!(a.options.disabled||a.element.attr("readonly"))){g=
-false;var f=d.ui.keyCode;switch(c.keyCode){case f.PAGE_UP:a._move("previousPage",c);break;case f.PAGE_DOWN:a._move("nextPage",c);break;case f.UP:a._move("previous",c);c.preventDefault();break;case f.DOWN:a._move("next",c);c.preventDefault();break;case f.ENTER:case f.NUMPAD_ENTER:if(a.menu.active){g=true;c.preventDefault()}case f.TAB:if(!a.menu.active)return;a.menu.select(c);break;case f.ESCAPE:a.element.val(a.term);a.close(c);break;default:clearTimeout(a.searching);a.searching=setTimeout(function(){if(a.term!=
-a.element.val()){a.selectedItem=null;a.search(null,c)}},a.options.delay);break}}}).bind("keypress.autocomplete",function(c){if(g){g=false;c.preventDefault()}}).bind("focus.autocomplete",function(){if(!a.options.disabled){a.selectedItem=null;a.previous=a.element.val()}}).bind("blur.autocomplete",function(c){if(!a.options.disabled){clearTimeout(a.searching);a.closing=setTimeout(function(){a.close(c);a._change(c)},150)}});this._initSource();this.response=function(){return a._response.apply(a,arguments)};
-this.menu=d("<ul></ul>").addClass("ui-autocomplete").appendTo(d(this.options.appendTo||"body",b)[0]).mousedown(function(c){var f=a.menu.element[0];d(c.target).closest(".ui-menu-item").length||setTimeout(function(){d(document).one("mousedown",function(h){h.target!==a.element[0]&&h.target!==f&&!d.ui.contains(f,h.target)&&a.close()})},1);setTimeout(function(){clearTimeout(a.closing)},13)}).menu({focus:function(c,f){f=f.item.data("item.autocomplete");false!==a._trigger("focus",c,{item:f})&&/^key/.test(c.originalEvent.type)&&
-a.element.val(f.value)},selected:function(c,f){var h=f.item.data("item.autocomplete"),i=a.previous;if(a.element[0]!==b.activeElement){a.element.focus();a.previous=i;setTimeout(function(){a.previous=i;a.selectedItem=h},1)}false!==a._trigger("select",c,{item:h})&&a.element.val(h.value);a.term=a.element.val();a.close(c);a.selectedItem=h},blur:function(){a.menu.element.is(":visible")&&a.element.val()!==a.term&&a.element.val(a.term)}}).zIndex(this.element.zIndex()+1).css({top:0,left:0}).hide().data("menu");
-d.fn.bgiframe&&this.menu.element.bgiframe()},destroy:function(){this.element.removeClass("ui-autocomplete-input").removeAttr("autocomplete").removeAttr("role").removeAttr("aria-autocomplete").removeAttr("aria-haspopup");this.menu.element.remove();d.Widget.prototype.destroy.call(this)},_setOption:function(a,b){d.Widget.prototype._setOption.apply(this,arguments);a==="source"&&this._initSource();if(a==="appendTo")this.menu.element.appendTo(d(b||"body",this.element[0].ownerDocument)[0]);a==="disabled"&&
-b&&this.xhr&&this.xhr.abort()},_initSource:function(){var a=this,b,g;if(d.isArray(this.options.source)){b=this.options.source;this.source=function(c,f){f(d.ui.autocomplete.filter(b,c.term))}}else if(typeof this.options.source==="string"){g=this.options.source;this.source=function(c,f){a.xhr&&a.xhr.abort();a.xhr=d.ajax({url:g,data:c,dataType:"json",autocompleteRequest:++e,success:function(h){this.autocompleteRequest===e&&f(h)},error:function(){this.autocompleteRequest===e&&f([])}})}}else this.source=
-this.options.source},search:function(a,b){a=a!=null?a:this.element.val();this.term=this.element.val();if(a.length<this.options.minLength)return this.close(b);clearTimeout(this.closing);if(this._trigger("search",b)!==false)return this._search(a)},_search:function(a){this.pending++;this.element.addClass("ui-autocomplete-loading");this.source({term:a},this.response)},_response:function(a){if(!this.options.disabled&&a&&a.length){a=this._normalize(a);this._suggest(a);this._trigger("open")}else this.close();
-this.pending--;this.pending||this.element.removeClass("ui-autocomplete-loading")},close:function(a){clearTimeout(this.closing);if(this.menu.element.is(":visible")){this.menu.element.hide();this.menu.deactivate();this._trigger("close",a)}},_change:function(a){this.previous!==this.element.val()&&this._trigger("change",a,{item:this.selectedItem})},_normalize:function(a){if(a.length&&a[0].label&&a[0].value)return a;return d.map(a,function(b){if(typeof b==="string")return{label:b,value:b};return d.extend({label:b.label||
-b.value,value:b.value||b.label},b)})},_suggest:function(a){var b=this.menu.element.empty().zIndex(this.element.zIndex()+1);this._renderMenu(b,a);this.menu.deactivate();this.menu.refresh();b.show();this._resizeMenu();b.position(d.extend({of:this.element},this.options.position));this.options.autoFocus&&this.menu.next(new d.Event("mouseover"))},_resizeMenu:function(){var a=this.menu.element;a.outerWidth(Math.max(a.width("").outerWidth(),this.element.outerWidth()))},_renderMenu:function(a,b){var g=this;
-d.each(b,function(c,f){g._renderItem(a,f)})},_renderItem:function(a,b){return d("<li></li>").data("item.autocomplete",b).append(d("<a></a>").text(b.label)).appendTo(a)},_move:function(a,b){if(this.menu.element.is(":visible"))if(this.menu.first()&&/^previous/.test(a)||this.menu.last()&&/^next/.test(a)){this.element.val(this.term);this.menu.deactivate()}else this.menu[a](b);else this.search(null,b)},widget:function(){return this.menu.element}});d.extend(d.ui.autocomplete,{escapeRegex:function(a){return a.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,
-"\\$&")},filter:function(a,b){var g=new RegExp(d.ui.autocomplete.escapeRegex(b),"i");return d.grep(a,function(c){return g.test(c.label||c.value||c)})}})})(jQuery);
-(function(d){d.widget("ui.menu",{_create:function(){var e=this;this.element.addClass("ui-menu ui-widget ui-widget-content ui-corner-all").attr({role:"listbox","aria-activedescendant":"ui-active-menuitem"}).click(function(a){if(d(a.target).closest(".ui-menu-item a").length){a.preventDefault();e.select(a)}});this.refresh()},refresh:function(){var e=this;this.element.children("li:not(.ui-menu-item):has(a)").addClass("ui-menu-item").attr("role","menuitem").children("a").addClass("ui-corner-all").attr("tabindex",
--1).mouseenter(function(a){e.activate(a,d(this).parent())}).mouseleave(function(){e.deactivate()})},activate:function(e,a){this.deactivate();if(this.hasScroll()){var b=a.offset().top-this.element.offset().top,g=this.element.attr("scrollTop"),c=this.element.height();if(b<0)this.element.attr("scrollTop",g+b);else b>=c&&this.element.attr("scrollTop",g+b-c+a.height())}this.active=a.eq(0).children("a").addClass("ui-state-hover").attr("id","ui-active-menuitem").end();this._trigger("focus",e,{item:a})},
-deactivate:function(){if(this.active){this.active.children("a").removeClass("ui-state-hover").removeAttr("id");this._trigger("blur");this.active=null}},next:function(e){this.move("next",".ui-menu-item:first",e)},previous:function(e){this.move("prev",".ui-menu-item:last",e)},first:function(){return this.active&&!this.active.prevAll(".ui-menu-item").length},last:function(){return this.active&&!this.active.nextAll(".ui-menu-item").length},move:function(e,a,b){if(this.active){e=this.active[e+"All"](".ui-menu-item").eq(0);
-e.length?this.activate(b,e):this.activate(b,this.element.children(a))}else this.activate(b,this.element.children(a))},nextPage:function(e){if(this.hasScroll())if(!this.active||this.last())this.activate(e,this.element.children(".ui-menu-item:first"));else{var a=this.active.offset().top,b=this.element.height(),g=this.element.children(".ui-menu-item").filter(function(){var c=d(this).offset().top-a-b+d(this).height();return c<10&&c>-10});g.length||(g=this.element.children(".ui-menu-item:last"));this.activate(e,
-g)}else this.activate(e,this.element.children(".ui-menu-item").filter(!this.active||this.last()?":first":":last"))},previousPage:function(e){if(this.hasScroll())if(!this.active||this.first())this.activate(e,this.element.children(".ui-menu-item:last"));else{var a=this.active.offset().top,b=this.element.height();result=this.element.children(".ui-menu-item").filter(function(){var g=d(this).offset().top-a+b-d(this).height();return g<10&&g>-10});result.length||(result=this.element.children(".ui-menu-item:first"));
-this.activate(e,result)}else this.activate(e,this.element.children(".ui-menu-item").filter(!this.active||this.first()?":last":":first"))},hasScroll:function(){return this.element.height()<this.element.attr("scrollHeight")},select:function(e){this._trigger("selected",e,{item:this.active})}})})(jQuery);
-;/*
- * jQuery UI Button 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Button
- *
- * Depends:
- *	jquery.ui.core.js
- *	jquery.ui.widget.js
- */
-(function(a){var g,i=function(b){a(":ui-button",b.target.form).each(function(){var c=a(this).data("button");setTimeout(function(){c.refresh()},1)})},h=function(b){var c=b.name,d=b.form,f=a([]);if(c)f=d?a(d).find("[name='"+c+"']"):a("[name='"+c+"']",b.ownerDocument).filter(function(){return!this.form});return f};a.widget("ui.button",{options:{disabled:null,text:true,label:null,icons:{primary:null,secondary:null}},_create:function(){this.element.closest("form").unbind("reset.button").bind("reset.button",
-i);if(typeof this.options.disabled!=="boolean")this.options.disabled=this.element.attr("disabled");this._determineButtonType();this.hasTitle=!!this.buttonElement.attr("title");var b=this,c=this.options,d=this.type==="checkbox"||this.type==="radio",f="ui-state-hover"+(!d?" ui-state-active":"");if(c.label===null)c.label=this.buttonElement.html();if(this.element.is(":disabled"))c.disabled=true;this.buttonElement.addClass("ui-button ui-widget ui-state-default ui-corner-all").attr("role","button").bind("mouseenter.button",
-function(){if(!c.disabled){a(this).addClass("ui-state-hover");this===g&&a(this).addClass("ui-state-active")}}).bind("mouseleave.button",function(){c.disabled||a(this).removeClass(f)}).bind("focus.button",function(){a(this).addClass("ui-state-focus")}).bind("blur.button",function(){a(this).removeClass("ui-state-focus")});d&&this.element.bind("change.button",function(){b.refresh()});if(this.type==="checkbox")this.buttonElement.bind("click.button",function(){if(c.disabled)return false;a(this).toggleClass("ui-state-active");
-b.buttonElement.attr("aria-pressed",b.element[0].checked)});else if(this.type==="radio")this.buttonElement.bind("click.button",function(){if(c.disabled)return false;a(this).addClass("ui-state-active");b.buttonElement.attr("aria-pressed",true);var e=b.element[0];h(e).not(e).map(function(){return a(this).button("widget")[0]}).removeClass("ui-state-active").attr("aria-pressed",false)});else{this.buttonElement.bind("mousedown.button",function(){if(c.disabled)return false;a(this).addClass("ui-state-active");
-g=this;a(document).one("mouseup",function(){g=null})}).bind("mouseup.button",function(){if(c.disabled)return false;a(this).removeClass("ui-state-active")}).bind("keydown.button",function(e){if(c.disabled)return false;if(e.keyCode==a.ui.keyCode.SPACE||e.keyCode==a.ui.keyCode.ENTER)a(this).addClass("ui-state-active")}).bind("keyup.button",function(){a(this).removeClass("ui-state-active")});this.buttonElement.is("a")&&this.buttonElement.keyup(function(e){e.keyCode===a.ui.keyCode.SPACE&&a(this).click()})}this._setOption("disabled",
-c.disabled)},_determineButtonType:function(){this.type=this.element.is(":checkbox")?"checkbox":this.element.is(":radio")?"radio":this.element.is("input")?"input":"button";if(this.type==="checkbox"||this.type==="radio"){var b=this.element.parents().filter(":last"),c="label[for="+this.element.attr("id")+"]";this.buttonElement=b.find(c);if(!this.buttonElement.length){b=b.length?b.siblings():this.element.siblings();this.buttonElement=b.filter(c);if(!this.buttonElement.length)this.buttonElement=b.find(c)}this.element.addClass("ui-helper-hidden-accessible");
-(b=this.element.is(":checked"))&&this.buttonElement.addClass("ui-state-active");this.buttonElement.attr("aria-pressed",b)}else this.buttonElement=this.element},widget:function(){return this.buttonElement},destroy:function(){this.element.removeClass("ui-helper-hidden-accessible");this.buttonElement.removeClass("ui-button ui-widget ui-state-default ui-corner-all ui-state-hover ui-state-active  ui-button-icons-only ui-button-icon-only ui-button-text-icons ui-button-text-icon-primary ui-button-text-icon-secondary ui-button-text-only").removeAttr("role").removeAttr("aria-pressed").html(this.buttonElement.find(".ui-button-text").html());
-this.hasTitle||this.buttonElement.removeAttr("title");a.Widget.prototype.destroy.call(this)},_setOption:function(b,c){a.Widget.prototype._setOption.apply(this,arguments);if(b==="disabled")c?this.element.attr("disabled",true):this.element.removeAttr("disabled");this._resetButton()},refresh:function(){var b=this.element.is(":disabled");b!==this.options.disabled&&this._setOption("disabled",b);if(this.type==="radio")h(this.element[0]).each(function(){a(this).is(":checked")?a(this).button("widget").addClass("ui-state-active").attr("aria-pressed",
-true):a(this).button("widget").removeClass("ui-state-active").attr("aria-pressed",false)});else if(this.type==="checkbox")this.element.is(":checked")?this.buttonElement.addClass("ui-state-active").attr("aria-pressed",true):this.buttonElement.removeClass("ui-state-active").attr("aria-pressed",false)},_resetButton:function(){if(this.type==="input")this.options.label&&this.element.val(this.options.label);else{var b=this.buttonElement.removeClass("ui-button-icons-only ui-button-icon-only ui-button-text-icons ui-button-text-icon-primary ui-button-text-icon-secondary ui-button-text-only"),
-c=a("<span></span>").addClass("ui-button-text").html(this.options.label).appendTo(b.empty()).text(),d=this.options.icons,f=d.primary&&d.secondary,e=[];if(d.primary||d.secondary){if(this.options.text)e.push("ui-button-text-icon"+(f?"s":d.primary?"-primary":"-secondary"));d.primary&&b.prepend("<span class='ui-button-icon-primary ui-icon "+d.primary+"'></span>");d.secondary&&b.append("<span class='ui-button-icon-secondary ui-icon "+d.secondary+"'></span>");if(!this.options.text){e.push(f?"ui-button-icons-only":
-"ui-button-icon-only");this.hasTitle||b.attr("title",c)}}else e.push("ui-button-text-only");b.addClass(e.join(" "))}}});a.widget("ui.buttonset",{options:{items:":button, :submit, :reset, :checkbox, :radio, a, :data(button)"},_create:function(){this.element.addClass("ui-buttonset")},_init:function(){this.refresh()},_setOption:function(b,c){b==="disabled"&&this.buttons.button("option",b,c);a.Widget.prototype._setOption.apply(this,arguments)},refresh:function(){this.buttons=this.element.find(this.options.items).filter(":ui-button").button("refresh").end().not(":ui-button").button().end().map(function(){return a(this).button("widget")[0]}).removeClass("ui-corner-all ui-corner-left ui-corner-right").filter(":first").addClass("ui-corner-left").end().filter(":last").addClass("ui-corner-right").end().end()},
-destroy:function(){this.element.removeClass("ui-buttonset");this.buttons.map(function(){return a(this).button("widget")[0]}).removeClass("ui-corner-left ui-corner-right").end().button("destroy");a.Widget.prototype.destroy.call(this)}})})(jQuery);
-;/*
- * jQuery UI Dialog 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Dialog
- *
- * Depends:
- *	jquery.ui.core.js
- *	jquery.ui.widget.js
- *  jquery.ui.button.js
- *	jquery.ui.draggable.js
- *	jquery.ui.mouse.js
- *	jquery.ui.position.js
- *	jquery.ui.resizable.js
- */
-(function(c,j){var k={buttons:true,height:true,maxHeight:true,maxWidth:true,minHeight:true,minWidth:true,width:true},l={maxHeight:true,maxWidth:true,minHeight:true,minWidth:true};c.widget("ui.dialog",{options:{autoOpen:true,buttons:{},closeOnEscape:true,closeText:"close",dialogClass:"",draggable:true,hide:null,height:"auto",maxHeight:false,maxWidth:false,minHeight:150,minWidth:150,modal:false,position:{my:"center",at:"center",collision:"fit",using:function(a){var b=c(this).css(a).offset().top;b<0&&
-c(this).css("top",a.top-b)}},resizable:true,show:null,stack:true,title:"",width:300,zIndex:1E3},_create:function(){this.originalTitle=this.element.attr("title");if(typeof this.originalTitle!=="string")this.originalTitle="";this.options.title=this.options.title||this.originalTitle;var a=this,b=a.options,d=b.title||"&#160;",e=c.ui.dialog.getTitleId(a.element),g=(a.uiDialog=c("<div></div>")).appendTo(document.body).hide().addClass("ui-dialog ui-widget ui-widget-content ui-corner-all "+b.dialogClass).css({zIndex:b.zIndex}).attr("tabIndex",
--1).css("outline",0).keydown(function(i){if(b.closeOnEscape&&i.keyCode&&i.keyCode===c.ui.keyCode.ESCAPE){a.close(i);i.preventDefault()}}).attr({role:"dialog","aria-labelledby":e}).mousedown(function(i){a.moveToTop(false,i)});a.element.show().removeAttr("title").addClass("ui-dialog-content ui-widget-content").appendTo(g);var f=(a.uiDialogTitlebar=c("<div></div>")).addClass("ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix").prependTo(g),h=c('<a href="#"></a>').addClass("ui-dialog-titlebar-close ui-corner-all").attr("role",
-"button").hover(function(){h.addClass("ui-state-hover")},function(){h.removeClass("ui-state-hover")}).focus(function(){h.addClass("ui-state-focus")}).blur(function(){h.removeClass("ui-state-focus")}).click(function(i){a.close(i);return false}).appendTo(f);(a.uiDialogTitlebarCloseText=c("<span></span>")).addClass("ui-icon ui-icon-closethick").text(b.closeText).appendTo(h);c("<span></span>").addClass("ui-dialog-title").attr("id",e).html(d).prependTo(f);if(c.isFunction(b.beforeclose)&&!c.isFunction(b.beforeClose))b.beforeClose=
-b.beforeclose;f.find("*").add(f).disableSelection();b.draggable&&c.fn.draggable&&a._makeDraggable();b.resizable&&c.fn.resizable&&a._makeResizable();a._createButtons(b.buttons);a._isOpen=false;c.fn.bgiframe&&g.bgiframe()},_init:function(){this.options.autoOpen&&this.open()},destroy:function(){var a=this;a.overlay&&a.overlay.destroy();a.uiDialog.hide();a.element.unbind(".dialog").removeData("dialog").removeClass("ui-dialog-content ui-widget-content").hide().appendTo("body");a.uiDialog.remove();a.originalTitle&&
-a.element.attr("title",a.originalTitle);return a},widget:function(){return this.uiDialog},close:function(a){var b=this,d,e;if(false!==b._trigger("beforeClose",a)){b.overlay&&b.overlay.destroy();b.uiDialog.unbind("keypress.ui-dialog");b._isOpen=false;if(b.options.hide)b.uiDialog.hide(b.options.hide,function(){b._trigger("close",a)});else{b.uiDialog.hide();b._trigger("close",a)}c.ui.dialog.overlay.resize();if(b.options.modal){d=0;c(".ui-dialog").each(function(){if(this!==b.uiDialog[0]){e=c(this).css("z-index");
-isNaN(e)||(d=Math.max(d,e))}});c.ui.dialog.maxZ=d}return b}},isOpen:function(){return this._isOpen},moveToTop:function(a,b){var d=this,e=d.options;if(e.modal&&!a||!e.stack&&!e.modal)return d._trigger("focus",b);if(e.zIndex>c.ui.dialog.maxZ)c.ui.dialog.maxZ=e.zIndex;if(d.overlay){c.ui.dialog.maxZ+=1;d.overlay.$el.css("z-index",c.ui.dialog.overlay.maxZ=c.ui.dialog.maxZ)}a={scrollTop:d.element.attr("scrollTop"),scrollLeft:d.element.attr("scrollLeft")};c.ui.dialog.maxZ+=1;d.uiDialog.css("z-index",c.ui.dialog.maxZ);
-d.element.attr(a);d._trigger("focus",b);return d},open:function(){if(!this._isOpen){var a=this,b=a.options,d=a.uiDialog;a.overlay=b.modal?new c.ui.dialog.overlay(a):null;a._size();a._position(b.position);d.show(b.show);a.moveToTop(true);b.modal&&d.bind("keypress.ui-dialog",function(e){if(e.keyCode===c.ui.keyCode.TAB){var g=c(":tabbable",this),f=g.filter(":first");g=g.filter(":last");if(e.target===g[0]&&!e.shiftKey){f.focus(1);return false}else if(e.target===f[0]&&e.shiftKey){g.focus(1);return false}}});
-c(a.element.find(":tabbable").get().concat(d.find(".ui-dialog-buttonpane :tabbable").get().concat(d.get()))).eq(0).focus();a._isOpen=true;a._trigger("open");return a}},_createButtons:function(a){var b=this,d=false,e=c("<div></div>").addClass("ui-dialog-buttonpane ui-widget-content ui-helper-clearfix"),g=c("<div></div>").addClass("ui-dialog-buttonset").appendTo(e);b.uiDialog.find(".ui-dialog-buttonpane").remove();typeof a==="object"&&a!==null&&c.each(a,function(){return!(d=true)});if(d){c.each(a,function(f,
-h){h=c.isFunction(h)?{click:h,text:f}:h;f=c('<button type="button"></button>').attr(h,true).unbind("click").click(function(){h.click.apply(b.element[0],arguments)}).appendTo(g);c.fn.button&&f.button()});e.appendTo(b.uiDialog)}},_makeDraggable:function(){function a(f){return{position:f.position,offset:f.offset}}var b=this,d=b.options,e=c(document),g;b.uiDialog.draggable({cancel:".ui-dialog-content, .ui-dialog-titlebar-close",handle:".ui-dialog-titlebar",containment:"document",start:function(f,h){g=
-d.height==="auto"?"auto":c(this).height();c(this).height(c(this).height()).addClass("ui-dialog-dragging");b._trigger("dragStart",f,a(h))},drag:function(f,h){b._trigger("drag",f,a(h))},stop:function(f,h){d.position=[h.position.left-e.scrollLeft(),h.position.top-e.scrollTop()];c(this).removeClass("ui-dialog-dragging").height(g);b._trigger("dragStop",f,a(h));c.ui.dialog.overlay.resize()}})},_makeResizable:function(a){function b(f){return{originalPosition:f.originalPosition,originalSize:f.originalSize,
-position:f.position,size:f.size}}a=a===j?this.options.resizable:a;var d=this,e=d.options,g=d.uiDialog.css("position");a=typeof a==="string"?a:"n,e,s,w,se,sw,ne,nw";d.uiDialog.resizable({cancel:".ui-dialog-content",containment:"document",alsoResize:d.element,maxWidth:e.maxWidth,maxHeight:e.maxHeight,minWidth:e.minWidth,minHeight:d._minHeight(),handles:a,start:function(f,h){c(this).addClass("ui-dialog-resizing");d._trigger("resizeStart",f,b(h))},resize:function(f,h){d._trigger("resize",f,b(h))},stop:function(f,
-h){c(this).removeClass("ui-dialog-resizing");e.height=c(this).height();e.width=c(this).width();d._trigger("resizeStop",f,b(h));c.ui.dialog.overlay.resize()}}).css("position",g).find(".ui-resizable-se").addClass("ui-icon ui-icon-grip-diagonal-se")},_minHeight:function(){var a=this.options;return a.height==="auto"?a.minHeight:Math.min(a.minHeight,a.height)},_position:function(a){var b=[],d=[0,0],e;if(a){if(typeof a==="string"||typeof a==="object"&&"0"in a){b=a.split?a.split(" "):[a[0],a[1]];if(b.length===
-1)b[1]=b[0];c.each(["left","top"],function(g,f){if(+b[g]===b[g]){d[g]=b[g];b[g]=f}});a={my:b.join(" "),at:b.join(" "),offset:d.join(" ")}}a=c.extend({},c.ui.dialog.prototype.options.position,a)}else a=c.ui.dialog.prototype.options.position;(e=this.uiDialog.is(":visible"))||this.uiDialog.show();this.uiDialog.css({top:0,left:0}).position(c.extend({of:window},a));e||this.uiDialog.hide()},_setOptions:function(a){var b=this,d={},e=false;c.each(a,function(g,f){b._setOption(g,f);if(g in k)e=true;if(g in
-l)d[g]=f});e&&this._size();this.uiDialog.is(":data(resizable)")&&this.uiDialog.resizable("option",d)},_setOption:function(a,b){var d=this,e=d.uiDialog;switch(a){case "beforeclose":a="beforeClose";break;case "buttons":d._createButtons(b);break;case "closeText":d.uiDialogTitlebarCloseText.text(""+b);break;case "dialogClass":e.removeClass(d.options.dialogClass).addClass("ui-dialog ui-widget ui-widget-content ui-corner-all "+b);break;case "disabled":b?e.addClass("ui-dialog-disabled"):e.removeClass("ui-dialog-disabled");
-break;case "draggable":var g=e.is(":data(draggable)");g&&!b&&e.draggable("destroy");!g&&b&&d._makeDraggable();break;case "position":d._position(b);break;case "resizable":(g=e.is(":data(resizable)"))&&!b&&e.resizable("destroy");g&&typeof b==="string"&&e.resizable("option","handles",b);!g&&b!==false&&d._makeResizable(b);break;case "title":c(".ui-dialog-title",d.uiDialogTitlebar).html(""+(b||"&#160;"));break}c.Widget.prototype._setOption.apply(d,arguments)},_size:function(){var a=this.options,b,d,e=
-this.uiDialog.is(":visible");this.element.show().css({width:"auto",minHeight:0,height:0});if(a.minWidth>a.width)a.width=a.minWidth;b=this.uiDialog.css({height:"auto",width:a.width}).height();d=Math.max(0,a.minHeight-b);if(a.height==="auto")if(c.support.minHeight)this.element.css({minHeight:d,height:"auto"});else{this.uiDialog.show();a=this.element.css("height","auto").height();e||this.uiDialog.hide();this.element.height(Math.max(a,d))}else this.element.height(Math.max(a.height-b,0));this.uiDialog.is(":data(resizable)")&&
-this.uiDialog.resizable("option","minHeight",this._minHeight())}});c.extend(c.ui.dialog,{version:"1.8.11",uuid:0,maxZ:0,getTitleId:function(a){a=a.attr("id");if(!a){this.uuid+=1;a=this.uuid}return"ui-dialog-title-"+a},overlay:function(a){this.$el=c.ui.dialog.overlay.create(a)}});c.extend(c.ui.dialog.overlay,{instances:[],oldInstances:[],maxZ:0,events:c.map("focus,mousedown,mouseup,keydown,keypress,click".split(","),function(a){return a+".dialog-overlay"}).join(" "),create:function(a){if(this.instances.length===
-0){setTimeout(function(){c.ui.dialog.overlay.instances.length&&c(document).bind(c.ui.dialog.overlay.events,function(d){if(c(d.target).zIndex()<c.ui.dialog.overlay.maxZ)return false})},1);c(document).bind("keydown.dialog-overlay",function(d){if(a.options.closeOnEscape&&d.keyCode&&d.keyCode===c.ui.keyCode.ESCAPE){a.close(d);d.preventDefault()}});c(window).bind("resize.dialog-overlay",c.ui.dialog.overlay.resize)}var b=(this.oldInstances.pop()||c("<div></div>").addClass("ui-widget-overlay")).appendTo(document.body).css({width:this.width(),
-height:this.height()});c.fn.bgiframe&&b.bgiframe();this.instances.push(b);return b},destroy:function(a){var b=c.inArray(a,this.instances);b!=-1&&this.oldInstances.push(this.instances.splice(b,1)[0]);this.instances.length===0&&c([document,window]).unbind(".dialog-overlay");a.remove();var d=0;c.each(this.instances,function(){d=Math.max(d,this.css("z-index"))});this.maxZ=d},height:function(){var a,b;if(c.browser.msie&&c.browser.version<7){a=Math.max(document.documentElement.scrollHeight,document.body.scrollHeight);
-b=Math.max(document.documentElement.offsetHeight,document.body.offsetHeight);return a<b?c(window).height()+"px":a+"px"}else return c(document).height()+"px"},width:function(){var a,b;if(c.browser.msie&&c.browser.version<7){a=Math.max(document.documentElement.scrollWidth,document.body.scrollWidth);b=Math.max(document.documentElement.offsetWidth,document.body.offsetWidth);return a<b?c(window).width()+"px":a+"px"}else return c(document).width()+"px"},resize:function(){var a=c([]);c.each(c.ui.dialog.overlay.instances,
-function(){a=a.add(this)});a.css({width:0,height:0}).css({width:c.ui.dialog.overlay.width(),height:c.ui.dialog.overlay.height()})}});c.extend(c.ui.dialog.overlay.prototype,{destroy:function(){c.ui.dialog.overlay.destroy(this.$el)}})})(jQuery);
-;/*
- * jQuery UI Slider 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Slider
- *
- * Depends:
- *	jquery.ui.core.js
- *	jquery.ui.mouse.js
- *	jquery.ui.widget.js
- */
-(function(d){d.widget("ui.slider",d.ui.mouse,{widgetEventPrefix:"slide",options:{animate:false,distance:0,max:100,min:0,orientation:"horizontal",range:false,step:1,value:0,values:null},_create:function(){var b=this,a=this.options;this._mouseSliding=this._keySliding=false;this._animateOff=true;this._handleIndex=null;this._detectOrientation();this._mouseInit();this.element.addClass("ui-slider ui-slider-"+this.orientation+" ui-widget ui-widget-content ui-corner-all");a.disabled&&this.element.addClass("ui-slider-disabled ui-disabled");
-this.range=d([]);if(a.range){if(a.range===true){this.range=d("<div></div>");if(!a.values)a.values=[this._valueMin(),this._valueMin()];if(a.values.length&&a.values.length!==2)a.values=[a.values[0],a.values[0]]}else this.range=d("<div></div>");this.range.appendTo(this.element).addClass("ui-slider-range");if(a.range==="min"||a.range==="max")this.range.addClass("ui-slider-range-"+a.range);this.range.addClass("ui-widget-header")}d(".ui-slider-handle",this.element).length===0&&d("<a href='#'></a>").appendTo(this.element).addClass("ui-slider-handle");
-if(a.values&&a.values.length)for(;d(".ui-slider-handle",this.element).length<a.values.length;)d("<a href='#'></a>").appendTo(this.element).addClass("ui-slider-handle");this.handles=d(".ui-slider-handle",this.element).addClass("ui-state-default ui-corner-all");this.handle=this.handles.eq(0);this.handles.add(this.range).filter("a").click(function(c){c.preventDefault()}).hover(function(){a.disabled||d(this).addClass("ui-state-hover")},function(){d(this).removeClass("ui-state-hover")}).focus(function(){if(a.disabled)d(this).blur();
-else{d(".ui-slider .ui-state-focus").removeClass("ui-state-focus");d(this).addClass("ui-state-focus")}}).blur(function(){d(this).removeClass("ui-state-focus")});this.handles.each(function(c){d(this).data("index.ui-slider-handle",c)});this.handles.keydown(function(c){var e=true,f=d(this).data("index.ui-slider-handle"),h,g,i;if(!b.options.disabled){switch(c.keyCode){case d.ui.keyCode.HOME:case d.ui.keyCode.END:case d.ui.keyCode.PAGE_UP:case d.ui.keyCode.PAGE_DOWN:case d.ui.keyCode.UP:case d.ui.keyCode.RIGHT:case d.ui.keyCode.DOWN:case d.ui.keyCode.LEFT:e=
-false;if(!b._keySliding){b._keySliding=true;d(this).addClass("ui-state-active");h=b._start(c,f);if(h===false)return}break}i=b.options.step;h=b.options.values&&b.options.values.length?(g=b.values(f)):(g=b.value());switch(c.keyCode){case d.ui.keyCode.HOME:g=b._valueMin();break;case d.ui.keyCode.END:g=b._valueMax();break;case d.ui.keyCode.PAGE_UP:g=b._trimAlignValue(h+(b._valueMax()-b._valueMin())/5);break;case d.ui.keyCode.PAGE_DOWN:g=b._trimAlignValue(h-(b._valueMax()-b._valueMin())/5);break;case d.ui.keyCode.UP:case d.ui.keyCode.RIGHT:if(h===
-b._valueMax())return;g=b._trimAlignValue(h+i);break;case d.ui.keyCode.DOWN:case d.ui.keyCode.LEFT:if(h===b._valueMin())return;g=b._trimAlignValue(h-i);break}b._slide(c,f,g);return e}}).keyup(function(c){var e=d(this).data("index.ui-slider-handle");if(b._keySliding){b._keySliding=false;b._stop(c,e);b._change(c,e);d(this).removeClass("ui-state-active")}});this._refreshValue();this._animateOff=false},destroy:function(){this.handles.remove();this.range.remove();this.element.removeClass("ui-slider ui-slider-horizontal ui-slider-vertical ui-slider-disabled ui-widget ui-widget-content ui-corner-all").removeData("slider").unbind(".slider");
-this._mouseDestroy();return this},_mouseCapture:function(b){var a=this.options,c,e,f,h,g;if(a.disabled)return false;this.elementSize={width:this.element.outerWidth(),height:this.element.outerHeight()};this.elementOffset=this.element.offset();c=this._normValueFromMouse({x:b.pageX,y:b.pageY});e=this._valueMax()-this._valueMin()+1;h=this;this.handles.each(function(i){var j=Math.abs(c-h.values(i));if(e>j){e=j;f=d(this);g=i}});if(a.range===true&&this.values(1)===a.min){g+=1;f=d(this.handles[g])}if(this._start(b,
-g)===false)return false;this._mouseSliding=true;h._handleIndex=g;f.addClass("ui-state-active").focus();a=f.offset();this._clickOffset=!d(b.target).parents().andSelf().is(".ui-slider-handle")?{left:0,top:0}:{left:b.pageX-a.left-f.width()/2,top:b.pageY-a.top-f.height()/2-(parseInt(f.css("borderTopWidth"),10)||0)-(parseInt(f.css("borderBottomWidth"),10)||0)+(parseInt(f.css("marginTop"),10)||0)};this.handles.hasClass("ui-state-hover")||this._slide(b,g,c);return this._animateOff=true},_mouseStart:function(){return true},
-_mouseDrag:function(b){var a=this._normValueFromMouse({x:b.pageX,y:b.pageY});this._slide(b,this._handleIndex,a);return false},_mouseStop:function(b){this.handles.removeClass("ui-state-active");this._mouseSliding=false;this._stop(b,this._handleIndex);this._change(b,this._handleIndex);this._clickOffset=this._handleIndex=null;return this._animateOff=false},_detectOrientation:function(){this.orientation=this.options.orientation==="vertical"?"vertical":"horizontal"},_normValueFromMouse:function(b){var a;
-if(this.orientation==="horizontal"){a=this.elementSize.width;b=b.x-this.elementOffset.left-(this._clickOffset?this._clickOffset.left:0)}else{a=this.elementSize.height;b=b.y-this.elementOffset.top-(this._clickOffset?this._clickOffset.top:0)}a=b/a;if(a>1)a=1;if(a<0)a=0;if(this.orientation==="vertical")a=1-a;b=this._valueMax()-this._valueMin();return this._trimAlignValue(this._valueMin()+a*b)},_start:function(b,a){var c={handle:this.handles[a],value:this.value()};if(this.options.values&&this.options.values.length){c.value=
-this.values(a);c.values=this.values()}return this._trigger("start",b,c)},_slide:function(b,a,c){var e;if(this.options.values&&this.options.values.length){e=this.values(a?0:1);if(this.options.values.length===2&&this.options.range===true&&(a===0&&c>e||a===1&&c<e))c=e;if(c!==this.values(a)){e=this.values();e[a]=c;b=this._trigger("slide",b,{handle:this.handles[a],value:c,values:e});this.values(a?0:1);b!==false&&this.values(a,c,true)}}else if(c!==this.value()){b=this._trigger("slide",b,{handle:this.handles[a],
-value:c});b!==false&&this.value(c)}},_stop:function(b,a){var c={handle:this.handles[a],value:this.value()};if(this.options.values&&this.options.values.length){c.value=this.values(a);c.values=this.values()}this._trigger("stop",b,c)},_change:function(b,a){if(!this._keySliding&&!this._mouseSliding){var c={handle:this.handles[a],value:this.value()};if(this.options.values&&this.options.values.length){c.value=this.values(a);c.values=this.values()}this._trigger("change",b,c)}},value:function(b){if(arguments.length){this.options.value=
-this._trimAlignValue(b);this._refreshValue();this._change(null,0)}return this._value()},values:function(b,a){var c,e,f;if(arguments.length>1){this.options.values[b]=this._trimAlignValue(a);this._refreshValue();this._change(null,b)}if(arguments.length)if(d.isArray(arguments[0])){c=this.options.values;e=arguments[0];for(f=0;f<c.length;f+=1){c[f]=this._trimAlignValue(e[f]);this._change(null,f)}this._refreshValue()}else return this.options.values&&this.options.values.length?this._values(b):this.value();
-else return this._values()},_setOption:function(b,a){var c,e=0;if(d.isArray(this.options.values))e=this.options.values.length;d.Widget.prototype._setOption.apply(this,arguments);switch(b){case "disabled":if(a){this.handles.filter(".ui-state-focus").blur();this.handles.removeClass("ui-state-hover");this.handles.attr("disabled","disabled");this.element.addClass("ui-disabled")}else{this.handles.removeAttr("disabled");this.element.removeClass("ui-disabled")}break;case "orientation":this._detectOrientation();
-this.element.removeClass("ui-slider-horizontal ui-slider-vertical").addClass("ui-slider-"+this.orientation);this._refreshValue();break;case "value":this._animateOff=true;this._refreshValue();this._change(null,0);this._animateOff=false;break;case "values":this._animateOff=true;this._refreshValue();for(c=0;c<e;c+=1)this._change(null,c);this._animateOff=false;break}},_value:function(){var b=this.options.value;return b=this._trimAlignValue(b)},_values:function(b){var a,c;if(arguments.length){a=this.options.values[b];
-return a=this._trimAlignValue(a)}else{a=this.options.values.slice();for(c=0;c<a.length;c+=1)a[c]=this._trimAlignValue(a[c]);return a}},_trimAlignValue:function(b){if(b<=this._valueMin())return this._valueMin();if(b>=this._valueMax())return this._valueMax();var a=this.options.step>0?this.options.step:1,c=(b-this._valueMin())%a;alignValue=b-c;if(Math.abs(c)*2>=a)alignValue+=c>0?a:-a;return parseFloat(alignValue.toFixed(5))},_valueMin:function(){return this.options.min},_valueMax:function(){return this.options.max},
-_refreshValue:function(){var b=this.options.range,a=this.options,c=this,e=!this._animateOff?a.animate:false,f,h={},g,i,j,l;if(this.options.values&&this.options.values.length)this.handles.each(function(k){f=(c.values(k)-c._valueMin())/(c._valueMax()-c._valueMin())*100;h[c.orientation==="horizontal"?"left":"bottom"]=f+"%";d(this).stop(1,1)[e?"animate":"css"](h,a.animate);if(c.options.range===true)if(c.orientation==="horizontal"){if(k===0)c.range.stop(1,1)[e?"animate":"css"]({left:f+"%"},a.animate);
-if(k===1)c.range[e?"animate":"css"]({width:f-g+"%"},{queue:false,duration:a.animate})}else{if(k===0)c.range.stop(1,1)[e?"animate":"css"]({bottom:f+"%"},a.animate);if(k===1)c.range[e?"animate":"css"]({height:f-g+"%"},{queue:false,duration:a.animate})}g=f});else{i=this.value();j=this._valueMin();l=this._valueMax();f=l!==j?(i-j)/(l-j)*100:0;h[c.orientation==="horizontal"?"left":"bottom"]=f+"%";this.handle.stop(1,1)[e?"animate":"css"](h,a.animate);if(b==="min"&&this.orientation==="horizontal")this.range.stop(1,
-1)[e?"animate":"css"]({width:f+"%"},a.animate);if(b==="max"&&this.orientation==="horizontal")this.range[e?"animate":"css"]({width:100-f+"%"},{queue:false,duration:a.animate});if(b==="min"&&this.orientation==="vertical")this.range.stop(1,1)[e?"animate":"css"]({height:f+"%"},a.animate);if(b==="max"&&this.orientation==="vertical")this.range[e?"animate":"css"]({height:100-f+"%"},{queue:false,duration:a.animate})}}});d.extend(d.ui.slider,{version:"1.8.11"})})(jQuery);
-;/*
- * jQuery UI Tabs 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Tabs
- *
- * Depends:
- *	jquery.ui.core.js
- *	jquery.ui.widget.js
- */
-(function(d,p){function u(){return++v}function w(){return++x}var v=0,x=0;d.widget("ui.tabs",{options:{add:null,ajaxOptions:null,cache:false,cookie:null,collapsible:false,disable:null,disabled:[],enable:null,event:"click",fx:null,idPrefix:"ui-tabs-",load:null,panelTemplate:"<div></div>",remove:null,select:null,show:null,spinner:"<em>Loading&#8230;</em>",tabTemplate:"<li><a href='#{href}'><span>#{label}</span></a></li>"},_create:function(){this._tabify(true)},_setOption:function(b,e){if(b=="selected")this.options.collapsible&&
-e==this.options.selected||this.select(e);else{this.options[b]=e;this._tabify()}},_tabId:function(b){return b.title&&b.title.replace(/\s/g,"_").replace(/[^\w\u00c0-\uFFFF-]/g,"")||this.options.idPrefix+u()},_sanitizeSelector:function(b){return b.replace(/:/g,"\\:")},_cookie:function(){var b=this.cookie||(this.cookie=this.options.cookie.name||"ui-tabs-"+w());return d.cookie.apply(null,[b].concat(d.makeArray(arguments)))},_ui:function(b,e){return{tab:b,panel:e,index:this.anchors.index(b)}},_cleanup:function(){this.lis.filter(".ui-state-processing").removeClass("ui-state-processing").find("span:data(label.tabs)").each(function(){var b=
-d(this);b.html(b.data("label.tabs")).removeData("label.tabs")})},_tabify:function(b){function e(g,f){g.css("display","");!d.support.opacity&&f.opacity&&g[0].style.removeAttribute("filter")}var a=this,c=this.options,h=/^#.+/;this.list=this.element.find("ol,ul").eq(0);this.lis=d(" > li:has(a[href])",this.list);this.anchors=this.lis.map(function(){return d("a",this)[0]});this.panels=d([]);this.anchors.each(function(g,f){var i=d(f).attr("href"),l=i.split("#")[0],q;if(l&&(l===location.toString().split("#")[0]||
-(q=d("base")[0])&&l===q.href)){i=f.hash;f.href=i}if(h.test(i))a.panels=a.panels.add(a.element.find(a._sanitizeSelector(i)));else if(i&&i!=="#"){d.data(f,"href.tabs",i);d.data(f,"load.tabs",i.replace(/#.*$/,""));i=a._tabId(f);f.href="#"+i;f=a.element.find("#"+i);if(!f.length){f=d(c.panelTemplate).attr("id",i).addClass("ui-tabs-panel ui-widget-content ui-corner-bottom").insertAfter(a.panels[g-1]||a.list);f.data("destroy.tabs",true)}a.panels=a.panels.add(f)}else c.disabled.push(g)});if(b){this.element.addClass("ui-tabs ui-widget ui-widget-content ui-corner-all");
-this.list.addClass("ui-tabs-nav ui-helper-reset ui-helper-clearfix ui-widget-header ui-corner-all");this.lis.addClass("ui-state-default ui-corner-top");this.panels.addClass("ui-tabs-panel ui-widget-content ui-corner-bottom");if(c.selected===p){location.hash&&this.anchors.each(function(g,f){if(f.hash==location.hash){c.selected=g;return false}});if(typeof c.selected!=="number"&&c.cookie)c.selected=parseInt(a._cookie(),10);if(typeof c.selected!=="number"&&this.lis.filter(".ui-tabs-selected").length)c.selected=
-this.lis.index(this.lis.filter(".ui-tabs-selected"));c.selected=c.selected||(this.lis.length?0:-1)}else if(c.selected===null)c.selected=-1;c.selected=c.selected>=0&&this.anchors[c.selected]||c.selected<0?c.selected:0;c.disabled=d.unique(c.disabled.concat(d.map(this.lis.filter(".ui-state-disabled"),function(g){return a.lis.index(g)}))).sort();d.inArray(c.selected,c.disabled)!=-1&&c.disabled.splice(d.inArray(c.selected,c.disabled),1);this.panels.addClass("ui-tabs-hide");this.lis.removeClass("ui-tabs-selected ui-state-active");
-if(c.selected>=0&&this.anchors.length){a.element.find(a._sanitizeSelector(a.anchors[c.selected].hash)).removeClass("ui-tabs-hide");this.lis.eq(c.selected).addClass("ui-tabs-selected ui-state-active");a.element.queue("tabs",function(){a._trigger("show",null,a._ui(a.anchors[c.selected],a.element.find(a._sanitizeSelector(a.anchors[c.selected].hash))[0]))});this.load(c.selected)}d(window).bind("unload",function(){a.lis.add(a.anchors).unbind(".tabs");a.lis=a.anchors=a.panels=null})}else c.selected=this.lis.index(this.lis.filter(".ui-tabs-selected"));
-this.element[c.collapsible?"addClass":"removeClass"]("ui-tabs-collapsible");c.cookie&&this._cookie(c.selected,c.cookie);b=0;for(var j;j=this.lis[b];b++)d(j)[d.inArray(b,c.disabled)!=-1&&!d(j).hasClass("ui-tabs-selected")?"addClass":"removeClass"]("ui-state-disabled");c.cache===false&&this.anchors.removeData("cache.tabs");this.lis.add(this.anchors).unbind(".tabs");if(c.event!=="mouseover"){var k=function(g,f){f.is(":not(.ui-state-disabled)")&&f.addClass("ui-state-"+g)},n=function(g,f){f.removeClass("ui-state-"+
-g)};this.lis.bind("mouseover.tabs",function(){k("hover",d(this))});this.lis.bind("mouseout.tabs",function(){n("hover",d(this))});this.anchors.bind("focus.tabs",function(){k("focus",d(this).closest("li"))});this.anchors.bind("blur.tabs",function(){n("focus",d(this).closest("li"))})}var m,o;if(c.fx)if(d.isArray(c.fx)){m=c.fx[0];o=c.fx[1]}else m=o=c.fx;var r=o?function(g,f){d(g).closest("li").addClass("ui-tabs-selected ui-state-active");f.hide().removeClass("ui-tabs-hide").animate(o,o.duration||"normal",
-function(){e(f,o);a._trigger("show",null,a._ui(g,f[0]))})}:function(g,f){d(g).closest("li").addClass("ui-tabs-selected ui-state-active");f.removeClass("ui-tabs-hide");a._trigger("show",null,a._ui(g,f[0]))},s=m?function(g,f){f.animate(m,m.duration||"normal",function(){a.lis.removeClass("ui-tabs-selected ui-state-active");f.addClass("ui-tabs-hide");e(f,m);a.element.dequeue("tabs")})}:function(g,f){a.lis.removeClass("ui-tabs-selected ui-state-active");f.addClass("ui-tabs-hide");a.element.dequeue("tabs")};
-this.anchors.bind(c.event+".tabs",function(){var g=this,f=d(g).closest("li"),i=a.panels.filter(":not(.ui-tabs-hide)"),l=a.element.find(a._sanitizeSelector(g.hash));if(f.hasClass("ui-tabs-selected")&&!c.collapsible||f.hasClass("ui-state-disabled")||f.hasClass("ui-state-processing")||a.panels.filter(":animated").length||a._trigger("select",null,a._ui(this,l[0]))===false){this.blur();return false}c.selected=a.anchors.index(this);a.abort();if(c.collapsible)if(f.hasClass("ui-tabs-selected")){c.selected=
--1;c.cookie&&a._cookie(c.selected,c.cookie);a.element.queue("tabs",function(){s(g,i)}).dequeue("tabs");this.blur();return false}else if(!i.length){c.cookie&&a._cookie(c.selected,c.cookie);a.element.queue("tabs",function(){r(g,l)});a.load(a.anchors.index(this));this.blur();return false}c.cookie&&a._cookie(c.selected,c.cookie);if(l.length){i.length&&a.element.queue("tabs",function(){s(g,i)});a.element.queue("tabs",function(){r(g,l)});a.load(a.anchors.index(this))}else throw"jQuery UI Tabs: Mismatching fragment identifier.";
-d.browser.msie&&this.blur()});this.anchors.bind("click.tabs",function(){return false})},_getIndex:function(b){if(typeof b=="string")b=this.anchors.index(this.anchors.filter("[href$="+b+"]"));return b},destroy:function(){var b=this.options;this.abort();this.element.unbind(".tabs").removeClass("ui-tabs ui-widget ui-widget-content ui-corner-all ui-tabs-collapsible").removeData("tabs");this.list.removeClass("ui-tabs-nav ui-helper-reset ui-helper-clearfix ui-widget-header ui-corner-all");this.anchors.each(function(){var e=
-d.data(this,"href.tabs");if(e)this.href=e;var a=d(this).unbind(".tabs");d.each(["href","load","cache"],function(c,h){a.removeData(h+".tabs")})});this.lis.unbind(".tabs").add(this.panels).each(function(){d.data(this,"destroy.tabs")?d(this).remove():d(this).removeClass("ui-state-default ui-corner-top ui-tabs-selected ui-state-active ui-state-hover ui-state-focus ui-state-disabled ui-tabs-panel ui-widget-content ui-corner-bottom ui-tabs-hide")});b.cookie&&this._cookie(null,b.cookie);return this},add:function(b,
-e,a){if(a===p)a=this.anchors.length;var c=this,h=this.options;e=d(h.tabTemplate.replace(/#\{href\}/g,b).replace(/#\{label\}/g,e));b=!b.indexOf("#")?b.replace("#",""):this._tabId(d("a",e)[0]);e.addClass("ui-state-default ui-corner-top").data("destroy.tabs",true);var j=c.element.find("#"+b);j.length||(j=d(h.panelTemplate).attr("id",b).data("destroy.tabs",true));j.addClass("ui-tabs-panel ui-widget-content ui-corner-bottom ui-tabs-hide");if(a>=this.lis.length){e.appendTo(this.list);j.appendTo(this.list[0].parentNode)}else{e.insertBefore(this.lis[a]);
-j.insertBefore(this.panels[a])}h.disabled=d.map(h.disabled,function(k){return k>=a?++k:k});this._tabify();if(this.anchors.length==1){h.selected=0;e.addClass("ui-tabs-selected ui-state-active");j.removeClass("ui-tabs-hide");this.element.queue("tabs",function(){c._trigger("show",null,c._ui(c.anchors[0],c.panels[0]))});this.load(0)}this._trigger("add",null,this._ui(this.anchors[a],this.panels[a]));return this},remove:function(b){b=this._getIndex(b);var e=this.options,a=this.lis.eq(b).remove(),c=this.panels.eq(b).remove();
-if(a.hasClass("ui-tabs-selected")&&this.anchors.length>1)this.select(b+(b+1<this.anchors.length?1:-1));e.disabled=d.map(d.grep(e.disabled,function(h){return h!=b}),function(h){return h>=b?--h:h});this._tabify();this._trigger("remove",null,this._ui(a.find("a")[0],c[0]));return this},enable:function(b){b=this._getIndex(b);var e=this.options;if(d.inArray(b,e.disabled)!=-1){this.lis.eq(b).removeClass("ui-state-disabled");e.disabled=d.grep(e.disabled,function(a){return a!=b});this._trigger("enable",null,
-this._ui(this.anchors[b],this.panels[b]));return this}},disable:function(b){b=this._getIndex(b);var e=this.options;if(b!=e.selected){this.lis.eq(b).addClass("ui-state-disabled");e.disabled.push(b);e.disabled.sort();this._trigger("disable",null,this._ui(this.anchors[b],this.panels[b]))}return this},select:function(b){b=this._getIndex(b);if(b==-1)if(this.options.collapsible&&this.options.selected!=-1)b=this.options.selected;else return this;this.anchors.eq(b).trigger(this.options.event+".tabs");return this},
-load:function(b){b=this._getIndex(b);var e=this,a=this.options,c=this.anchors.eq(b)[0],h=d.data(c,"load.tabs");this.abort();if(!h||this.element.queue("tabs").length!==0&&d.data(c,"cache.tabs"))this.element.dequeue("tabs");else{this.lis.eq(b).addClass("ui-state-processing");if(a.spinner){var j=d("span",c);j.data("label.tabs",j.html()).html(a.spinner)}this.xhr=d.ajax(d.extend({},a.ajaxOptions,{url:h,success:function(k,n){e.element.find(e._sanitizeSelector(c.hash)).html(k);e._cleanup();a.cache&&d.data(c,
-"cache.tabs",true);e._trigger("load",null,e._ui(e.anchors[b],e.panels[b]));try{a.ajaxOptions.success(k,n)}catch(m){}},error:function(k,n){e._cleanup();e._trigger("load",null,e._ui(e.anchors[b],e.panels[b]));try{a.ajaxOptions.error(k,n,b,c)}catch(m){}}}));e.element.dequeue("tabs");return this}},abort:function(){this.element.queue([]);this.panels.stop(false,true);this.element.queue("tabs",this.element.queue("tabs").splice(-2,2));if(this.xhr){this.xhr.abort();delete this.xhr}this._cleanup();return this},
-url:function(b,e){this.anchors.eq(b).removeData("cache.tabs").data("load.tabs",e);return this},length:function(){return this.anchors.length}});d.extend(d.ui.tabs,{version:"1.8.11"});d.extend(d.ui.tabs.prototype,{rotation:null,rotate:function(b,e){var a=this,c=this.options,h=a._rotate||(a._rotate=function(j){clearTimeout(a.rotation);a.rotation=setTimeout(function(){var k=c.selected;a.select(++k<a.anchors.length?k:0)},b);j&&j.stopPropagation()});e=a._unrotate||(a._unrotate=!e?function(j){j.clientX&&
-a.rotate(null)}:function(){t=c.selected;h()});if(b){this.element.bind("tabsshow",h);this.anchors.bind(c.event+".tabs",e);h()}else{clearTimeout(a.rotation);this.element.unbind("tabsshow",h);this.anchors.unbind(c.event+".tabs",e);delete this._rotate;delete this._unrotate}return this}})})(jQuery);
-;/*
- * jQuery UI Datepicker 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Datepicker
- *
- * Depends:
- *	jquery.ui.core.js
- */
-(function(d,A){function K(){this.debug=false;this._curInst=null;this._keyEvent=false;this._disabledInputs=[];this._inDialog=this._datepickerShowing=false;this._mainDivId="ui-datepicker-div";this._inlineClass="ui-datepicker-inline";this._appendClass="ui-datepicker-append";this._triggerClass="ui-datepicker-trigger";this._dialogClass="ui-datepicker-dialog";this._disableClass="ui-datepicker-disabled";this._unselectableClass="ui-datepicker-unselectable";this._currentClass="ui-datepicker-current-day";this._dayOverClass=
-"ui-datepicker-days-cell-over";this.regional=[];this.regional[""]={closeText:"Done",prevText:"Prev",nextText:"Next",currentText:"Today",monthNames:["January","February","March","April","May","June","July","August","September","October","November","December"],monthNamesShort:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],dayNames:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],dayNamesShort:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],dayNamesMin:["Su",
-"Mo","Tu","We","Th","Fr","Sa"],weekHeader:"Wk",dateFormat:"mm/dd/yy",firstDay:0,isRTL:false,showMonthAfterYear:false,yearSuffix:""};this._defaults={showOn:"focus",showAnim:"fadeIn",showOptions:{},defaultDate:null,appendText:"",buttonText:"...",buttonImage:"",buttonImageOnly:false,hideIfNoPrevNext:false,navigationAsDateFormat:false,gotoCurrent:false,changeMonth:false,changeYear:false,yearRange:"c-10:c+10",showOtherMonths:false,selectOtherMonths:false,showWeek:false,calculateWeek:this.iso8601Week,shortYearCutoff:"+10",
-minDate:null,maxDate:null,duration:"fast",beforeShowDay:null,beforeShow:null,onSelect:null,onChangeMonthYear:null,onClose:null,numberOfMonths:1,showCurrentAtPos:0,stepMonths:1,stepBigMonths:12,altField:"",altFormat:"",constrainInput:true,showButtonPanel:false,autoSize:false};d.extend(this._defaults,this.regional[""]);this.dpDiv=d('<div id="'+this._mainDivId+'" class="ui-datepicker ui-widget ui-widget-content ui-helper-clearfix ui-corner-all"></div>')}function F(a,b){d.extend(a,b);for(var c in b)if(b[c]==
-null||b[c]==A)a[c]=b[c];return a}d.extend(d.ui,{datepicker:{version:"1.8.11"}});var y=(new Date).getTime();d.extend(K.prototype,{markerClassName:"hasDatepicker",log:function(){this.debug&&console.log.apply("",arguments)},_widgetDatepicker:function(){return this.dpDiv},setDefaults:function(a){F(this._defaults,a||{});return this},_attachDatepicker:function(a,b){var c=null;for(var e in this._defaults){var f=a.getAttribute("date:"+e);if(f){c=c||{};try{c[e]=eval(f)}catch(h){c[e]=f}}}e=a.nodeName.toLowerCase();
-f=e=="div"||e=="span";if(!a.id){this.uuid+=1;a.id="dp"+this.uuid}var i=this._newInst(d(a),f);i.settings=d.extend({},b||{},c||{});if(e=="input")this._connectDatepicker(a,i);else f&&this._inlineDatepicker(a,i)},_newInst:function(a,b){return{id:a[0].id.replace(/([^A-Za-z0-9_-])/g,"\\\\$1"),input:a,selectedDay:0,selectedMonth:0,selectedYear:0,drawMonth:0,drawYear:0,inline:b,dpDiv:!b?this.dpDiv:d('<div class="'+this._inlineClass+' ui-datepicker ui-widget ui-widget-content ui-helper-clearfix ui-corner-all"></div>')}},
-_connectDatepicker:function(a,b){var c=d(a);b.append=d([]);b.trigger=d([]);if(!c.hasClass(this.markerClassName)){this._attachments(c,b);c.addClass(this.markerClassName).keydown(this._doKeyDown).keypress(this._doKeyPress).keyup(this._doKeyUp).bind("setData.datepicker",function(e,f,h){b.settings[f]=h}).bind("getData.datepicker",function(e,f){return this._get(b,f)});this._autoSize(b);d.data(a,"datepicker",b)}},_attachments:function(a,b){var c=this._get(b,"appendText"),e=this._get(b,"isRTL");b.append&&
-b.append.remove();if(c){b.append=d('<span class="'+this._appendClass+'">'+c+"</span>");a[e?"before":"after"](b.append)}a.unbind("focus",this._showDatepicker);b.trigger&&b.trigger.remove();c=this._get(b,"showOn");if(c=="focus"||c=="both")a.focus(this._showDatepicker);if(c=="button"||c=="both"){c=this._get(b,"buttonText");var f=this._get(b,"buttonImage");b.trigger=d(this._get(b,"buttonImageOnly")?d("<img/>").addClass(this._triggerClass).attr({src:f,alt:c,title:c}):d('<button type="button"></button>').addClass(this._triggerClass).html(f==
-""?c:d("<img/>").attr({src:f,alt:c,title:c})));a[e?"before":"after"](b.trigger);b.trigger.click(function(){d.datepicker._datepickerShowing&&d.datepicker._lastInput==a[0]?d.datepicker._hideDatepicker():d.datepicker._showDatepicker(a[0]);return false})}},_autoSize:function(a){if(this._get(a,"autoSize")&&!a.inline){var b=new Date(2009,11,20),c=this._get(a,"dateFormat");if(c.match(/[DM]/)){var e=function(f){for(var h=0,i=0,g=0;g<f.length;g++)if(f[g].length>h){h=f[g].length;i=g}return i};b.setMonth(e(this._get(a,
-c.match(/MM/)?"monthNames":"monthNamesShort")));b.setDate(e(this._get(a,c.match(/DD/)?"dayNames":"dayNamesShort"))+20-b.getDay())}a.input.attr("size",this._formatDate(a,b).length)}},_inlineDatepicker:function(a,b){var c=d(a);if(!c.hasClass(this.markerClassName)){c.addClass(this.markerClassName).append(b.dpDiv).bind("setData.datepicker",function(e,f,h){b.settings[f]=h}).bind("getData.datepicker",function(e,f){return this._get(b,f)});d.data(a,"datepicker",b);this._setDate(b,this._getDefaultDate(b),
-true);this._updateDatepicker(b);this._updateAlternate(b);b.dpDiv.show()}},_dialogDatepicker:function(a,b,c,e,f){a=this._dialogInst;if(!a){this.uuid+=1;this._dialogInput=d('<input type="text" id="'+("dp"+this.uuid)+'" style="position: absolute; top: -100px; width: 0px; z-index: -10;"/>');this._dialogInput.keydown(this._doKeyDown);d("body").append(this._dialogInput);a=this._dialogInst=this._newInst(this._dialogInput,false);a.settings={};d.data(this._dialogInput[0],"datepicker",a)}F(a.settings,e||{});
-b=b&&b.constructor==Date?this._formatDate(a,b):b;this._dialogInput.val(b);this._pos=f?f.length?f:[f.pageX,f.pageY]:null;if(!this._pos)this._pos=[document.documentElement.clientWidth/2-100+(document.documentElement.scrollLeft||document.body.scrollLeft),document.documentElement.clientHeight/2-150+(document.documentElement.scrollTop||document.body.scrollTop)];this._dialogInput.css("left",this._pos[0]+20+"px").css("top",this._pos[1]+"px");a.settings.onSelect=c;this._inDialog=true;this.dpDiv.addClass(this._dialogClass);
-this._showDatepicker(this._dialogInput[0]);d.blockUI&&d.blockUI(this.dpDiv);d.data(this._dialogInput[0],"datepicker",a);return this},_destroyDatepicker:function(a){var b=d(a),c=d.data(a,"datepicker");if(b.hasClass(this.markerClassName)){var e=a.nodeName.toLowerCase();d.removeData(a,"datepicker");if(e=="input"){c.append.remove();c.trigger.remove();b.removeClass(this.markerClassName).unbind("focus",this._showDatepicker).unbind("keydown",this._doKeyDown).unbind("keypress",this._doKeyPress).unbind("keyup",
-this._doKeyUp)}else if(e=="div"||e=="span")b.removeClass(this.markerClassName).empty()}},_enableDatepicker:function(a){var b=d(a),c=d.data(a,"datepicker");if(b.hasClass(this.markerClassName)){var e=a.nodeName.toLowerCase();if(e=="input"){a.disabled=false;c.trigger.filter("button").each(function(){this.disabled=false}).end().filter("img").css({opacity:"1.0",cursor:""})}else if(e=="div"||e=="span")b.children("."+this._inlineClass).children().removeClass("ui-state-disabled");this._disabledInputs=d.map(this._disabledInputs,
-function(f){return f==a?null:f})}},_disableDatepicker:function(a){var b=d(a),c=d.data(a,"datepicker");if(b.hasClass(this.markerClassName)){var e=a.nodeName.toLowerCase();if(e=="input"){a.disabled=true;c.trigger.filter("button").each(function(){this.disabled=true}).end().filter("img").css({opacity:"0.5",cursor:"default"})}else if(e=="div"||e=="span")b.children("."+this._inlineClass).children().addClass("ui-state-disabled");this._disabledInputs=d.map(this._disabledInputs,function(f){return f==a?null:
-f});this._disabledInputs[this._disabledInputs.length]=a}},_isDisabledDatepicker:function(a){if(!a)return false;for(var b=0;b<this._disabledInputs.length;b++)if(this._disabledInputs[b]==a)return true;return false},_getInst:function(a){try{return d.data(a,"datepicker")}catch(b){throw"Missing instance data for this datepicker";}},_optionDatepicker:function(a,b,c){var e=this._getInst(a);if(arguments.length==2&&typeof b=="string")return b=="defaults"?d.extend({},d.datepicker._defaults):e?b=="all"?d.extend({},
-e.settings):this._get(e,b):null;var f=b||{};if(typeof b=="string"){f={};f[b]=c}if(e){this._curInst==e&&this._hideDatepicker();var h=this._getDateDatepicker(a,true),i=this._getMinMaxDate(e,"min"),g=this._getMinMaxDate(e,"max");F(e.settings,f);if(i!==null&&f.dateFormat!==A&&f.minDate===A)e.settings.minDate=this._formatDate(e,i);if(g!==null&&f.dateFormat!==A&&f.maxDate===A)e.settings.maxDate=this._formatDate(e,g);this._attachments(d(a),e);this._autoSize(e);this._setDateDatepicker(a,h);this._updateDatepicker(e)}},
-_changeDatepicker:function(a,b,c){this._optionDatepicker(a,b,c)},_refreshDatepicker:function(a){(a=this._getInst(a))&&this._updateDatepicker(a)},_setDateDatepicker:function(a,b){if(a=this._getInst(a)){this._setDate(a,b);this._updateDatepicker(a);this._updateAlternate(a)}},_getDateDatepicker:function(a,b){(a=this._getInst(a))&&!a.inline&&this._setDateFromField(a,b);return a?this._getDate(a):null},_doKeyDown:function(a){var b=d.datepicker._getInst(a.target),c=true,e=b.dpDiv.is(".ui-datepicker-rtl");
-b._keyEvent=true;if(d.datepicker._datepickerShowing)switch(a.keyCode){case 9:d.datepicker._hideDatepicker();c=false;break;case 13:c=d("td."+d.datepicker._dayOverClass+":not(."+d.datepicker._currentClass+")",b.dpDiv);c[0]?d.datepicker._selectDay(a.target,b.selectedMonth,b.selectedYear,c[0]):d.datepicker._hideDatepicker();return false;case 27:d.datepicker._hideDatepicker();break;case 33:d.datepicker._adjustDate(a.target,a.ctrlKey?-d.datepicker._get(b,"stepBigMonths"):-d.datepicker._get(b,"stepMonths"),
-"M");break;case 34:d.datepicker._adjustDate(a.target,a.ctrlKey?+d.datepicker._get(b,"stepBigMonths"):+d.datepicker._get(b,"stepMonths"),"M");break;case 35:if(a.ctrlKey||a.metaKey)d.datepicker._clearDate(a.target);c=a.ctrlKey||a.metaKey;break;case 36:if(a.ctrlKey||a.metaKey)d.datepicker._gotoToday(a.target);c=a.ctrlKey||a.metaKey;break;case 37:if(a.ctrlKey||a.metaKey)d.datepicker._adjustDate(a.target,e?+1:-1,"D");c=a.ctrlKey||a.metaKey;if(a.originalEvent.altKey)d.datepicker._adjustDate(a.target,a.ctrlKey?
--d.datepicker._get(b,"stepBigMonths"):-d.datepicker._get(b,"stepMonths"),"M");break;case 38:if(a.ctrlKey||a.metaKey)d.datepicker._adjustDate(a.target,-7,"D");c=a.ctrlKey||a.metaKey;break;case 39:if(a.ctrlKey||a.metaKey)d.datepicker._adjustDate(a.target,e?-1:+1,"D");c=a.ctrlKey||a.metaKey;if(a.originalEvent.altKey)d.datepicker._adjustDate(a.target,a.ctrlKey?+d.datepicker._get(b,"stepBigMonths"):+d.datepicker._get(b,"stepMonths"),"M");break;case 40:if(a.ctrlKey||a.metaKey)d.datepicker._adjustDate(a.target,
-+7,"D");c=a.ctrlKey||a.metaKey;break;default:c=false}else if(a.keyCode==36&&a.ctrlKey)d.datepicker._showDatepicker(this);else c=false;if(c){a.preventDefault();a.stopPropagation()}},_doKeyPress:function(a){var b=d.datepicker._getInst(a.target);if(d.datepicker._get(b,"constrainInput")){b=d.datepicker._possibleChars(d.datepicker._get(b,"dateFormat"));var c=String.fromCharCode(a.charCode==A?a.keyCode:a.charCode);return a.ctrlKey||a.metaKey||c<" "||!b||b.indexOf(c)>-1}},_doKeyUp:function(a){a=d.datepicker._getInst(a.target);
-if(a.input.val()!=a.lastVal)try{if(d.datepicker.parseDate(d.datepicker._get(a,"dateFormat"),a.input?a.input.val():null,d.datepicker._getFormatConfig(a))){d.datepicker._setDateFromField(a);d.datepicker._updateAlternate(a);d.datepicker._updateDatepicker(a)}}catch(b){d.datepicker.log(b)}return true},_showDatepicker:function(a){a=a.target||a;if(a.nodeName.toLowerCase()!="input")a=d("input",a.parentNode)[0];if(!(d.datepicker._isDisabledDatepicker(a)||d.datepicker._lastInput==a)){var b=d.datepicker._getInst(a);
-d.datepicker._curInst&&d.datepicker._curInst!=b&&d.datepicker._curInst.dpDiv.stop(true,true);var c=d.datepicker._get(b,"beforeShow");F(b.settings,c?c.apply(a,[a,b]):{});b.lastVal=null;d.datepicker._lastInput=a;d.datepicker._setDateFromField(b);if(d.datepicker._inDialog)a.value="";if(!d.datepicker._pos){d.datepicker._pos=d.datepicker._findPos(a);d.datepicker._pos[1]+=a.offsetHeight}var e=false;d(a).parents().each(function(){e|=d(this).css("position")=="fixed";return!e});if(e&&d.browser.opera){d.datepicker._pos[0]-=
-document.documentElement.scrollLeft;d.datepicker._pos[1]-=document.documentElement.scrollTop}c={left:d.datepicker._pos[0],top:d.datepicker._pos[1]};d.datepicker._pos=null;b.dpDiv.empty();b.dpDiv.css({position:"absolute",display:"block",top:"-1000px"});d.datepicker._updateDatepicker(b);c=d.datepicker._checkOffset(b,c,e);b.dpDiv.css({position:d.datepicker._inDialog&&d.blockUI?"static":e?"fixed":"absolute",display:"none",left:c.left+"px",top:c.top+"px"});if(!b.inline){c=d.datepicker._get(b,"showAnim");
-var f=d.datepicker._get(b,"duration"),h=function(){d.datepicker._datepickerShowing=true;var i=b.dpDiv.find("iframe.ui-datepicker-cover");if(i.length){var g=d.datepicker._getBorders(b.dpDiv);i.css({left:-g[0],top:-g[1],width:b.dpDiv.outerWidth(),height:b.dpDiv.outerHeight()})}};b.dpDiv.zIndex(d(a).zIndex()+1);d.effects&&d.effects[c]?b.dpDiv.show(c,d.datepicker._get(b,"showOptions"),f,h):b.dpDiv[c||"show"](c?f:null,h);if(!c||!f)h();b.input.is(":visible")&&!b.input.is(":disabled")&&b.input.focus();d.datepicker._curInst=
-b}}},_updateDatepicker:function(a){var b=this,c=d.datepicker._getBorders(a.dpDiv);a.dpDiv.empty().append(this._generateHTML(a));var e=a.dpDiv.find("iframe.ui-datepicker-cover");e.length&&e.css({left:-c[0],top:-c[1],width:a.dpDiv.outerWidth(),height:a.dpDiv.outerHeight()});a.dpDiv.find("button, .ui-datepicker-prev, .ui-datepicker-next, .ui-datepicker-calendar td a").bind("mouseout",function(){d(this).removeClass("ui-state-hover");this.className.indexOf("ui-datepicker-prev")!=-1&&d(this).removeClass("ui-datepicker-prev-hover");
-this.className.indexOf("ui-datepicker-next")!=-1&&d(this).removeClass("ui-datepicker-next-hover")}).bind("mouseover",function(){if(!b._isDisabledDatepicker(a.inline?a.dpDiv.parent()[0]:a.input[0])){d(this).parents(".ui-datepicker-calendar").find("a").removeClass("ui-state-hover");d(this).addClass("ui-state-hover");this.className.indexOf("ui-datepicker-prev")!=-1&&d(this).addClass("ui-datepicker-prev-hover");this.className.indexOf("ui-datepicker-next")!=-1&&d(this).addClass("ui-datepicker-next-hover")}}).end().find("."+
-this._dayOverClass+" a").trigger("mouseover").end();c=this._getNumberOfMonths(a);e=c[1];e>1?a.dpDiv.addClass("ui-datepicker-multi-"+e).css("width",17*e+"em"):a.dpDiv.removeClass("ui-datepicker-multi-2 ui-datepicker-multi-3 ui-datepicker-multi-4").width("");a.dpDiv[(c[0]!=1||c[1]!=1?"add":"remove")+"Class"]("ui-datepicker-multi");a.dpDiv[(this._get(a,"isRTL")?"add":"remove")+"Class"]("ui-datepicker-rtl");a==d.datepicker._curInst&&d.datepicker._datepickerShowing&&a.input&&a.input.is(":visible")&&!a.input.is(":disabled")&&
-a.input[0]!=document.activeElement&&a.input.focus();if(a.yearshtml){var f=a.yearshtml;setTimeout(function(){f===a.yearshtml&&a.dpDiv.find("select.ui-datepicker-year:first").replaceWith(a.yearshtml);f=a.yearshtml=null},0)}},_getBorders:function(a){var b=function(c){return{thin:1,medium:2,thick:3}[c]||c};return[parseFloat(b(a.css("border-left-width"))),parseFloat(b(a.css("border-top-width")))]},_checkOffset:function(a,b,c){var e=a.dpDiv.outerWidth(),f=a.dpDiv.outerHeight(),h=a.input?a.input.outerWidth():
-0,i=a.input?a.input.outerHeight():0,g=document.documentElement.clientWidth+d(document).scrollLeft(),j=document.documentElement.clientHeight+d(document).scrollTop();b.left-=this._get(a,"isRTL")?e-h:0;b.left-=c&&b.left==a.input.offset().left?d(document).scrollLeft():0;b.top-=c&&b.top==a.input.offset().top+i?d(document).scrollTop():0;b.left-=Math.min(b.left,b.left+e>g&&g>e?Math.abs(b.left+e-g):0);b.top-=Math.min(b.top,b.top+f>j&&j>f?Math.abs(f+i):0);return b},_findPos:function(a){for(var b=this._get(this._getInst(a),
-"isRTL");a&&(a.type=="hidden"||a.nodeType!=1||d.expr.filters.hidden(a));)a=a[b?"previousSibling":"nextSibling"];a=d(a).offset();return[a.left,a.top]},_hideDatepicker:function(a){var b=this._curInst;if(!(!b||a&&b!=d.data(a,"datepicker")))if(this._datepickerShowing){a=this._get(b,"showAnim");var c=this._get(b,"duration"),e=function(){d.datepicker._tidyDialog(b);this._curInst=null};d.effects&&d.effects[a]?b.dpDiv.hide(a,d.datepicker._get(b,"showOptions"),c,e):b.dpDiv[a=="slideDown"?"slideUp":a=="fadeIn"?
-"fadeOut":"hide"](a?c:null,e);a||e();if(a=this._get(b,"onClose"))a.apply(b.input?b.input[0]:null,[b.input?b.input.val():"",b]);this._datepickerShowing=false;this._lastInput=null;if(this._inDialog){this._dialogInput.css({position:"absolute",left:"0",top:"-100px"});if(d.blockUI){d.unblockUI();d("body").append(this.dpDiv)}}this._inDialog=false}},_tidyDialog:function(a){a.dpDiv.removeClass(this._dialogClass).unbind(".ui-datepicker-calendar")},_checkExternalClick:function(a){if(d.datepicker._curInst){a=
-d(a.target);a[0].id!=d.datepicker._mainDivId&&a.parents("#"+d.datepicker._mainDivId).length==0&&!a.hasClass(d.datepicker.markerClassName)&&!a.hasClass(d.datepicker._triggerClass)&&d.datepicker._datepickerShowing&&!(d.datepicker._inDialog&&d.blockUI)&&d.datepicker._hideDatepicker()}},_adjustDate:function(a,b,c){a=d(a);var e=this._getInst(a[0]);if(!this._isDisabledDatepicker(a[0])){this._adjustInstDate(e,b+(c=="M"?this._get(e,"showCurrentAtPos"):0),c);this._updateDatepicker(e)}},_gotoToday:function(a){a=
-d(a);var b=this._getInst(a[0]);if(this._get(b,"gotoCurrent")&&b.currentDay){b.selectedDay=b.currentDay;b.drawMonth=b.selectedMonth=b.currentMonth;b.drawYear=b.selectedYear=b.currentYear}else{var c=new Date;b.selectedDay=c.getDate();b.drawMonth=b.selectedMonth=c.getMonth();b.drawYear=b.selectedYear=c.getFullYear()}this._notifyChange(b);this._adjustDate(a)},_selectMonthYear:function(a,b,c){a=d(a);var e=this._getInst(a[0]);e._selectingMonthYear=false;e["selected"+(c=="M"?"Month":"Year")]=e["draw"+(c==
-"M"?"Month":"Year")]=parseInt(b.options[b.selectedIndex].value,10);this._notifyChange(e);this._adjustDate(a)},_clickMonthYear:function(a){var b=this._getInst(d(a)[0]);b.input&&b._selectingMonthYear&&setTimeout(function(){b.input.focus()},0);b._selectingMonthYear=!b._selectingMonthYear},_selectDay:function(a,b,c,e){var f=d(a);if(!(d(e).hasClass(this._unselectableClass)||this._isDisabledDatepicker(f[0]))){f=this._getInst(f[0]);f.selectedDay=f.currentDay=d("a",e).html();f.selectedMonth=f.currentMonth=
-b;f.selectedYear=f.currentYear=c;this._selectDate(a,this._formatDate(f,f.currentDay,f.currentMonth,f.currentYear))}},_clearDate:function(a){a=d(a);this._getInst(a[0]);this._selectDate(a,"")},_selectDate:function(a,b){a=this._getInst(d(a)[0]);b=b!=null?b:this._formatDate(a);a.input&&a.input.val(b);this._updateAlternate(a);var c=this._get(a,"onSelect");if(c)c.apply(a.input?a.input[0]:null,[b,a]);else a.input&&a.input.trigger("change");if(a.inline)this._updateDatepicker(a);else{this._hideDatepicker();
-this._lastInput=a.input[0];typeof a.input[0]!="object"&&a.input.focus();this._lastInput=null}},_updateAlternate:function(a){var b=this._get(a,"altField");if(b){var c=this._get(a,"altFormat")||this._get(a,"dateFormat"),e=this._getDate(a),f=this.formatDate(c,e,this._getFormatConfig(a));d(b).each(function(){d(this).val(f)})}},noWeekends:function(a){a=a.getDay();return[a>0&&a<6,""]},iso8601Week:function(a){a=new Date(a.getTime());a.setDate(a.getDate()+4-(a.getDay()||7));var b=a.getTime();a.setMonth(0);
-a.setDate(1);return Math.floor(Math.round((b-a)/864E5)/7)+1},parseDate:function(a,b,c){if(a==null||b==null)throw"Invalid arguments";b=typeof b=="object"?b.toString():b+"";if(b=="")return null;var e=(c?c.shortYearCutoff:null)||this._defaults.shortYearCutoff;e=typeof e!="string"?e:(new Date).getFullYear()%100+parseInt(e,10);for(var f=(c?c.dayNamesShort:null)||this._defaults.dayNamesShort,h=(c?c.dayNames:null)||this._defaults.dayNames,i=(c?c.monthNamesShort:null)||this._defaults.monthNamesShort,g=(c?
-c.monthNames:null)||this._defaults.monthNames,j=c=-1,l=-1,u=-1,k=false,o=function(p){(p=z+1<a.length&&a.charAt(z+1)==p)&&z++;return p},m=function(p){var v=o(p);p=new RegExp("^\\d{1,"+(p=="@"?14:p=="!"?20:p=="y"&&v?4:p=="o"?3:2)+"}");p=b.substring(s).match(p);if(!p)throw"Missing number at position "+s;s+=p[0].length;return parseInt(p[0],10)},n=function(p,v,H){p=o(p)?H:v;for(v=0;v<p.length;v++)if(b.substr(s,p[v].length).toLowerCase()==p[v].toLowerCase()){s+=p[v].length;return v+1}throw"Unknown name at position "+
-s;},r=function(){if(b.charAt(s)!=a.charAt(z))throw"Unexpected literal at position "+s;s++},s=0,z=0;z<a.length;z++)if(k)if(a.charAt(z)=="'"&&!o("'"))k=false;else r();else switch(a.charAt(z)){case "d":l=m("d");break;case "D":n("D",f,h);break;case "o":u=m("o");break;case "m":j=m("m");break;case "M":j=n("M",i,g);break;case "y":c=m("y");break;case "@":var w=new Date(m("@"));c=w.getFullYear();j=w.getMonth()+1;l=w.getDate();break;case "!":w=new Date((m("!")-this._ticksTo1970)/1E4);c=w.getFullYear();j=w.getMonth()+
-1;l=w.getDate();break;case "'":if(o("'"))r();else k=true;break;default:r()}if(c==-1)c=(new Date).getFullYear();else if(c<100)c+=(new Date).getFullYear()-(new Date).getFullYear()%100+(c<=e?0:-100);if(u>-1){j=1;l=u;do{e=this._getDaysInMonth(c,j-1);if(l<=e)break;j++;l-=e}while(1)}w=this._daylightSavingAdjust(new Date(c,j-1,l));if(w.getFullYear()!=c||w.getMonth()+1!=j||w.getDate()!=l)throw"Invalid date";return w},ATOM:"yy-mm-dd",COOKIE:"D, dd M yy",ISO_8601:"yy-mm-dd",RFC_822:"D, d M y",RFC_850:"DD, dd-M-y",
-RFC_1036:"D, d M y",RFC_1123:"D, d M yy",RFC_2822:"D, d M yy",RSS:"D, d M y",TICKS:"!",TIMESTAMP:"@",W3C:"yy-mm-dd",_ticksTo1970:(718685+Math.floor(492.5)-Math.floor(19.7)+Math.floor(4.925))*24*60*60*1E7,formatDate:function(a,b,c){if(!b)return"";var e=(c?c.dayNamesShort:null)||this._defaults.dayNamesShort,f=(c?c.dayNames:null)||this._defaults.dayNames,h=(c?c.monthNamesShort:null)||this._defaults.monthNamesShort;c=(c?c.monthNames:null)||this._defaults.monthNames;var i=function(o){(o=k+1<a.length&&
-a.charAt(k+1)==o)&&k++;return o},g=function(o,m,n){m=""+m;if(i(o))for(;m.length<n;)m="0"+m;return m},j=function(o,m,n,r){return i(o)?r[m]:n[m]},l="",u=false;if(b)for(var k=0;k<a.length;k++)if(u)if(a.charAt(k)=="'"&&!i("'"))u=false;else l+=a.charAt(k);else switch(a.charAt(k)){case "d":l+=g("d",b.getDate(),2);break;case "D":l+=j("D",b.getDay(),e,f);break;case "o":l+=g("o",(b.getTime()-(new Date(b.getFullYear(),0,0)).getTime())/864E5,3);break;case "m":l+=g("m",b.getMonth()+1,2);break;case "M":l+=j("M",
-b.getMonth(),h,c);break;case "y":l+=i("y")?b.getFullYear():(b.getYear()%100<10?"0":"")+b.getYear()%100;break;case "@":l+=b.getTime();break;case "!":l+=b.getTime()*1E4+this._ticksTo1970;break;case "'":if(i("'"))l+="'";else u=true;break;default:l+=a.charAt(k)}return l},_possibleChars:function(a){for(var b="",c=false,e=function(h){(h=f+1<a.length&&a.charAt(f+1)==h)&&f++;return h},f=0;f<a.length;f++)if(c)if(a.charAt(f)=="'"&&!e("'"))c=false;else b+=a.charAt(f);else switch(a.charAt(f)){case "d":case "m":case "y":case "@":b+=
-"0123456789";break;case "D":case "M":return null;case "'":if(e("'"))b+="'";else c=true;break;default:b+=a.charAt(f)}return b},_get:function(a,b){return a.settings[b]!==A?a.settings[b]:this._defaults[b]},_setDateFromField:function(a,b){if(a.input.val()!=a.lastVal){var c=this._get(a,"dateFormat"),e=a.lastVal=a.input?a.input.val():null,f,h;f=h=this._getDefaultDate(a);var i=this._getFormatConfig(a);try{f=this.parseDate(c,e,i)||h}catch(g){this.log(g);e=b?"":e}a.selectedDay=f.getDate();a.drawMonth=a.selectedMonth=
-f.getMonth();a.drawYear=a.selectedYear=f.getFullYear();a.currentDay=e?f.getDate():0;a.currentMonth=e?f.getMonth():0;a.currentYear=e?f.getFullYear():0;this._adjustInstDate(a)}},_getDefaultDate:function(a){return this._restrictMinMax(a,this._determineDate(a,this._get(a,"defaultDate"),new Date))},_determineDate:function(a,b,c){var e=function(h){var i=new Date;i.setDate(i.getDate()+h);return i},f=function(h){try{return d.datepicker.parseDate(d.datepicker._get(a,"dateFormat"),h,d.datepicker._getFormatConfig(a))}catch(i){}var g=
-(h.toLowerCase().match(/^c/)?d.datepicker._getDate(a):null)||new Date,j=g.getFullYear(),l=g.getMonth();g=g.getDate();for(var u=/([+-]?[0-9]+)\s*(d|D|w|W|m|M|y|Y)?/g,k=u.exec(h);k;){switch(k[2]||"d"){case "d":case "D":g+=parseInt(k[1],10);break;case "w":case "W":g+=parseInt(k[1],10)*7;break;case "m":case "M":l+=parseInt(k[1],10);g=Math.min(g,d.datepicker._getDaysInMonth(j,l));break;case "y":case "Y":j+=parseInt(k[1],10);g=Math.min(g,d.datepicker._getDaysInMonth(j,l));break}k=u.exec(h)}return new Date(j,
-l,g)};if(b=(b=b==null||b===""?c:typeof b=="string"?f(b):typeof b=="number"?isNaN(b)?c:e(b):new Date(b.getTime()))&&b.toString()=="Invalid Date"?c:b){b.setHours(0);b.setMinutes(0);b.setSeconds(0);b.setMilliseconds(0)}return this._daylightSavingAdjust(b)},_daylightSavingAdjust:function(a){if(!a)return null;a.setHours(a.getHours()>12?a.getHours()+2:0);return a},_setDate:function(a,b,c){var e=!b,f=a.selectedMonth,h=a.selectedYear;b=this._restrictMinMax(a,this._determineDate(a,b,new Date));a.selectedDay=
-a.currentDay=b.getDate();a.drawMonth=a.selectedMonth=a.currentMonth=b.getMonth();a.drawYear=a.selectedYear=a.currentYear=b.getFullYear();if((f!=a.selectedMonth||h!=a.selectedYear)&&!c)this._notifyChange(a);this._adjustInstDate(a);if(a.input)a.input.val(e?"":this._formatDate(a))},_getDate:function(a){return!a.currentYear||a.input&&a.input.val()==""?null:this._daylightSavingAdjust(new Date(a.currentYear,a.currentMonth,a.currentDay))},_generateHTML:function(a){var b=new Date;b=this._daylightSavingAdjust(new Date(b.getFullYear(),
-b.getMonth(),b.getDate()));var c=this._get(a,"isRTL"),e=this._get(a,"showButtonPanel"),f=this._get(a,"hideIfNoPrevNext"),h=this._get(a,"navigationAsDateFormat"),i=this._getNumberOfMonths(a),g=this._get(a,"showCurrentAtPos"),j=this._get(a,"stepMonths"),l=i[0]!=1||i[1]!=1,u=this._daylightSavingAdjust(!a.currentDay?new Date(9999,9,9):new Date(a.currentYear,a.currentMonth,a.currentDay)),k=this._getMinMaxDate(a,"min"),o=this._getMinMaxDate(a,"max");g=a.drawMonth-g;var m=a.drawYear;if(g<0){g+=12;m--}if(o){var n=
-this._daylightSavingAdjust(new Date(o.getFullYear(),o.getMonth()-i[0]*i[1]+1,o.getDate()));for(n=k&&n<k?k:n;this._daylightSavingAdjust(new Date(m,g,1))>n;){g--;if(g<0){g=11;m--}}}a.drawMonth=g;a.drawYear=m;n=this._get(a,"prevText");n=!h?n:this.formatDate(n,this._daylightSavingAdjust(new Date(m,g-j,1)),this._getFormatConfig(a));n=this._canAdjustMonth(a,-1,m,g)?'<a class="ui-datepicker-prev ui-corner-all" onclick="DP_jQuery_'+y+".datepicker._adjustDate('#"+a.id+"', -"+j+", 'M');\" title=\""+n+'"><span class="ui-icon ui-icon-circle-triangle-'+
-(c?"e":"w")+'">'+n+"</span></a>":f?"":'<a class="ui-datepicker-prev ui-corner-all ui-state-disabled" title="'+n+'"><span class="ui-icon ui-icon-circle-triangle-'+(c?"e":"w")+'">'+n+"</span></a>";var r=this._get(a,"nextText");r=!h?r:this.formatDate(r,this._daylightSavingAdjust(new Date(m,g+j,1)),this._getFormatConfig(a));f=this._canAdjustMonth(a,+1,m,g)?'<a class="ui-datepicker-next ui-corner-all" onclick="DP_jQuery_'+y+".datepicker._adjustDate('#"+a.id+"', +"+j+", 'M');\" title=\""+r+'"><span class="ui-icon ui-icon-circle-triangle-'+
-(c?"w":"e")+'">'+r+"</span></a>":f?"":'<a class="ui-datepicker-next ui-corner-all ui-state-disabled" title="'+r+'"><span class="ui-icon ui-icon-circle-triangle-'+(c?"w":"e")+'">'+r+"</span></a>";j=this._get(a,"currentText");r=this._get(a,"gotoCurrent")&&a.currentDay?u:b;j=!h?j:this.formatDate(j,r,this._getFormatConfig(a));h=!a.inline?'<button type="button" class="ui-datepicker-close ui-state-default ui-priority-primary ui-corner-all" onclick="DP_jQuery_'+y+'.datepicker._hideDatepicker();">'+this._get(a,
-"closeText")+"</button>":"";e=e?'<div class="ui-datepicker-buttonpane ui-widget-content">'+(c?h:"")+(this._isInRange(a,r)?'<button type="button" class="ui-datepicker-current ui-state-default ui-priority-secondary ui-corner-all" onclick="DP_jQuery_'+y+".datepicker._gotoToday('#"+a.id+"');\">"+j+"</button>":"")+(c?"":h)+"</div>":"";h=parseInt(this._get(a,"firstDay"),10);h=isNaN(h)?0:h;j=this._get(a,"showWeek");r=this._get(a,"dayNames");this._get(a,"dayNamesShort");var s=this._get(a,"dayNamesMin"),z=
-this._get(a,"monthNames"),w=this._get(a,"monthNamesShort"),p=this._get(a,"beforeShowDay"),v=this._get(a,"showOtherMonths"),H=this._get(a,"selectOtherMonths");this._get(a,"calculateWeek");for(var L=this._getDefaultDate(a),I="",D=0;D<i[0];D++){for(var M="",E=0;E<i[1];E++){var N=this._daylightSavingAdjust(new Date(m,g,a.selectedDay)),t=" ui-corner-all",x="";if(l){x+='<div class="ui-datepicker-group';if(i[1]>1)switch(E){case 0:x+=" ui-datepicker-group-first";t=" ui-corner-"+(c?"right":"left");break;case i[1]-
-1:x+=" ui-datepicker-group-last";t=" ui-corner-"+(c?"left":"right");break;default:x+=" ui-datepicker-group-middle";t="";break}x+='">'}x+='<div class="ui-datepicker-header ui-widget-header ui-helper-clearfix'+t+'">'+(/all|left/.test(t)&&D==0?c?f:n:"")+(/all|right/.test(t)&&D==0?c?n:f:"")+this._generateMonthYearHeader(a,g,m,k,o,D>0||E>0,z,w)+'</div><table class="ui-datepicker-calendar"><thead><tr>';var B=j?'<th class="ui-datepicker-week-col">'+this._get(a,"weekHeader")+"</th>":"";for(t=0;t<7;t++){var q=
-(t+h)%7;B+="<th"+((t+h+6)%7>=5?' class="ui-datepicker-week-end"':"")+'><span title="'+r[q]+'">'+s[q]+"</span></th>"}x+=B+"</tr></thead><tbody>";B=this._getDaysInMonth(m,g);if(m==a.selectedYear&&g==a.selectedMonth)a.selectedDay=Math.min(a.selectedDay,B);t=(this._getFirstDayOfMonth(m,g)-h+7)%7;B=l?6:Math.ceil((t+B)/7);q=this._daylightSavingAdjust(new Date(m,g,1-t));for(var O=0;O<B;O++){x+="<tr>";var P=!j?"":'<td class="ui-datepicker-week-col">'+this._get(a,"calculateWeek")(q)+"</td>";for(t=0;t<7;t++){var G=
-p?p.apply(a.input?a.input[0]:null,[q]):[true,""],C=q.getMonth()!=g,J=C&&!H||!G[0]||k&&q<k||o&&q>o;P+='<td class="'+((t+h+6)%7>=5?" ui-datepicker-week-end":"")+(C?" ui-datepicker-other-month":"")+(q.getTime()==N.getTime()&&g==a.selectedMonth&&a._keyEvent||L.getTime()==q.getTime()&&L.getTime()==N.getTime()?" "+this._dayOverClass:"")+(J?" "+this._unselectableClass+" ui-state-disabled":"")+(C&&!v?"":" "+G[1]+(q.getTime()==u.getTime()?" "+this._currentClass:"")+(q.getTime()==b.getTime()?" ui-datepicker-today":
-""))+'"'+((!C||v)&&G[2]?' title="'+G[2]+'"':"")+(J?"":' onclick="DP_jQuery_'+y+".datepicker._selectDay('#"+a.id+"',"+q.getMonth()+","+q.getFullYear()+', this);return false;"')+">"+(C&&!v?"&#xa0;":J?'<span class="ui-state-default">'+q.getDate()+"</span>":'<a class="ui-state-default'+(q.getTime()==b.getTime()?" ui-state-highlight":"")+(q.getTime()==u.getTime()?" ui-state-active":"")+(C?" ui-priority-secondary":"")+'" href="#">'+q.getDate()+"</a>")+"</td>";q.setDate(q.getDate()+1);q=this._daylightSavingAdjust(q)}x+=
-P+"</tr>"}g++;if(g>11){g=0;m++}x+="</tbody></table>"+(l?"</div>"+(i[0]>0&&E==i[1]-1?'<div class="ui-datepicker-row-break"></div>':""):"");M+=x}I+=M}I+=e+(d.browser.msie&&parseInt(d.browser.version,10)<7&&!a.inline?'<iframe src="javascript:false;" class="ui-datepicker-cover" frameborder="0"></iframe>':"");a._keyEvent=false;return I},_generateMonthYearHeader:function(a,b,c,e,f,h,i,g){var j=this._get(a,"changeMonth"),l=this._get(a,"changeYear"),u=this._get(a,"showMonthAfterYear"),k='<div class="ui-datepicker-title">',
-o="";if(h||!j)o+='<span class="ui-datepicker-month">'+i[b]+"</span>";else{i=e&&e.getFullYear()==c;var m=f&&f.getFullYear()==c;o+='<select class="ui-datepicker-month" onchange="DP_jQuery_'+y+".datepicker._selectMonthYear('#"+a.id+"', this, 'M');\" onclick=\"DP_jQuery_"+y+".datepicker._clickMonthYear('#"+a.id+"');\">";for(var n=0;n<12;n++)if((!i||n>=e.getMonth())&&(!m||n<=f.getMonth()))o+='<option value="'+n+'"'+(n==b?' selected="selected"':"")+">"+g[n]+"</option>";o+="</select>"}u||(k+=o+(h||!(j&&
-l)?"&#xa0;":""));a.yearshtml="";if(h||!l)k+='<span class="ui-datepicker-year">'+c+"</span>";else{g=this._get(a,"yearRange").split(":");var r=(new Date).getFullYear();i=function(s){s=s.match(/c[+-].*/)?c+parseInt(s.substring(1),10):s.match(/[+-].*/)?r+parseInt(s,10):parseInt(s,10);return isNaN(s)?r:s};b=i(g[0]);g=Math.max(b,i(g[1]||""));b=e?Math.max(b,e.getFullYear()):b;g=f?Math.min(g,f.getFullYear()):g;for(a.yearshtml+='<select class="ui-datepicker-year" onchange="DP_jQuery_'+y+".datepicker._selectMonthYear('#"+
-a.id+"', this, 'Y');\" onclick=\"DP_jQuery_"+y+".datepicker._clickMonthYear('#"+a.id+"');\">";b<=g;b++)a.yearshtml+='<option value="'+b+'"'+(b==c?' selected="selected"':"")+">"+b+"</option>";a.yearshtml+="</select>";if(d.browser.mozilla)k+='<select class="ui-datepicker-year"><option value="'+c+'" selected="selected">'+c+"</option></select>";else{k+=a.yearshtml;a.yearshtml=null}}k+=this._get(a,"yearSuffix");if(u)k+=(h||!(j&&l)?"&#xa0;":"")+o;k+="</div>";return k},_adjustInstDate:function(a,b,c){var e=
-a.drawYear+(c=="Y"?b:0),f=a.drawMonth+(c=="M"?b:0);b=Math.min(a.selectedDay,this._getDaysInMonth(e,f))+(c=="D"?b:0);e=this._restrictMinMax(a,this._daylightSavingAdjust(new Date(e,f,b)));a.selectedDay=e.getDate();a.drawMonth=a.selectedMonth=e.getMonth();a.drawYear=a.selectedYear=e.getFullYear();if(c=="M"||c=="Y")this._notifyChange(a)},_restrictMinMax:function(a,b){var c=this._getMinMaxDate(a,"min");a=this._getMinMaxDate(a,"max");b=c&&b<c?c:b;return b=a&&b>a?a:b},_notifyChange:function(a){var b=this._get(a,
-"onChangeMonthYear");if(b)b.apply(a.input?a.input[0]:null,[a.selectedYear,a.selectedMonth+1,a])},_getNumberOfMonths:function(a){a=this._get(a,"numberOfMonths");return a==null?[1,1]:typeof a=="number"?[1,a]:a},_getMinMaxDate:function(a,b){return this._determineDate(a,this._get(a,b+"Date"),null)},_getDaysInMonth:function(a,b){return 32-this._daylightSavingAdjust(new Date(a,b,32)).getDate()},_getFirstDayOfMonth:function(a,b){return(new Date(a,b,1)).getDay()},_canAdjustMonth:function(a,b,c,e){var f=this._getNumberOfMonths(a);
-c=this._daylightSavingAdjust(new Date(c,e+(b<0?b:f[0]*f[1]),1));b<0&&c.setDate(this._getDaysInMonth(c.getFullYear(),c.getMonth()));return this._isInRange(a,c)},_isInRange:function(a,b){var c=this._getMinMaxDate(a,"min");a=this._getMinMaxDate(a,"max");return(!c||b.getTime()>=c.getTime())&&(!a||b.getTime()<=a.getTime())},_getFormatConfig:function(a){var b=this._get(a,"shortYearCutoff");b=typeof b!="string"?b:(new Date).getFullYear()%100+parseInt(b,10);return{shortYearCutoff:b,dayNamesShort:this._get(a,
-"dayNamesShort"),dayNames:this._get(a,"dayNames"),monthNamesShort:this._get(a,"monthNamesShort"),monthNames:this._get(a,"monthNames")}},_formatDate:function(a,b,c,e){if(!b){a.currentDay=a.selectedDay;a.currentMonth=a.selectedMonth;a.currentYear=a.selectedYear}b=b?typeof b=="object"?b:this._daylightSavingAdjust(new Date(e,c,b)):this._daylightSavingAdjust(new Date(a.currentYear,a.currentMonth,a.currentDay));return this.formatDate(this._get(a,"dateFormat"),b,this._getFormatConfig(a))}});d.fn.datepicker=
-function(a){if(!this.length)return this;if(!d.datepicker.initialized){d(document).mousedown(d.datepicker._checkExternalClick).find("body").append(d.datepicker.dpDiv);d.datepicker.initialized=true}var b=Array.prototype.slice.call(arguments,1);if(typeof a=="string"&&(a=="isDisabled"||a=="getDate"||a=="widget"))return d.datepicker["_"+a+"Datepicker"].apply(d.datepicker,[this[0]].concat(b));if(a=="option"&&arguments.length==2&&typeof arguments[1]=="string")return d.datepicker["_"+a+"Datepicker"].apply(d.datepicker,
-[this[0]].concat(b));return this.each(function(){typeof a=="string"?d.datepicker["_"+a+"Datepicker"].apply(d.datepicker,[this].concat(b)):d.datepicker._attachDatepicker(this,a)})};d.datepicker=new K;d.datepicker.initialized=false;d.datepicker.uuid=(new Date).getTime();d.datepicker.version="1.8.11";window["DP_jQuery_"+y]=d})(jQuery);
-;/*
- * jQuery UI Progressbar 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Progressbar
- *
- * Depends:
- *   jquery.ui.core.js
- *   jquery.ui.widget.js
- */
-(function(b,d){b.widget("ui.progressbar",{options:{value:0,max:100},min:0,_create:function(){this.element.addClass("ui-progressbar ui-widget ui-widget-content ui-corner-all").attr({role:"progressbar","aria-valuemin":this.min,"aria-valuemax":this.options.max,"aria-valuenow":this._value()});this.valueDiv=b("<div class='ui-progressbar-value ui-widget-header ui-corner-left'></div>").appendTo(this.element);this.oldValue=this._value();this._refreshValue()},destroy:function(){this.element.removeClass("ui-progressbar ui-widget ui-widget-content ui-corner-all").removeAttr("role").removeAttr("aria-valuemin").removeAttr("aria-valuemax").removeAttr("aria-valuenow");
-this.valueDiv.remove();b.Widget.prototype.destroy.apply(this,arguments)},value:function(a){if(a===d)return this._value();this._setOption("value",a);return this},_setOption:function(a,c){if(a==="value"){this.options.value=c;this._refreshValue();this._value()===this.options.max&&this._trigger("complete")}b.Widget.prototype._setOption.apply(this,arguments)},_value:function(){var a=this.options.value;if(typeof a!=="number")a=0;return Math.min(this.options.max,Math.max(this.min,a))},_percentage:function(){return 100*
-this._value()/this.options.max},_refreshValue:function(){var a=this.value(),c=this._percentage();if(this.oldValue!==a){this.oldValue=a;this._trigger("change")}this.valueDiv.toggleClass("ui-corner-right",a===this.options.max).width(c.toFixed(0)+"%");this.element.attr("aria-valuenow",a)}});b.extend(b.ui.progressbar,{version:"1.8.11"})})(jQuery);
-;/*
- * jQuery UI Effects 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Effects/
- */
-jQuery.effects||function(f,j){function n(c){var a;if(c&&c.constructor==Array&&c.length==3)return c;if(a=/rgb\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*\)/.exec(c))return[parseInt(a[1],10),parseInt(a[2],10),parseInt(a[3],10)];if(a=/rgb\(\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*\)/.exec(c))return[parseFloat(a[1])*2.55,parseFloat(a[2])*2.55,parseFloat(a[3])*2.55];if(a=/#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec(c))return[parseInt(a[1],
-16),parseInt(a[2],16),parseInt(a[3],16)];if(a=/#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])/.exec(c))return[parseInt(a[1]+a[1],16),parseInt(a[2]+a[2],16),parseInt(a[3]+a[3],16)];if(/rgba\(0, 0, 0, 0\)/.exec(c))return o.transparent;return o[f.trim(c).toLowerCase()]}function s(c,a){var b;do{b=f.curCSS(c,a);if(b!=""&&b!="transparent"||f.nodeName(c,"body"))break;a="backgroundColor"}while(c=c.parentNode);return n(b)}function p(){var c=document.defaultView?document.defaultView.getComputedStyle(this,null):this.currentStyle,
-a={},b,d;if(c&&c.length&&c[0]&&c[c[0]])for(var e=c.length;e--;){b=c[e];if(typeof c[b]=="string"){d=b.replace(/\-(\w)/g,function(g,h){return h.toUpperCase()});a[d]=c[b]}}else for(b in c)if(typeof c[b]==="string")a[b]=c[b];return a}function q(c){var a,b;for(a in c){b=c[a];if(b==null||f.isFunction(b)||a in t||/scrollbar/.test(a)||!/color/i.test(a)&&isNaN(parseFloat(b)))delete c[a]}return c}function u(c,a){var b={_:0},d;for(d in a)if(c[d]!=a[d])b[d]=a[d];return b}function k(c,a,b,d){if(typeof c=="object"){d=
-a;b=null;a=c;c=a.effect}if(f.isFunction(a)){d=a;b=null;a={}}if(typeof a=="number"||f.fx.speeds[a]){d=b;b=a;a={}}if(f.isFunction(b)){d=b;b=null}a=a||{};b=b||a.duration;b=f.fx.off?0:typeof b=="number"?b:b in f.fx.speeds?f.fx.speeds[b]:f.fx.speeds._default;d=d||a.complete;return[c,a,b,d]}function m(c){if(!c||typeof c==="number"||f.fx.speeds[c])return true;if(typeof c==="string"&&!f.effects[c])return true;return false}f.effects={};f.each(["backgroundColor","borderBottomColor","borderLeftColor","borderRightColor",
-"borderTopColor","borderColor","color","outlineColor"],function(c,a){f.fx.step[a]=function(b){if(!b.colorInit){b.start=s(b.elem,a);b.end=n(b.end);b.colorInit=true}b.elem.style[a]="rgb("+Math.max(Math.min(parseInt(b.pos*(b.end[0]-b.start[0])+b.start[0],10),255),0)+","+Math.max(Math.min(parseInt(b.pos*(b.end[1]-b.start[1])+b.start[1],10),255),0)+","+Math.max(Math.min(parseInt(b.pos*(b.end[2]-b.start[2])+b.start[2],10),255),0)+")"}});var o={aqua:[0,255,255],azure:[240,255,255],beige:[245,245,220],black:[0,
-0,0],blue:[0,0,255],brown:[165,42,42],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgrey:[169,169,169],darkgreen:[0,100,0],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkviolet:[148,0,211],fuchsia:[255,0,255],gold:[255,215,0],green:[0,128,0],indigo:[75,0,130],khaki:[240,230,140],lightblue:[173,216,230],lightcyan:[224,255,255],lightgreen:[144,238,144],lightgrey:[211,
-211,211],lightpink:[255,182,193],lightyellow:[255,255,224],lime:[0,255,0],magenta:[255,0,255],maroon:[128,0,0],navy:[0,0,128],olive:[128,128,0],orange:[255,165,0],pink:[255,192,203],purple:[128,0,128],violet:[128,0,128],red:[255,0,0],silver:[192,192,192],white:[255,255,255],yellow:[255,255,0],transparent:[255,255,255]},r=["add","remove","toggle"],t={border:1,borderBottom:1,borderColor:1,borderLeft:1,borderRight:1,borderTop:1,borderWidth:1,margin:1,padding:1};f.effects.animateClass=function(c,a,b,
-d){if(f.isFunction(b)){d=b;b=null}return this.queue("fx",function(){var e=f(this),g=e.attr("style")||" ",h=q(p.call(this)),l,v=e.attr("className");f.each(r,function(w,i){c[i]&&e[i+"Class"](c[i])});l=q(p.call(this));e.attr("className",v);e.animate(u(h,l),a,b,function(){f.each(r,function(w,i){c[i]&&e[i+"Class"](c[i])});if(typeof e.attr("style")=="object"){e.attr("style").cssText="";e.attr("style").cssText=g}else e.attr("style",g);d&&d.apply(this,arguments)});h=f.queue(this);l=h.splice(h.length-1,1)[0];
-h.splice(1,0,l);f.dequeue(this)})};f.fn.extend({_addClass:f.fn.addClass,addClass:function(c,a,b,d){return a?f.effects.animateClass.apply(this,[{add:c},a,b,d]):this._addClass(c)},_removeClass:f.fn.removeClass,removeClass:function(c,a,b,d){return a?f.effects.animateClass.apply(this,[{remove:c},a,b,d]):this._removeClass(c)},_toggleClass:f.fn.toggleClass,toggleClass:function(c,a,b,d,e){return typeof a=="boolean"||a===j?b?f.effects.animateClass.apply(this,[a?{add:c}:{remove:c},b,d,e]):this._toggleClass(c,
-a):f.effects.animateClass.apply(this,[{toggle:c},a,b,d])},switchClass:function(c,a,b,d,e){return f.effects.animateClass.apply(this,[{add:a,remove:c},b,d,e])}});f.extend(f.effects,{version:"1.8.11",save:function(c,a){for(var b=0;b<a.length;b++)a[b]!==null&&c.data("ec.storage."+a[b],c[0].style[a[b]])},restore:function(c,a){for(var b=0;b<a.length;b++)a[b]!==null&&c.css(a[b],c.data("ec.storage."+a[b]))},setMode:function(c,a){if(a=="toggle")a=c.is(":hidden")?"show":"hide";return a},getBaseline:function(c,
-a){var b;switch(c[0]){case "top":b=0;break;case "middle":b=0.5;break;case "bottom":b=1;break;default:b=c[0]/a.height}switch(c[1]){case "left":c=0;break;case "center":c=0.5;break;case "right":c=1;break;default:c=c[1]/a.width}return{x:c,y:b}},createWrapper:function(c){if(c.parent().is(".ui-effects-wrapper"))return c.parent();var a={width:c.outerWidth(true),height:c.outerHeight(true),"float":c.css("float")},b=f("<div></div>").addClass("ui-effects-wrapper").css({fontSize:"100%",background:"transparent",
-border:"none",margin:0,padding:0});c.wrap(b);b=c.parent();if(c.css("position")=="static"){b.css({position:"relative"});c.css({position:"relative"})}else{f.extend(a,{position:c.css("position"),zIndex:c.css("z-index")});f.each(["top","left","bottom","right"],function(d,e){a[e]=c.css(e);if(isNaN(parseInt(a[e],10)))a[e]="auto"});c.css({position:"relative",top:0,left:0,right:"auto",bottom:"auto"})}return b.css(a).show()},removeWrapper:function(c){if(c.parent().is(".ui-effects-wrapper"))return c.parent().replaceWith(c);
-return c},setTransition:function(c,a,b,d){d=d||{};f.each(a,function(e,g){unit=c.cssUnit(g);if(unit[0]>0)d[g]=unit[0]*b+unit[1]});return d}});f.fn.extend({effect:function(c){var a=k.apply(this,arguments),b={options:a[1],duration:a[2],callback:a[3]};a=b.options.mode;var d=f.effects[c];if(f.fx.off||!d)return a?this[a](b.duration,b.callback):this.each(function(){b.callback&&b.callback.call(this)});return d.call(this,b)},_show:f.fn.show,show:function(c){if(m(c))return this._show.apply(this,arguments);
-else{var a=k.apply(this,arguments);a[1].mode="show";return this.effect.apply(this,a)}},_hide:f.fn.hide,hide:function(c){if(m(c))return this._hide.apply(this,arguments);else{var a=k.apply(this,arguments);a[1].mode="hide";return this.effect.apply(this,a)}},__toggle:f.fn.toggle,toggle:function(c){if(m(c)||typeof c==="boolean"||f.isFunction(c))return this.__toggle.apply(this,arguments);else{var a=k.apply(this,arguments);a[1].mode="toggle";return this.effect.apply(this,a)}},cssUnit:function(c){var a=this.css(c),
-b=[];f.each(["em","px","%","pt"],function(d,e){if(a.indexOf(e)>0)b=[parseFloat(a),e]});return b}});f.easing.jswing=f.easing.swing;f.extend(f.easing,{def:"easeOutQuad",swing:function(c,a,b,d,e){return f.easing[f.easing.def](c,a,b,d,e)},easeInQuad:function(c,a,b,d,e){return d*(a/=e)*a+b},easeOutQuad:function(c,a,b,d,e){return-d*(a/=e)*(a-2)+b},easeInOutQuad:function(c,a,b,d,e){if((a/=e/2)<1)return d/2*a*a+b;return-d/2*(--a*(a-2)-1)+b},easeInCubic:function(c,a,b,d,e){return d*(a/=e)*a*a+b},easeOutCubic:function(c,
-a,b,d,e){return d*((a=a/e-1)*a*a+1)+b},easeInOutCubic:function(c,a,b,d,e){if((a/=e/2)<1)return d/2*a*a*a+b;return d/2*((a-=2)*a*a+2)+b},easeInQuart:function(c,a,b,d,e){return d*(a/=e)*a*a*a+b},easeOutQuart:function(c,a,b,d,e){return-d*((a=a/e-1)*a*a*a-1)+b},easeInOutQuart:function(c,a,b,d,e){if((a/=e/2)<1)return d/2*a*a*a*a+b;return-d/2*((a-=2)*a*a*a-2)+b},easeInQuint:function(c,a,b,d,e){return d*(a/=e)*a*a*a*a+b},easeOutQuint:function(c,a,b,d,e){return d*((a=a/e-1)*a*a*a*a+1)+b},easeInOutQuint:function(c,
-a,b,d,e){if((a/=e/2)<1)return d/2*a*a*a*a*a+b;return d/2*((a-=2)*a*a*a*a+2)+b},easeInSine:function(c,a,b,d,e){return-d*Math.cos(a/e*(Math.PI/2))+d+b},easeOutSine:function(c,a,b,d,e){return d*Math.sin(a/e*(Math.PI/2))+b},easeInOutSine:function(c,a,b,d,e){return-d/2*(Math.cos(Math.PI*a/e)-1)+b},easeInExpo:function(c,a,b,d,e){return a==0?b:d*Math.pow(2,10*(a/e-1))+b},easeOutExpo:function(c,a,b,d,e){return a==e?b+d:d*(-Math.pow(2,-10*a/e)+1)+b},easeInOutExpo:function(c,a,b,d,e){if(a==0)return b;if(a==
-e)return b+d;if((a/=e/2)<1)return d/2*Math.pow(2,10*(a-1))+b;return d/2*(-Math.pow(2,-10*--a)+2)+b},easeInCirc:function(c,a,b,d,e){return-d*(Math.sqrt(1-(a/=e)*a)-1)+b},easeOutCirc:function(c,a,b,d,e){return d*Math.sqrt(1-(a=a/e-1)*a)+b},easeInOutCirc:function(c,a,b,d,e){if((a/=e/2)<1)return-d/2*(Math.sqrt(1-a*a)-1)+b;return d/2*(Math.sqrt(1-(a-=2)*a)+1)+b},easeInElastic:function(c,a,b,d,e){c=1.70158;var g=0,h=d;if(a==0)return b;if((a/=e)==1)return b+d;g||(g=e*0.3);if(h<Math.abs(d)){h=d;c=g/4}else c=
-g/(2*Math.PI)*Math.asin(d/h);return-(h*Math.pow(2,10*(a-=1))*Math.sin((a*e-c)*2*Math.PI/g))+b},easeOutElastic:function(c,a,b,d,e){c=1.70158;var g=0,h=d;if(a==0)return b;if((a/=e)==1)return b+d;g||(g=e*0.3);if(h<Math.abs(d)){h=d;c=g/4}else c=g/(2*Math.PI)*Math.asin(d/h);return h*Math.pow(2,-10*a)*Math.sin((a*e-c)*2*Math.PI/g)+d+b},easeInOutElastic:function(c,a,b,d,e){c=1.70158;var g=0,h=d;if(a==0)return b;if((a/=e/2)==2)return b+d;g||(g=e*0.3*1.5);if(h<Math.abs(d)){h=d;c=g/4}else c=g/(2*Math.PI)*Math.asin(d/
-h);if(a<1)return-0.5*h*Math.pow(2,10*(a-=1))*Math.sin((a*e-c)*2*Math.PI/g)+b;return h*Math.pow(2,-10*(a-=1))*Math.sin((a*e-c)*2*Math.PI/g)*0.5+d+b},easeInBack:function(c,a,b,d,e,g){if(g==j)g=1.70158;return d*(a/=e)*a*((g+1)*a-g)+b},easeOutBack:function(c,a,b,d,e,g){if(g==j)g=1.70158;return d*((a=a/e-1)*a*((g+1)*a+g)+1)+b},easeInOutBack:function(c,a,b,d,e,g){if(g==j)g=1.70158;if((a/=e/2)<1)return d/2*a*a*(((g*=1.525)+1)*a-g)+b;return d/2*((a-=2)*a*(((g*=1.525)+1)*a+g)+2)+b},easeInBounce:function(c,
-a,b,d,e){return d-f.easing.easeOutBounce(c,e-a,0,d,e)+b},easeOutBounce:function(c,a,b,d,e){return(a/=e)<1/2.75?d*7.5625*a*a+b:a<2/2.75?d*(7.5625*(a-=1.5/2.75)*a+0.75)+b:a<2.5/2.75?d*(7.5625*(a-=2.25/2.75)*a+0.9375)+b:d*(7.5625*(a-=2.625/2.75)*a+0.984375)+b},easeInOutBounce:function(c,a,b,d,e){if(a<e/2)return f.easing.easeInBounce(c,a*2,0,d,e)*0.5+b;return f.easing.easeOutBounce(c,a*2-e,0,d,e)*0.5+d*0.5+b}})}(jQuery);
-;/*
- * jQuery UI Effects Blind 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Effects/Blind
- *
- * Depends:
- *	jquery.effects.core.js
- */
-(function(b){b.effects.blind=function(c){return this.queue(function(){var a=b(this),g=["position","top","bottom","left","right"],f=b.effects.setMode(a,c.options.mode||"hide"),d=c.options.direction||"vertical";b.effects.save(a,g);a.show();var e=b.effects.createWrapper(a).css({overflow:"hidden"}),h=d=="vertical"?"height":"width";d=d=="vertical"?e.height():e.width();f=="show"&&e.css(h,0);var i={};i[h]=f=="show"?d:0;e.animate(i,c.duration,c.options.easing,function(){f=="hide"&&a.hide();b.effects.restore(a,
-g);b.effects.removeWrapper(a);c.callback&&c.callback.apply(a[0],arguments);a.dequeue()})})}})(jQuery);
-;/*
- * jQuery UI Effects Bounce 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Effects/Bounce
- *
- * Depends:
- *	jquery.effects.core.js
- */
-(function(e){e.effects.bounce=function(b){return this.queue(function(){var a=e(this),l=["position","top","bottom","left","right"],h=e.effects.setMode(a,b.options.mode||"effect"),d=b.options.direction||"up",c=b.options.distance||20,m=b.options.times||5,i=b.duration||250;/show|hide/.test(h)&&l.push("opacity");e.effects.save(a,l);a.show();e.effects.createWrapper(a);var f=d=="up"||d=="down"?"top":"left";d=d=="up"||d=="left"?"pos":"neg";c=b.options.distance||(f=="top"?a.outerHeight({margin:true})/3:a.outerWidth({margin:true})/
-3);if(h=="show")a.css("opacity",0).css(f,d=="pos"?-c:c);if(h=="hide")c/=m*2;h!="hide"&&m--;if(h=="show"){var g={opacity:1};g[f]=(d=="pos"?"+=":"-=")+c;a.animate(g,i/2,b.options.easing);c/=2;m--}for(g=0;g<m;g++){var j={},k={};j[f]=(d=="pos"?"-=":"+=")+c;k[f]=(d=="pos"?"+=":"-=")+c;a.animate(j,i/2,b.options.easing).animate(k,i/2,b.options.easing);c=h=="hide"?c*2:c/2}if(h=="hide"){g={opacity:0};g[f]=(d=="pos"?"-=":"+=")+c;a.animate(g,i/2,b.options.easing,function(){a.hide();e.effects.restore(a,l);e.effects.removeWrapper(a);
-b.callback&&b.callback.apply(this,arguments)})}else{j={};k={};j[f]=(d=="pos"?"-=":"+=")+c;k[f]=(d=="pos"?"+=":"-=")+c;a.animate(j,i/2,b.options.easing).animate(k,i/2,b.options.easing,function(){e.effects.restore(a,l);e.effects.removeWrapper(a);b.callback&&b.callback.apply(this,arguments)})}a.queue("fx",function(){a.dequeue()});a.dequeue()})}})(jQuery);
-;/*
- * jQuery UI Effects Clip 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Effects/Clip
- *
- * Depends:
- *	jquery.effects.core.js
- */
-(function(b){b.effects.clip=function(e){return this.queue(function(){var a=b(this),i=["position","top","bottom","left","right","height","width"],f=b.effects.setMode(a,e.options.mode||"hide"),c=e.options.direction||"vertical";b.effects.save(a,i);a.show();var d=b.effects.createWrapper(a).css({overflow:"hidden"});d=a[0].tagName=="IMG"?d:a;var g={size:c=="vertical"?"height":"width",position:c=="vertical"?"top":"left"};c=c=="vertical"?d.height():d.width();if(f=="show"){d.css(g.size,0);d.css(g.position,
-c/2)}var h={};h[g.size]=f=="show"?c:0;h[g.position]=f=="show"?0:c/2;d.animate(h,{queue:false,duration:e.duration,easing:e.options.easing,complete:function(){f=="hide"&&a.hide();b.effects.restore(a,i);b.effects.removeWrapper(a);e.callback&&e.callback.apply(a[0],arguments);a.dequeue()}})})}})(jQuery);
-;/*
- * jQuery UI Effects Drop 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Effects/Drop
- *
- * Depends:
- *	jquery.effects.core.js
- */
-(function(c){c.effects.drop=function(d){return this.queue(function(){var a=c(this),h=["position","top","bottom","left","right","opacity"],e=c.effects.setMode(a,d.options.mode||"hide"),b=d.options.direction||"left";c.effects.save(a,h);a.show();c.effects.createWrapper(a);var f=b=="up"||b=="down"?"top":"left";b=b=="up"||b=="left"?"pos":"neg";var g=d.options.distance||(f=="top"?a.outerHeight({margin:true})/2:a.outerWidth({margin:true})/2);if(e=="show")a.css("opacity",0).css(f,b=="pos"?-g:g);var i={opacity:e==
-"show"?1:0};i[f]=(e=="show"?b=="pos"?"+=":"-=":b=="pos"?"-=":"+=")+g;a.animate(i,{queue:false,duration:d.duration,easing:d.options.easing,complete:function(){e=="hide"&&a.hide();c.effects.restore(a,h);c.effects.removeWrapper(a);d.callback&&d.callback.apply(this,arguments);a.dequeue()}})})}})(jQuery);
-;/*
- * jQuery UI Effects Explode 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Effects/Explode
- *
- * Depends:
- *	jquery.effects.core.js
- */
-(function(j){j.effects.explode=function(a){return this.queue(function(){var c=a.options.pieces?Math.round(Math.sqrt(a.options.pieces)):3,d=a.options.pieces?Math.round(Math.sqrt(a.options.pieces)):3;a.options.mode=a.options.mode=="toggle"?j(this).is(":visible")?"hide":"show":a.options.mode;var b=j(this).show().css("visibility","hidden"),g=b.offset();g.top-=parseInt(b.css("marginTop"),10)||0;g.left-=parseInt(b.css("marginLeft"),10)||0;for(var h=b.outerWidth(true),i=b.outerHeight(true),e=0;e<c;e++)for(var f=
-0;f<d;f++)b.clone().appendTo("body").wrap("<div></div>").css({position:"absolute",visibility:"visible",left:-f*(h/d),top:-e*(i/c)}).parent().addClass("ui-effects-explode").css({position:"absolute",overflow:"hidden",width:h/d,height:i/c,left:g.left+f*(h/d)+(a.options.mode=="show"?(f-Math.floor(d/2))*(h/d):0),top:g.top+e*(i/c)+(a.options.mode=="show"?(e-Math.floor(c/2))*(i/c):0),opacity:a.options.mode=="show"?0:1}).animate({left:g.left+f*(h/d)+(a.options.mode=="show"?0:(f-Math.floor(d/2))*(h/d)),top:g.top+
-e*(i/c)+(a.options.mode=="show"?0:(e-Math.floor(c/2))*(i/c)),opacity:a.options.mode=="show"?1:0},a.duration||500);setTimeout(function(){a.options.mode=="show"?b.css({visibility:"visible"}):b.css({visibility:"visible"}).hide();a.callback&&a.callback.apply(b[0]);b.dequeue();j("div.ui-effects-explode").remove()},a.duration||500)})}})(jQuery);
-;/*
- * jQuery UI Effects Fade 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Effects/Fade
- *
- * Depends:
- *	jquery.effects.core.js
- */
-(function(b){b.effects.fade=function(a){return this.queue(function(){var c=b(this),d=b.effects.setMode(c,a.options.mode||"hide");c.animate({opacity:d},{queue:false,duration:a.duration,easing:a.options.easing,complete:function(){a.callback&&a.callback.apply(this,arguments);c.dequeue()}})})}})(jQuery);
-;/*
- * jQuery UI Effects Fold 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Effects/Fold
- *
- * Depends:
- *	jquery.effects.core.js
- */
-(function(c){c.effects.fold=function(a){return this.queue(function(){var b=c(this),j=["position","top","bottom","left","right"],d=c.effects.setMode(b,a.options.mode||"hide"),g=a.options.size||15,h=!!a.options.horizFirst,k=a.duration?a.duration/2:c.fx.speeds._default/2;c.effects.save(b,j);b.show();var e=c.effects.createWrapper(b).css({overflow:"hidden"}),f=d=="show"!=h,l=f?["width","height"]:["height","width"];f=f?[e.width(),e.height()]:[e.height(),e.width()];var i=/([0-9]+)%/.exec(g);if(i)g=parseInt(i[1],
-10)/100*f[d=="hide"?0:1];if(d=="show")e.css(h?{height:0,width:g}:{height:g,width:0});h={};i={};h[l[0]]=d=="show"?f[0]:g;i[l[1]]=d=="show"?f[1]:0;e.animate(h,k,a.options.easing).animate(i,k,a.options.easing,function(){d=="hide"&&b.hide();c.effects.restore(b,j);c.effects.removeWrapper(b);a.callback&&a.callback.apply(b[0],arguments);b.dequeue()})})}})(jQuery);
-;/*
- * jQuery UI Effects Highlight 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Effects/Highlight
- *
- * Depends:
- *	jquery.effects.core.js
- */
-(function(b){b.effects.highlight=function(c){return this.queue(function(){var a=b(this),e=["backgroundImage","backgroundColor","opacity"],d=b.effects.setMode(a,c.options.mode||"show"),f={backgroundColor:a.css("backgroundColor")};if(d=="hide")f.opacity=0;b.effects.save(a,e);a.show().css({backgroundImage:"none",backgroundColor:c.options.color||"#ffff99"}).animate(f,{queue:false,duration:c.duration,easing:c.options.easing,complete:function(){d=="hide"&&a.hide();b.effects.restore(a,e);d=="show"&&!b.support.opacity&&
-this.style.removeAttribute("filter");c.callback&&c.callback.apply(this,arguments);a.dequeue()}})})}})(jQuery);
-;/*
- * jQuery UI Effects Pulsate 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Effects/Pulsate
- *
- * Depends:
- *	jquery.effects.core.js
- */
-(function(d){d.effects.pulsate=function(a){return this.queue(function(){var b=d(this),c=d.effects.setMode(b,a.options.mode||"show");times=(a.options.times||5)*2-1;duration=a.duration?a.duration/2:d.fx.speeds._default/2;isVisible=b.is(":visible");animateTo=0;if(!isVisible){b.css("opacity",0).show();animateTo=1}if(c=="hide"&&isVisible||c=="show"&&!isVisible)times--;for(c=0;c<times;c++){b.animate({opacity:animateTo},duration,a.options.easing);animateTo=(animateTo+1)%2}b.animate({opacity:animateTo},duration,
-a.options.easing,function(){animateTo==0&&b.hide();a.callback&&a.callback.apply(this,arguments)});b.queue("fx",function(){b.dequeue()}).dequeue()})}})(jQuery);
-;/*
- * jQuery UI Effects Scale 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Effects/Scale
- *
- * Depends:
- *	jquery.effects.core.js
- */
-(function(c){c.effects.puff=function(b){return this.queue(function(){var a=c(this),e=c.effects.setMode(a,b.options.mode||"hide"),g=parseInt(b.options.percent,10)||150,h=g/100,i={height:a.height(),width:a.width()};c.extend(b.options,{fade:true,mode:e,percent:e=="hide"?g:100,from:e=="hide"?i:{height:i.height*h,width:i.width*h}});a.effect("scale",b.options,b.duration,b.callback);a.dequeue()})};c.effects.scale=function(b){return this.queue(function(){var a=c(this),e=c.extend(true,{},b.options),g=c.effects.setMode(a,
-b.options.mode||"effect"),h=parseInt(b.options.percent,10)||(parseInt(b.options.percent,10)==0?0:g=="hide"?0:100),i=b.options.direction||"both",f=b.options.origin;if(g!="effect"){e.origin=f||["middle","center"];e.restore=true}f={height:a.height(),width:a.width()};a.from=b.options.from||(g=="show"?{height:0,width:0}:f);h={y:i!="horizontal"?h/100:1,x:i!="vertical"?h/100:1};a.to={height:f.height*h.y,width:f.width*h.x};if(b.options.fade){if(g=="show"){a.from.opacity=0;a.to.opacity=1}if(g=="hide"){a.from.opacity=
-1;a.to.opacity=0}}e.from=a.from;e.to=a.to;e.mode=g;a.effect("size",e,b.duration,b.callback);a.dequeue()})};c.effects.size=function(b){return this.queue(function(){var a=c(this),e=["position","top","bottom","left","right","width","height","overflow","opacity"],g=["position","top","bottom","left","right","overflow","opacity"],h=["width","height","overflow"],i=["fontSize"],f=["borderTopWidth","borderBottomWidth","paddingTop","paddingBottom"],k=["borderLeftWidth","borderRightWidth","paddingLeft","paddingRight"],
-p=c.effects.setMode(a,b.options.mode||"effect"),n=b.options.restore||false,m=b.options.scale||"both",l=b.options.origin,j={height:a.height(),width:a.width()};a.from=b.options.from||j;a.to=b.options.to||j;if(l){l=c.effects.getBaseline(l,j);a.from.top=(j.height-a.from.height)*l.y;a.from.left=(j.width-a.from.width)*l.x;a.to.top=(j.height-a.to.height)*l.y;a.to.left=(j.width-a.to.width)*l.x}var d={from:{y:a.from.height/j.height,x:a.from.width/j.width},to:{y:a.to.height/j.height,x:a.to.width/j.width}};
-if(m=="box"||m=="both"){if(d.from.y!=d.to.y){e=e.concat(f);a.from=c.effects.setTransition(a,f,d.from.y,a.from);a.to=c.effects.setTransition(a,f,d.to.y,a.to)}if(d.from.x!=d.to.x){e=e.concat(k);a.from=c.effects.setTransition(a,k,d.from.x,a.from);a.to=c.effects.setTransition(a,k,d.to.x,a.to)}}if(m=="content"||m=="both")if(d.from.y!=d.to.y){e=e.concat(i);a.from=c.effects.setTransition(a,i,d.from.y,a.from);a.to=c.effects.setTransition(a,i,d.to.y,a.to)}c.effects.save(a,n?e:g);a.show();c.effects.createWrapper(a);
-a.css("overflow","hidden").css(a.from);if(m=="content"||m=="both"){f=f.concat(["marginTop","marginBottom"]).concat(i);k=k.concat(["marginLeft","marginRight"]);h=e.concat(f).concat(k);a.find("*[width]").each(function(){child=c(this);n&&c.effects.save(child,h);var o={height:child.height(),width:child.width()};child.from={height:o.height*d.from.y,width:o.width*d.from.x};child.to={height:o.height*d.to.y,width:o.width*d.to.x};if(d.from.y!=d.to.y){child.from=c.effects.setTransition(child,f,d.from.y,child.from);
-child.to=c.effects.setTransition(child,f,d.to.y,child.to)}if(d.from.x!=d.to.x){child.from=c.effects.setTransition(child,k,d.from.x,child.from);child.to=c.effects.setTransition(child,k,d.to.x,child.to)}child.css(child.from);child.animate(child.to,b.duration,b.options.easing,function(){n&&c.effects.restore(child,h)})})}a.animate(a.to,{queue:false,duration:b.duration,easing:b.options.easing,complete:function(){a.to.opacity===0&&a.css("opacity",a.from.opacity);p=="hide"&&a.hide();c.effects.restore(a,
-n?e:g);c.effects.removeWrapper(a);b.callback&&b.callback.apply(this,arguments);a.dequeue()}})})}})(jQuery);
-;/*
- * jQuery UI Effects Shake 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Effects/Shake
- *
- * Depends:
- *	jquery.effects.core.js
- */
-(function(d){d.effects.shake=function(a){return this.queue(function(){var b=d(this),j=["position","top","bottom","left","right"];d.effects.setMode(b,a.options.mode||"effect");var c=a.options.direction||"left",e=a.options.distance||20,l=a.options.times||3,f=a.duration||a.options.duration||140;d.effects.save(b,j);b.show();d.effects.createWrapper(b);var g=c=="up"||c=="down"?"top":"left",h=c=="up"||c=="left"?"pos":"neg";c={};var i={},k={};c[g]=(h=="pos"?"-=":"+=")+e;i[g]=(h=="pos"?"+=":"-=")+e*2;k[g]=
-(h=="pos"?"-=":"+=")+e*2;b.animate(c,f,a.options.easing);for(e=1;e<l;e++)b.animate(i,f,a.options.easing).animate(k,f,a.options.easing);b.animate(i,f,a.options.easing).animate(c,f/2,a.options.easing,function(){d.effects.restore(b,j);d.effects.removeWrapper(b);a.callback&&a.callback.apply(this,arguments)});b.queue("fx",function(){b.dequeue()});b.dequeue()})}})(jQuery);
-;/*
- * jQuery UI Effects Slide 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Effects/Slide
- *
- * Depends:
- *	jquery.effects.core.js
- */
-(function(c){c.effects.slide=function(d){return this.queue(function(){var a=c(this),h=["position","top","bottom","left","right"],f=c.effects.setMode(a,d.options.mode||"show"),b=d.options.direction||"left";c.effects.save(a,h);a.show();c.effects.createWrapper(a).css({overflow:"hidden"});var g=b=="up"||b=="down"?"top":"left";b=b=="up"||b=="left"?"pos":"neg";var e=d.options.distance||(g=="top"?a.outerHeight({margin:true}):a.outerWidth({margin:true}));if(f=="show")a.css(g,b=="pos"?isNaN(e)?"-"+e:-e:e);
-var i={};i[g]=(f=="show"?b=="pos"?"+=":"-=":b=="pos"?"-=":"+=")+e;a.animate(i,{queue:false,duration:d.duration,easing:d.options.easing,complete:function(){f=="hide"&&a.hide();c.effects.restore(a,h);c.effects.removeWrapper(a);d.callback&&d.callback.apply(this,arguments);a.dequeue()}})})}})(jQuery);
-;/*
- * jQuery UI Effects Transfer 1.8.11
- *
- * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Effects/Transfer
- *
- * Depends:
- *	jquery.effects.core.js
- */
-(function(e){e.effects.transfer=function(a){return this.queue(function(){var b=e(this),c=e(a.options.to),d=c.offset();c={top:d.top,left:d.left,height:c.innerHeight(),width:c.innerWidth()};d=b.offset();var f=e('<div class="ui-effects-transfer"></div>').appendTo(document.body).addClass(a.options.className).css({top:d.top,left:d.left,height:b.innerHeight(),width:b.innerWidth(),position:"absolute"}).animate(c,a.duration,a.options.easing,function(){f.remove();a.callback&&a.callback.apply(b[0],arguments);
-b.dequeue()})})}})(jQuery);
-;

+ 0 - 1
output/fe-helper/template/fehelper_background.html

@@ -1 +0,0 @@
-<!DOCTYPE HTML><html lang=zh-CN><head><title></title><meta charset=utf-8><script src=../static/js/core/jquery-1.5.min.js></script><script src=../static/js/mod/mod_background.js></script></head><body>

+ 0 - 1
output/fe-helper/template/fehelper_endecode.html

@@ -1 +0,0 @@
-<!DOCTYPE HTML><html lang=zh-CN> <head> <title>字符串编解码工具</title> <meta charset=UTF-8> <link rel=stylesheet href=../static/css/fe-endecode.css> <script src=../static/js/core/jquery-1.5.min.js></script><script src=../static/js/mod/mod_endecode.js></script> </head> <body> <div class="mod-endecode -e-x-container"> <fieldset> <legend>对字符串进行各种编解码操作</legend> <div class=x-input> <textarea class="-e-zxl-ta-src" id="srcText" cols="" rows=""></textarea> </div> <div class=-e-x-btn> <span class=-e-x-radio> <input type=radio name=codeType id=uniEncode checked=checked><label for=uniEncode>Unicode编码</label> <input type=radio name=codeType id=uniDecode><label for=uniDecode>Unicode解码</label> <input type=radio name=codeType id=utf8Encode><label for=utf8Encode>UTF-8编码</label> <input type=radio name=codeType id=utf8Decode><label for=utf8Decode>UTF-8解码</label> <input type=radio name=codeType id=base64Encode><label for=base64Encode>base64编码</label> <input type=radio name=codeType id=base64Decode><label for=base64Decode>base64解码</label> <input type=radio name=codeType id=md5Encode><label for=md5Encode>md5编码</label> </span> <input id=btnCodeClear class="-e-btn -e-clear-btn" type=button value="清空"> <input id=btnCodeChange class=-e-btn type=button value="转换"> </div> </fieldset> <div id=rst class="x-input -e-x-rst"> <textarea class="zxl-ta-rst" id="rstCode" cols="" rows=""></textarea> </div> </div> <div class=-e-x-footer> &copy; 2013 <a href="mailto:[email protected]">Baidu space-fe</a> </div> 

+ 0 - 1
output/fe-helper/template/fehelper_fdp.html

@@ -1 +0,0 @@
-<!DOCTYPE HTML><html lang=zh-CN> <head> <title>Fe文档检索工具</title> <meta charset=utf-8><link rel=stylesheet href=../static/css/fe-fdp.css><script src=../static/js/core/jquery-1.5.min.js></script><script src=../static/js/mod/mod_fdp.js></script> </head> <body> <div id=fdp-doc-box> <div id=fdp-doc-logo></div><div id=fdp-doc-nav><ul class=-d-list><li class="-d-normal -d-selected" id=fdp-doc>空间FDP文档<sub class=-d-sub>(<span id=num-fdp-doc>0</span>)</sub><li class=-d-normal id=fe-doc>大FE文档<sub class=-d-sub>(<span id=num-fe-doc>0</span>)</sub></ul></div> <form action="#" id=fdp-doc-form> <input type=text class=fdp-search-input id=fdp-search-input><img src=../static/img/43.png alt="FE一下" title="FE一下" class=fdp-search-btn id=fdp-search-btn><div id=fdp-doc-rst-list></div> </form> </div> 

+ 0 - 1
output/fe-helper/template/fehelper_jsonformat.html

@@ -1 +0,0 @@
-<!DOCTYPE HTML><html lang=zh-CN> <head> <title>Json格式化查看工具</title> <meta charset=UTF-8> <link rel=stylesheet href=../static/css/fe-jsonformat.css> <script src=../static/js/core/jquery-1.5.min.js></script><script src=../static/js/mod/mod_jsonformat.js></script> </head> <body> <div class=mod-json> <div class="format-item clearfix"> <fieldset> <legend>JSON格式化查看:请在下面粘贴你的JSON字符串</legend> <textarea id="jsonSource"></textarea> <div><button id=btnFormat>格式化</button></div> </fieldset> </div> <div class=rst-item> <div id=formattingMsg> <svg id=spinner width=16 height=16 viewBox="0 0 300 300" xmlns=http://www.w3.org/2000/svg version=1.1> <path d="M 150,0 a 150,150 0 0,1 106.066,256.066 l -35.355,-35.355 a -100,-100 0 0,0 -70.711,-170.711 z" fill="#3d7fe6"></path> </svg> 加载中... </div> <div id=jfContent></div> <pre id="jfContent_pre"></pre> </div> </div> 

Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 0
output/fe-helper/template/fehelper_options.html


+ 0 - 1
output/fe-helper/template/fehelper_popup.html

@@ -1 +0,0 @@
-<!DOCTYPE HTML><html lang=zh-CN> <head> <title>FeHelper弹出页面</title> <meta charset=utf-8><link rel=stylesheet href=../static/css/fe-popup.css><script src=../static/js/core/jquery-1.5.min.js></script><script src=../static/js/mod/mod_popup.js></script> </head> <body> <div class=fe-function-title>FE助手</div> <ul class=fe-function-list> <li class=-x-fcp><b></b><span>编码规范检测</span> <li class=-x-loadtime><b></b><span>页面性能检测</span> <li class=-x-grid><b></b><span>栅格规范检测</span> <li class="-x-fdp fe-hide"><b></b><span>FE文档检索</span> <li class=-x-endecode><b></b><span>字符串编解码</span> <li class=-x-jsonformat><b></b><span>JSON格式化</span> <li class=-x-qrcode><b></b><span>QR码生成器</span> </ul> <div class=fe-feedback> <a href="http://www.baidufe.com/item/889639af23968ee688b9.html#comment" target=_blank>意见反馈</a> </div>

+ 0 - 3
output/fe-helper/template/fehelper_qrcode.html

@@ -1,3 +0,0 @@
-<!DOCTYPE HTML><html lang=zh-CN> <head> <title>Json格式化查看工具</title> <meta charset=UTF-8> <link rel=stylesheet href=../static/css/fe-qrcode.css> <script src=../static/js/core/jquery-1.5.min.js></script><script src=../static/js/mod/mod_qrcode.js></script> </head> <body> <div class=mod-qrcode> <div class="qr-item clearfix"> <fieldset> <legend>生成QR码</legend> <div> 原始数据:&nbsp;<textarea id="source"></textarea> <a href="#" id=btnDemo>隐藏demo</a> </div> <div id=demo> <div class=item> <span class=title>名片</span> <span class=content>                                CARD:N:Alien;TIL:WEB前端工程师;DIV:某部门;COR:某IT公司;ADR:北京市海淀区;ZIP:100085;TEL:保密;M:保密;EM:[email protected];URL:http://www.baidufe.com;;
-                            </span> <a href="#" class=test>试用</a> </div> <div class=item> <span class=title>网址</span> <span class=content>                               http://www.baidufe.com;;
-                            </span> <a href="#" class=test>试用</a> </div> </div> <div> 图片尺寸:&nbsp;<input type=text id=size value=4> <button id=btnQR>生成</button> </div> </fieldset> <div id=qrResult></div> </div> </div> 

+ 0 - 1
output/fe-helper/template/fehelper_wpo.html

@@ -1 +0,0 @@
-<!DOCTYPE HTML><html lang=zh-CN> <head> <title>当前网页加载时间</title> <meta charset=utf-8> <style type="text/css">body{font-family:Tahoma, sans-serif;font-size:10pt;color:#333}table{border-collapse:collapse;width:100%}table thead th{text-align:center;color:#000}table.mod-header thead th{width:100px}th{background-color:#E0E0E0;border:1px solid #A0A0A0;font-size:10pt}td{border:1px solid #A0A0A0;font-size:10pt;text-align:right}#loadTotal{background:#f1f1f1;font-weight:bold}</style><script src=../static/js/google_analytics.js></script> </head> <body><table cellpadding=3 cellspacing=0> <thead> <th>事件</th> <th>单独耗时</th> <th>累计耗时</th>  <tbody> <tr> <td>DNS解析 <td id=dns> <td id=dnsTotal>  <tr> <td>建立连接 <td id=connect> <td id=requestTotal>  <tr> <td>等待响应 <td id=response> <td id=responseTotal>  <tr> <td>接收响应 <td id=responseEnd> <td id=responseEndTotal>  <tr> <td>内容加载 <td id=contentLoaded> <td id=contentLoadedTotal>  <tr> <td>页面渲染 <td id=domComplete> <td id=domCompleteTotal>  <tr> <td>总耗时 <td colspan=2 id=loadTotal>  </table><table class=mod-header> <thead> <th>网页信息</th> <th>数据</th>  <tbody> <tr> <td>Server Type <td id=server>  <tr> <td>Server Time <td id=serverTime>  <tr> <td>Content Encoding <td id=contentEncoding>  <tr> <td>Content Type <td id=contentType>  <tr> <td>Content Length <td id=contentLength>  <tr> <td>Connection <td id=connection>  <tr> <td>Vary <td id=vary>  <tr> <td>Transfer Encoding <td id=transferEncoding>  <tr> <td>Cache Control <td id=cacheControl>  <tr> <td>Expires <td id=exprires>  <tr> <td>Last Modified <td id=lastModified>  </table><script src=../static/js/core/core.js></script><script src=../static/js/core/fe-const.js></script><script src=../static/js/core/log.js></script><script src=../static/js/wpo/fe-wpo.js></script> 

+ 0 - 77
static/css/fe-endecode.css

@@ -1,77 +0,0 @@
-html {
-	background:url(../img/baidufe_bj.gif);
-	font-size: 14px;
-}
-body{
-	font-family:Arial,"simsun";
-	color:#666;
-}
-
-.mod-endecode {
-	width:980px;
-	margin:0 auto;
-}
-.mod-endecode fieldset {
-	border : 1px solid #bbb;
-	padding:10px;
-	width:960px;
-	margin-bottom: 10px;
-}
-.mod-endecode fieldset legend {
-	padding:0 5px;
-	color:red;
-}
-.mod-endecode fieldset>div {
-	margin-bottom: 10px;
-}
-.-e-x-container {
-	width:980px;
-	margin:0 auto;
-	padding:30px 0 50px 0;
-	min-height:400px;
-}
-.-e-x-radio label:hover {
-	color:#333;
-	cursor:pointer;
-}
-.-e-zxl-ta-src {
-	width:950px;
-	height:100px;
-}
-.-e-x-btn  {
-	padding:10px;
-	padding-bottom: 0;
-	height:24px;
-}
-.-e-x-btn .-e-x-radio {
-	float:left;
-	font-size:14px;
-}
-.-e-x-btn .-e-btn {
-	float:right;
-	height:30px;
-	width:70px;
-	font-size:13px;
-	padding:5px;
-	cursor:pointer;
-}
-.-e-x-btn .-e-clear-btn {
-	margin-left:20px;
-	font-weight:normal;
-}
-.-e-x-rst {
-    margin: 20px 0;
-	display:none;
-}
-.zxl-ta-rst {
-	width:980px;
-	height:100px;
-}
-.-e-x-footer {
-	text-align:center;
-	font-size:12px;
-	margin-top:30px;
-	color:#00c;
-	padding:5px;
-	display:none;
-}

+ 0 - 128
static/css/fe-fdp.css

@@ -1,128 +0,0 @@
-body{
-	font-family:Arial,"simsun";
-}
-#fdp-doc-box {
-	width:924px;
-	margin:0 auto;
-	padding:50px 0 50px 0;
-	min-height:500px;
-	text-align:center;
-	background:-webkit-gradient(linear, left top, left bottom, from(#B0DDE5), to(#fefefe));
-	-webkit-border-radius:8px;
-}
-
-#fdp-doc-logo .fdp-logo-f{
-	width:80px;	
-	margin-right:-30px;
-}
-#fdp-doc-logo .fdp-logo-e{
-	width:80px;	
-}
-
-#fdp-doc-nav {
-	font-size:16px;
-	text-align:center;
-}
-#fdp-doc-nav .-d-list{
-	margin:0;
-	padding:0;
-	list-style:none;
-}
-#fdp-doc-nav .-d-normal{
-	color:#333;
-	display:inline;
-	cursor:pointer;
-	padding:5px;
-}
-#fdp-doc-nav .-d-normal:hover{
-	color:#f00;
-}
-#fe-doc {
-	margin-left:20px;
-}
-#fdp-doc-nav .-d-sub {
-	font-size:6px;
-	color:#48b;
-}
-#fdp-doc-nav .-d-sub span {
-	color:#f00;
-}
-#fdp-doc-nav .-d-selected{
-	border:1px solid #555;
-	-webkit-border-radius:5px 5px;
-	background:#444;
-	color:#ff0;
-}
-#fdp-doc-form {
-	padding:20px;
-}
-#fdp-doc-form .fdp-search-input {
-	width:400px;
-	height:22px;
-	line-height:22px;
-	padding:2px 34px 2px 2px;
-	border:2px solid #075;
-	-webkit-border-radius:5px 5px;
-}
-#fdp-doc-form .fdp-search-btn {
-	width:24px;
-	cursor:pointer;
-	margin: 0 0 -7px -40px;
-	border-left:1px solid #bbb;
-	padding-left:2px;
-	-webkit-opacity:0.5;
-}
-#fdp-doc-form .fdp-search-btn:hover {
-	-webkit-opacity:1;
-}
-#fdp-doc-rst-list {
-	text-align:left;
-	margin: 10px 25px 0;
-	font-size:14px;
-}
-#fdp-doc-rst-list dt{
-	color: #084A4D;
-	font-weight: bold;
-	line-height: 24px;
-	height: 24px;
-}
-#fdp-doc-rst-list dd{
-	display: block;
-	line-height: 26px;
-	position: relative;
-	padding: 0;
-	margin: 0;
-	text-indent: 0;
-	border: 0;
-}
-#fdp-doc-rst-list i{
-	font-style: normal;
-	color: #888;
-}
-#fdp-doc-rst-list a{
-	color: #37628B;
-	text-decoration: none;
-	height: 26px;
-}
-#fdp-doc-rst-list a:hover{
-	text-decoration:underline;
-}
-#fdp-doc-rst-list .-d-author{
-	color: #777;
-	font-style: normal;
-	display: block;
-	height: 26px;
-	overflow: hidden;
-	position: absolute;
-	right: 0px;
-	top: 0;
-	width: 250px;
-}
-#fdp-doc-rst-list .-d-no-result{
-	color:#b00;
-	font-weight:bold;
-}
-#fdp-doc-rst-list .-d-highlight{
-	color:#f00;
-}
-

+ 0 - 347
static/css/fe-helper.css

@@ -1,347 +0,0 @@
-.fe-helper-hide {
-	display:none;
-}
-#fe-helper-box {
-    position: fixed;
-    left: 1px;
-    bottom: 0;
-	right:8px;
-    z-index: 2147483646;
-	font-size:12px;
-}
-
-#fe-helper-main-ifr {
-    width: 100%;
-    height: 100%;
-    position: absolute;
-    left: 0;
-    top: 0;
-	bottom:0;
-    z-index: 2147483646;
-}
-
-#fe-helper-main-tab {
-    width: 100%;
-    position: absolute;
-	top:0;
-    left: 0;
-    bottom: 0;
-    z-index: 2147483647;
-    background: #fcfcfc;
-	text-align:left;
-}
-
-#fe-helper-main-tab .ui-tabs-nav {
-	-webkit-user-select : none;
-}
-
-#fe-helper-main-tab li .ui-icon-close {
-    float: left;
-    margin: 0.4em 0.2em 0 0;
-    cursor: pointer;
-}
-
-#fe-helper-main-tab.ui-tabs .ui-tabs-panel {
-	padding-right:0;
-}
-
-
-#fe-helper-main-tab .rst-title .rst-count{
-	color:#f00;
-}
-#fe-helper-main-tab .rst-content{
-	color:#666;
-	height:460px;
-	overflow-y:auto;
-}
-#fe-helper-main-tab .rst-content .x-num{
-	color:#f00;
-	font-weight:bold;
-}
-#fe-helper-main-tab .rst-content .x-tag{
-	color:#00f;
-	font-weight:bold;
-}
-#fe-helper-main-tab .rst-content .x-attr{
-	color:#b00;
-	font-weight:bold;
-}
-#fe-helper-main-tab .rst-content .x-file{
-	color:#48b;
-}
-
-#fe-helper-box .ui-corner-top>a{
-	font-weight:bold;
-}
-#fe-helper-box .ui-resizable-s{
-    position: absolute;
-    top:0px;
-    z-index: 2147483647;
-}
-#fe-helper-box #fe-helper-minusthick,
-#fe-helper-box #fe-helper-plusthick,
-#fe-helper-box #fe-helper-closethick{
-    float:right;
-	cursor:pointer;
-	margin:5px 5px 0 ;
-}
-#fe-helper-box #fe-helper-minusthick:hover,
-#fe-helper-box #fe-helper-plusthick:hover,
-#fe-helper-box #fe-helper-closethick:hover{
-    background:#c00;
-}
-
-#fe-helper-box table {
-	font-size:11px;
-	border:2px solid #366EB9;
-	border-collapse:collapse;
-	width:100%;
-	table-layout:fixed;
-}
-#fe-helper-box table th,
-#fe-helper-box table td {
-	vertical-align:middle;
-	padding:3px 10px;
-	border:1px solid #eee;
-}
-#fe-helper-box table .td-linenum {
-	background:#ffc;
-	color:#900;
-	font-weight:normal;
-	font-style:italic;
-	text-align:right;
-	-webkit-user-select:none;
-	width:10%;
-	cursor:default;
-}
-#fe-helper-box table .td-content {
-	text-align:left;
-	padding-left:10px;
-	width:90%;
-}
-#fe-helper-box table .td-content-title {
-	text-align:right;
-	padding-right:10px;
-	width:6%;
-}
-#fe-helper-box table .td-content-content {
-	text-align:left;
-	padding-left:10px;
-	width:84%;
-}
-#fe-helper-box table .td-content-content.-c-x-issue {
-	color:#555;
-}
-
-#fe-helper-box table .td-cookie-linenum {
-	background:#ffc;
-	color:#900;
-	font-weight:normal;
-	font-style:italic;
-	text-align:right;
-	-webkit-user-select:none;
-	width:5%;
-}
-#fe-helper-box table .td-cookie-name {
-	width:20%;
-	word-wrap:break-word;
-}
-#fe-helper-box table .td-cookie-value {
-	word-wrap:break-word;
-	width:30%;
-}
-#fe-helper-box table .td-cookie-domain {
-	width:15%;
-}
-#fe-helper-box table .td-cookie-expires {
-	width:20%;
-}
-#fe-helper-box table .td-cookie-op {
-	width:10%;
-	text-align:center;
-}
-
-#fe-helper-box table thead td{
-	background:#366EB9;
-	font-weight:bold;
-	height:20px;
-	text-align:center;
-	color:#ff0;
-	cursor:default;
-}
-#fe-helper-box table thead .td-content-title {
-	border-right:none;
-}
-#fe-helper-box table thead .td-content-content {
-	border-left:none;
-	text-align:center;
-}
-#fe-helper-box table tbody tr.tr-content-even {
-	background:#F3FAFF;
-}
-#fe-helper-box table tbody tr:hover {
-	background:#ffa;
-}
-#fe-helper-box table tbody .-x-issue{
-	color:#b00;
-}
-#fe-helper-box table tbody .-x-suggestion{
-	color:#00b;
-}
-
-#fe-helper-box .x-selector {
-	color:#00f;
-}
-#fe-helper-box .x-css-text {
-	color:#aaa;
-	padding-left:20px;
-}
-#fe-helper-box .table-css-bg {
-	margin-left:40px;
-	margin-top:10px;
-}
-#fe-helper-box .table-css-bg div {
-	height:20px;
-}
-#fe-helper-box .table-css-bg div:hover {
-	background:#fff;
-}
-#fe-helper-box .x-expand {
-	margin-left:20px;
-	cursor:pointer;
-	color:#48b;
-	font-weight:bold;
-}
-#fe-img-tootip {
-	position:absolute;
-    z-index: 2147483647;
-	top:-10000px;
-	left:-10000px;
-}
-#f-h-p-m {
-	position:fixed;
-	top:0;
-	left:0;
-	bottom:0;
-	right:0;
-    z-index: 2147483646;
-	background:#000;
-	opacity:0.4;
-}
-#fe-helper-progress-bar-img {
-	position:fixed;
-    z-index: 2147483647;
-	width:800px;
-	height:20px;
-	line-height:20px;
-	text-align:center;
-	font-weight:bold;
-	color:#f00;
-	border:1px solid transparent;
-	-webkit-border-radius:2px 2px;
-}
-#fe-helper-progress-bar {
-	width:0px;
-	height:0px;
-}
-#fe-helper-acc-HTML-issue-sug,
-#fe-helper-acc-CSS-issue-sug,
-#fe-helper-acc-Javascript-issue-sug{
-	width:100%;
-	overflow:auto;
-}
-#fe-helper-box .-f-h-get-more- {
-	position:absolute;
-	bottom:10px;
-	right:20px;
-	color:#00f;
-}
-#fe-helper-grid {
-	position:absolute;
-	top:0;
-	left:0;
-	z-index:2147483647;
-	opacity:0.2;
-	overflow:hidden;
-	-webkit-user-select:none;
-}
-#fe-helper-btn-close-grid {
-	position:fixed;
-	bottom:10px;
-	right:10px;
-	font-size:12px;
-	font-weight:bold;
-	color:#00f;
-	z-index:2147483647;
-	cursor:pointer;
-}
-#fe-helper-btn-close-grid:hover {
-	color:#f00;
-}
-#fe-helper-g-pos {
-	background:none;
-	position:absolute;
-	top:0;
-	left:0;
-	z-index:2147483646;
-	border:1px solid #0b0;
-	border-width:0 1px 1px 0;
-}
-#fe-helper-gp-info {
-	position:absolute;
-	z-index:2147483646;
-	background:#ffc;
-	border:1px solid #666;
-	font-size:12px;
-	text-align:left;
-	padding:2px 10px;
-	display:none;
-	color:#000;
-}
-
-#fe-helper-ruler-top {
-	position:fixed;
-	top:0;
-	left:0;
-	right:0;
-	height:20px;
-	background:#fff;
-	border-bottom:1px solid #000;
-	z-index:2147483647;
-	overflow:hidden;
-}
-#fe-helper-ruler-left {
-	position:fixed;
-	top:0px;
-	left:0;
-	bottom:0;
-	width:20px;
-	background:#fff;
-	border-right:1px solid #000;
-	z-index:2147483647;
-	overflow:hidden;
-}
-#fe-helper-ruler-top .h-line{
-	position:absolute;
-	width:1px;
-	background:#000;
-}
-#fe-helper-ruler-top .h-text{
-	position:absolute;
-	top:0;
-	font-size:8px;
-	color:#000;
-}
-#fe-helper-ruler-left .v-line{
-	position:absolute;
-	height:1px;
-	background:#000;
-}
-#fe-helper-ruler-left .v-text{
-	position:absolute;
-	left:0;
-	font-size:8px;
-	color:#000;
-	-webkit-transform:rotate(90deg);
-	margin-top:4px;
-}

+ 0 - 84
static/css/fe-jsonformat.css

@@ -1,84 +0,0 @@
-#jfContent{-webkit-user-select:text;margin:0;}
-#optionBar{-webkit-user-select:none;display:block;position:absolute;top:0px;right:0px}
-#buttonFormatted,#buttonPlain{-webkit-border-radius:2px;-webkit-box-shadow:0px 1px 3px rgba(0,0,0,0.1);
-	-webkit-user-select:none;background:-webkit-linear-gradient(#fafafa, #f4f4f4 40%, #e5e5e5);
-	border:1px solid #aaa;color:#444;font-size:12px;margin-bottom:0px;min-width:4em;padding:3px 0;
-	position:relative;z-index:10;display:inline-block;width:80px;
-	text-shadow:1px 1px rgba(255,255,255,0.3)}
-#buttonFormatted{margin-left:0;border-top-left-radius:0;border-bottom-left-radius:0}
-#buttonPlain{margin-right:0;border-top-right-radius:0;border-bottom-right-radius:0;border-right:none}
-#buttonFormatted:hover,#buttonPlain:hover{-webkit-box-shadow:0px 1px 3px rgba(0,0,0,0.2);
-	background:#ebebeb -webkit-linear-gradient(#fefefe, #f8f8f8 40%, #e9e9e9);border-color:#999;color:#222}
-#buttonFormatted:active,#buttonPlain:active{-webkit-box-shadow:inset 0px 1px 3px rgba(0,0,0,0.2);
-	background:#ebebeb -webkit-linear-gradient(#f4f4f4, #efefef 40%, #dcdcdc);color:#333}
-#buttonFormatted.selected,#buttonPlain.selected{-webkit-box-shadow:inset 0px 1px 5px rgba(0,0,0,0.2);
-	background:#ebebeb -webkit-linear-gradient(#e4e4e4, #dfdfdf 40%, #dcdcdc);color:#333}
-#jsonpOpener,#jsonpCloser{padding:4px 0 0 8px;color:black;margin-bottom:-6px}
-#jsonpCloser{margin-top:0}
-#formattedJson{padding-left:28px;padding-top:6px}pre{padding:36px 5px 5px 5px}
-.kvov{display:block;padding-left:20px;margin-left:-20px;position:relative}
-.collapsed{white-space:nowrap}.collapsed>.blockInner{display:none}
-.collapsed>.ell:after{content:"…";font-weight:bold}
-.collapsed>.ell{margin:0 4px;color:#888}
-.collapsed .kvov{display:inline}
-.e{width:20px;height:18px;display:block;position:absolute;left:-2px;top:1px;z-index:5;
-	background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAICAYAAADED76LAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAD1JREFUeNpiYGBgOADE%2F3Hgw0DM4IRHgSsDFOzFInmMAQnY49ONzZRjDFiADT7dMLALiE8y4AGW6LoBAgwAuIkf%2F%2FB7O9sAAAAASUVORK5CYII%3D");
-	background-repeat:no-repeat;background-position:center center;display:block;opacity:0.15}
-.collapsed>.e{-webkit-transform:rotate(-90deg);width:18px;height:20px;left:0px;top:0px}
-.e:hover{opacity:0.35}.e:active{opacity:0.5}.collapsed .kvov .e{display:none}
-.blockInner{display:block;padding-left:24px;border-left:1px dotted #bbb;margin-left:2px}
-#formattedJson,#jsonpOpener,#jsonpCloser{color:#333;font:13px/18px monospace}
-#formattedJson{color:#444}.b{font-weight:bold}.s{color:#0B7500;word-wrap:break-word}
-#jfContent a:link,jfContent a:visited{text-decoration:none;color:inherit}
-#jfContent a:hover,#jfContent a:active{text-decoration:underline;color:#050}
-.bl,.nl,.n{font-weight:bold;color:#1A01CC}.k{color:black}
-#formattingMsg{font:13px "Lucida Grande", "Segoe UI", "Tahoma";padding:10px 0 0 8px;margin:0;color:#333;display:none;}
-#formattingMsg>svg{margin:0 7px;position:relative;top:1px}
-[hidden]{display:none !important}
-#jfContentspan{white-space:pre-wrap}
-@-webkit-keyframes spin{from{-webkit-transform:rotate(0deg)}to{-webkit-transform:rotate(360deg)}}
-#spinner{-webkit-animation:spin 1s 0 infinite}*{-webkit-font-smoothing:antialiased}
-#jfContent .x-json-tips {
-	color:red;
-}
-#jfContent_pre {padding:0;margin:0;
-	word-break:break-word;
-}
-
-html {
-	background:url(../img/baidufe_bj.gif);
-	font-size: 14px;
-	color:#333;
-}
-.mod-json {
-	width:980px;
-	margin:0 auto;
-	position: relative;
-}
-.mod-json fieldset {
-	border : 1px solid #bbb;
-	margin:0 0 10px;
-}
-.mod-json fieldset legend {
-	padding:0 5px;
-	color:red;
-}
-.mod-json .format-item {
-	line-height: 16px;
-}
-.mod-json .format-item textarea{
-	width:970px;
-	height:120px;
-	padding:2px 5px;
-	margin:0 auto;
-	resize:none;
-}
-.mod-json .format-item button{
-	width:80px;
-	height:30px;
-	float: right;
-}
-.mod-json .rst-item {
-	position: relative;
-	padding-top:30px;
-}

+ 0 - 129
static/css/fe-opt.css

@@ -1,129 +0,0 @@
-body {
-	font-family:"MS Sans Serif";
-	font-size:14px;
-}
-.fe-opt-header {
-	height:120px;
-	width:100%;
-	position:fixed;
-	top:0;
-	left:0;
-}
-.fe-opt-header .top{
-	padding:10px;
-}
-.fe-opt-header .top img{
-	width:60px;
-}
-.fe-opt-header .top .text{
-	font-size:20pt;
-	position:absolute;
-	top:30px;
-	left:80px;
-}
-.fe-opt-header .top .copy-right{
-	font-size:12px;
-	position:absolute;
-	bottom:35px;
-	right:10px;
-	color:#77C;
-}
-.fe-opt-header .bar{
-	height:30px;
-	width:100%;
-	position:absolute;
-	bottom:0;
-	left:0;
-	border-top:1px solid #78b;
-	background:#def;
-	clear:both;
-}
-.fe-opt-header .bar:after {
-	content:"\20";
-}
-
-.fe-opt-header .bar .text{
-	float:left;
-	padding:5px;
-}
-
-.fe-opt-header .bar .btn{
-	float:right;
-	margin:5px 10px;
-	font-weight:bold;
-	color:#00b;
-	cursor:pointer;
-}
-
-.fe-opt-header .bar .btn.close {
-	margin-left:0;
-	margin-right:20px;
-}
-.fe-opt-header .bar .btn:hover {
-	color:#b00;
-}
-
-.fe-opt-content {
-	position:absolute;
-	top:120px;
-	left:0;
-	bottom:0;
-	right:0;
-}
-.fe-opt-content .left{
-	position:absolute;
-	top:0;
-	left:0;
-	bottom:0;
-	width:200px;
-	border-right:5px solid #def;
-}
-.fe-opt-content .left ul{
-	margin:0;
-	padding:5px;
-}
-.fe-opt-content .left li{
-	padding:6px 0 6px 20px;
-	cursor:default;
-	margin:4px 0;
-	list-style:none;
-}
-.fe-opt-content .left li:hover{
-	background:#eee;
-	color:#b00;
-}
-.fe-opt-content .left li.selected{
-	background:#eee;
-	color:#b00;
-}
-.fe-opt-content .right{
-	position:absolute;
-	left:210px;
-}
-.fe-opt-content .right .title{
-	margin:20px 0 10px;
-	color:#48b;
-	font-weight:bold;
-}
-.fe-opt-content .right ul{
-	margin:0px;
-	padding:5px;
-}
-.fe-opt-content .right ul li{
-	margin:0 0 0 20px;
-	padding:5px;
-}
-.fe-opt-content .right ul.no-list-style li{
-	margin:0;
-	list-style:none;
-}
-.fe-opt-content .right ul li:hover{
-	background:#f8f8f0;
-}
-.fe-hide {
-	display:none;
-}
-
-.fe-opt-footer {
-	
-}

+ 0 - 83
static/css/fe-popup.css

@@ -1,83 +0,0 @@
-body {
-	font-size:14px;
-	font-family:"arial","simsun";
-	-webkit-user-select:none;
-	padding:0;
-	margin:0;
-	width:150px;
-	position:relative;
-	overflow: hidden;
-}
-.fe-hide {
-	display:none;
-}
-.fe-function-title {
-	width:100%;
-	padding:5px;
-	color:#522;
-	font-weight:bolder;
-	cursor:default;
-	border-bottom:1px dotted #aaa;
-}
-ul.fe-function-list {
-	padding:0px;
-	list-style:none;
-}
-ul.fe-function-list li {
-	padding:3px 3px 3px 10px;
-	cursor:pointer;
-	color:#555;
-	-webkit-transition:all .4s ease;
-}
-ul.fe-function-list li:hover {
-	color:#ff3C11;
-	background:#f1f1f1;
-}
-ul.fe-function-list li>span {
-	padding-left:24px;
-}
-ul.fe-function-list li>b{
-	width:14px;
-	height:14px;
-	background:url(../img/ui-icons_228ef1_256x240.png) no-repeat ;
-	-webkit-transition:all .5s ease;
-	position:absolute;
-}
-ul.fe-function-list li:hover>b {
-	-webkit-transform:rotate(360deg);
-}
-ul.fe-function-list li.-x-fcp b {
-	background-position:0px -145px;
-}
-ul.fe-function-list li.-x-grid b {
-	background-position:-113px -113px;
-}
-ul.fe-function-list li.-x-fdp b {
-	background-position:-162px -113px;
-}
-ul.fe-function-list li.-x-endecode b {
-	background-position:-113px -81px;
-}
-ul.fe-function-list li.-x-loadtime b {
-	background-position:-81px -113px;
-}
-ul.fe-function-list li.-x-jsonformat b {
-	background-position:-224px -113px;
-}
-ul.fe-function-list li.-x-qrcode b {
-	background-position:-81px -209px;
-}
-.fe-feedback {
-	font-size:12px;
-	border-top:1px dotted #ddd;
-	padding:5px 15px 5px 5px;
-	text-align:right;
-}
-.fe-feedback  a {
-	text-decoration:none;
-	color:#888;
-}
-.fe-feedback  a:hover {
-	color:#a00;
-}
-

+ 0 - 57
static/css/fe-qrcode.css

@@ -1,57 +0,0 @@
-html {
-	background:url(../img/baidufe_bj.gif);
-	font-size: 14px;
-	color:#333;
-}
-.mod-qrcode {
-	width:980px;
-	margin:0 auto;
-}
-.mod-qrcode fieldset {
-	border : 1px solid #bbb;
-	padding:10px;
-	width:960px;
-	margin-bottom: 10px;
-}
-.mod-qrcode fieldset legend {
-	padding:0 5px;
-	color:red;
-}
-.mod-qrcode fieldset>div {
-	margin-bottom: 10px;
-}
-.mod-qrcode .qr-item {
-	line-height: 16px;
-}
-#source,#size{
-	width:30px;
-	height:22px;
-	padding:2px 5px;
-}
-#source {
-	width : 800px;
-	height:50px;
-}
-.mod-qrcode .qr-item button{
-	width:80px;
-	height:30px;
-	float: right;
-	margin-right: 17px;
-}
-.mod-qrcode a {
-	color:#009;
-}
-#demo .item {
-	border-bottom:1px solid #ccc;
-	font-size: 12px;
-	margin:10px 80px 10px 70px;
-}
-#demo .item .title {
-	color:red;
-	font-weight: bold;
-	margin-right:10px;
-	float: left;
-}
-#demo .item .test {
-
-}

BIN
static/img/43.png


BIN
static/img/baidufe_bj.gif


BIN
static/img/fe-128.png


BIN
static/img/fe-16.png


BIN
static/img/fe-48.png


BIN
static/img/grid.png


BIN
static/img/pbar-ani.gif


BIN
static/img/ui-icons_228ef1_256x240.png


+ 0 - 153
static/js/core/core.js

@@ -1,153 +0,0 @@
-/**
- * @author 赵先烈([email protected]
- * @class 类库
- */
-var baidu = function(){
-	this.version = "1.3.5";
-};
-
-/**
- * 增加命名空间机制
- */
-baidu.namespace = new Object();
-
-/**
- * 注册命名空间
- * @param {String} fullNS 完整的命名空间字符串,如baidu.libs.Firefox
- * @example baidu.namespace.register("baidu.libs.Firefox");
- */
-baidu.namespace.register = function(fullNS){
-	//命名空间合法性校验依据
-	var reg = /^[_$a-z]+[_$a-z0-9]*/i;
-	
-    // 将命名空间切成N部分, 比如baidu.libs.Firefox等
-    var nsArray = fullNS.split('.');
-    var sEval = "";
-    var sNS = "";
-    for (var i = 0; i < nsArray.length; i++){
-		//命名空间合法性校验
-		if(!reg.test(nsArray[i])) {
-			throw new Error("Invalid namespace:" + nsArray[i] + "");
-			return ;
-		}
-
-        if (i != 0) sNS += ".";
-        sNS += nsArray[i];
-        // 依次创建构造命名空间对象(假如不存在的话)的语句
-        sEval += "if (typeof(" + sNS + ") == 'undefined') " + sNS + " = new Object();";
-    }
-	//生成命名空间
-    if (sEval != "") eval(sEval);
-};
-
-/**
- * 让所有字符串支持空白过滤功能:trim
- * @retrn {String} 返回两端无空白的字符串
- */
-String.prototype.trim = function(){
-	return this.replace(/^\s*|\s*$/g,"");
-};
-
-/**
- * 字符串的format方法
- */
-String.prototype.format = function(){
-    var $ = arguments.length, _ = this;
-    while ($--) 
-        _ = _.replace(new RegExp("\\{" + $ + "\\}", "g"), arguments[$]);
-    return _
-};
-
-/**
- * 日期格式化
- * @param {Object} pattern
- */
-Date.prototype.format = function(pattern){
-	var pad = function (source, length) {
-	    var pre = "",
-	        negative = (source < 0),
-	        string = String(Math.abs(source));
-	
-	    if (string.length < length) {
-	        pre = (new Array(length - string.length + 1)).join('0');
-	    }
-	
-	    return (negative ?  "-" : "") + pre + string;
-	};
-	
-	if ('string' != typeof pattern) {
-        return this.toString();
-    }
-
-    var replacer = function(patternPart, result) {
-        pattern = pattern.replace(patternPart, result);
-    }
-    
-    var year    = this.getFullYear(),
-        month   = this.getMonth() + 1,
-        date2   = this.getDate(),
-        hours   = this.getHours(),
-        minutes = this.getMinutes(),
-        seconds = this.getSeconds();
-
-    replacer(/yyyy/g, pad(year, 4));
-    replacer(/yy/g, pad(parseInt(year.toString().slice(2), 10), 2));
-    replacer(/MM/g, pad(month, 2));
-    replacer(/M/g, month);
-    replacer(/dd/g, pad(date2, 2));
-    replacer(/d/g, date2);
-
-    replacer(/HH/g, pad(hours, 2));
-    replacer(/H/g, hours);
-    replacer(/hh/g, pad(hours % 12, 2));
-    replacer(/h/g, hours % 12);
-    replacer(/mm/g, pad(minutes, 2));
-    replacer(/m/g, minutes);
-    replacer(/ss/g, pad(seconds, 2));
-    replacer(/s/g, seconds);
-
-    return pattern;
-};
-
-/**
- * 获取某字符串的字节数
- */
-String.prototype.getBytes = function () {
-    var stream = this.replace(/\n/g, 'xx').replace(/\t/g, 'x');
-    var escapedStr = encodeURIComponent(stream);
-    return escapedStr.replace(/%[A-Z0-9][A-Z0-9]/g, 'x').length;
-}
-
-/**
- * 获取某个节点的outerhtml,超过40个字符,则以...代替
- * @param {} elm
- */
-var getOuterHtmlEllipsis = function(elm) {
-	var reg = /(<[^>]+>)/g;
-	var arr = reg.exec(elm.outerHTML);
-	var rst = arr ? arr[1] : elm.outerHTML;
-	rst = rst.length > 40 ? rst.substr(0,40) + '...' : rst;
-	return rst.replace(/</g,'&lt;').replace(/>/g,'&gt;');
-};
-
-/**
- * 获取某节点的整个html片段,超过40个字符,则以...代替
- * @param {Object} elm
- */
-var getOuterAndInnerHtmlEllipsis = function(elm){
-	var rst = jQuery('<div></div>').append(elm).html();
-};
-
-(function(){
-    baidu.i18n = {};
-    baidu.i18n.getMessage = function(msgId,arr){
-        if(arr) {
-            for(var i=0,len=arr.length;i<len;i++){
-                arr[i] = '' + arr[i];
-            }
-            return chrome.i18n.getMessage(msgId,arr);
-        }else{
-            return chrome.i18n.getMessage(msgId);
-        }
-    };
-})();

+ 0 - 391
static/js/core/fe-const.js

@@ -1,391 +0,0 @@
-
-/**
- * 常量定义
- * @author zhaoxianlie 
- */
-
-/**
- * 各个模块进行信息交互时的消息类型
- */
-const MSG_TYPE = {
-	//browserAction被点击
-	BROWSER_CLICKED : "browser-clicked",
-	//提取CSS
-	GET_CSS : "get-css",
-	//提取JS
-	GET_JS : "get-js",
-	//提取HTML
-	GET_HTML : "get-html",
-	//cookie
-	GET_COOKIE : 'get-cookie',
-	//remvoe cookie
-	REMOVE_COOKIE : 'remove-cookie',
-	//set cookie
-	SET_COOKIE : 'set-cookie',
-	//get options
-	GET_OPTIONS : 'get_options',
-	//set options
-	SET_OPTIONS : 'set_options',
-	
-	//css ready...
-	CSS_READY : 'css-ready',
-	
-	//js ready...
-	JS_READY : 'js-ready',
-	
-	//html ready...
-	HTML_READY : 'html-ready',
-	
-	//启动项
-	START_OPTION : 'start-option',
-	//启动FCPHelper
-	OPT_START_FCP : 'opt-item-fcp',
-	//启动栅格检测
-	OPT_START_GRID : 'opt-item-grid',
-	
-	//计算网页加载时间
-	CALC_PAGE_LOAD_TIME : "calc-page-load-time",
-	//查看加载时间
-	SHOW_PAGE_LOAD_TIME : "show-page-load-time",
-	
-	//执行FCP Helper检测
-	FCP_HELPER_DETECT : 'fcp-helper-detect',
-	//执行栅格检测
-	GRID_DETECT : 'grid-detect',
-	//进行FDP平台文件检索
-	FDP_HELPER : 'fdp-helper',
-	//字符串编解码
-	EN_DECODE : 'en-decode',
-	//json查看器
-	JSON_FORMAT : 'json_format',
-	//QR生成器
-	QR_CODE : 'qr_code',
-
-	//页面相关性能数据
-	GET_PAGE_WPO_INFO : 'get_page_wpo_info'
-};
-
-/**
- * 文件类型
- */
-const FILE = {
-	//css的<style>标签
-	STYLE : "style",
-	//css的<link>标签
-	LINK : "link",
-	//js:通过script定义的内联js
-	SCRIPT : "script-block"
-};
-
-//首先配一个DTD中的白名单
-const PUBLIC_ID_WHITE_LIST = {
-    '': {
-        systemIds: {
-            '': true
-        }
-    },
-    '-//W3C//DTD HTML 3.2 Final//EN': {
-        systemIds: {
-            '': true
-        }
-    },
-    '-//W3C//DTD HTML 4.0//EN': {
-        systemIds: {
-            '': true,
-            'http://www.w3.org/TR/html4/strict.dtd': true
-        }
-    },
-    '-//W3C//DTD HTML 4.01//EN': {
-        systemIds: {
-            '': true,
-            'http://www.w3.org/TR/html4/strict.dtd': true
-        }
-    },
-    '-//W3C//DTD HTML 4.0 Transitional//EN': {
-        systemIds: {
-            '': true,
-            'http://www.w3.org/TR/html4/loose.dtd': true
-        }
-    },
-    '-//W3C//DTD HTML 4.01 Transitional//EN': {
-        systemIds: {
-            '': true,
-            'http://www.w3.org/TR/html4/loose.dtd': true,
-            'http://www.w3.org/TR/1999/REC-html401-19991224/loose.dtd': true
-        }
-    },
-    '-//W3C//DTD XHTML 1.1//EN': {
-        systemIds: {
-            'http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd': true
-        }
-    },
-    '-//W3C//DTD XHTML Basic 1.0//EN': {
-        systemIds: {
-            'http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd': true
-        }
-    },
-    '-//W3C//DTD XHTML 1.0 Strict//EN': {
-        systemIds: {
-            'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd': true
-        }
-    },
-    '-//W3C//DTD XHTML 1.0 Transitional//EN': {
-        systemIds: {
-            'http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd': true
-        }
-    },
-    'ISO/IEC 15445:1999//DTD HyperText Markup Language//EN': {
-        systemIds: {
-            '': true
-        }
-    },
-    'ISO/IEC 15445:2000//DTD HTML//EN': {
-        systemIds: {
-            '': true
-        }
-    },
-    'ISO/IEC 15445:1999//DTD HTML//EN': {
-        systemIds: {
-            '': true
-        }
-    }
-};
-
-/**
- * IE和Webkit对Doctype的解析差异
- */
-const COMPAT_MODE_DIFF_PUBLIC_ID_MAP = {
-    '-//W3C//DTD HTML 4.0 Transitional//EN': {
-        systemIds: {
-            'http://www.w3.org/TR/html4/loose.dtd': {
-                IE: 'S',
-                WebKit: 'Q'
-            }
-        }
-    },
-    'ISO/IEC 15445:2000//DTD HTML//EN': {
-        systemIds: {
-            '': {
-                IE: 'Q',
-                WebKit: 'S'
-            }
-        }
-    },
-    'ISO/IEC 15445:1999//DTD HTML//EN': {
-        systemIds: {
-            '': {
-                IE: 'Q',
-                WebKit: 'S'
-            }
-        }
-    }
-};
-
-
-/**
- * 过时的HTML标签,HTML5已经不再支持
- */
-const HTML_DEPRECATED_TAGS = {
-    acronym: "定义首字母缩写",
-    applet: "定义Java Applet",
-    basefont: "定义Font定义",
-    big: "定义大号文本",
-    center: "定义居中的文本",
-    dir: "定义目录列表",
-    font: "定义文字相关",
-    frame: "定义框架",
-    frameset: "定义框架集",
-    isindex: "定义单行的输入域",
-    noframes: "定义noframe 部分",
-    s: "定义加删除线的文本",
-    strike: "定义加删除线的文本",
-    tt: "定义打字机文本",
-    u: "定义下划线文本",
-    xmp: "定义预格式文本",
-    layer: "定义层"
-}
-
-/**
- * 过时的HTML属性,HTML5已经不再支持
- */
-const HTML_DEPRECATED_ATTRIBUTES = {
-    align: {
-        iframe: true,
-        img: true,
-        object: true,
-        table: true
-    },
-    color: {
-        font: true
-    },
-    height: {
-        td: true,
-        th: true
-    },
-    language: {
-        script: true
-    },
-    noshade: {
-        hr: true
-    },
-    nowrap: {
-        td: true,
-        th: true
-    },
-    size: {
-        hr: true,
-        font: true,
-        basefont: true
-    }
-};
-
-/**
- * 块级元素
- */
-const BLOCK_HTML_ELEMENT = [
-	'address','blockquote','center','dir',
-	'div','dl','fieldset','form','h1','h2',
-	'h3','h4','h5','h6','hr','isindex','menu',
-	'noframes','noscript','ol','p','pre','table','ul'
-];
-
-/**
- * 内联元素
- */
-const INLINE_HTML_ELEMENT = [
-	'a','acronym','b','bdo','big','br','cite','code',
-	'dfn','em','font','i','img','input','kbd','label',
-	'q','s','samp','select','small','span','strike','strong',
-	'sub','sup','textarea','tt','u','var'
-];
-
-
-/**
- * 可变元素:为根据上下文语境决定该元素为块元素或者内联元素。
- */
-const CHANGE_ABLE_HTML_ELEMENT = [
-	'applet','button','del','iframe',
-	'ins','map','object','script'
-];
-
-//关于IE的条件注释,可以参考这里:http://msdn.microsoft.com/en-us/library/ms537512(v=vs.85).aspx
-
-//条件注释的正则匹配规则
-const CONDITIONAL_COMMENT_REGEXP = /\[\s*if\s+[^\]][\s\w]*\]/i;
-
-// 非IE条件注释开始:<![if !IE]> or <![if false]>
-const NOT_IE_REVEALED_OPENING_CONDITIONAL_COMMENT_REGEXP = /^\[if\s+(!IE|false)\]$/i;
-
-// IE条件注释结束:<![endif]>
-const REVEALED_CLOSING_CONDITIONAL_COMMENT_REGEXP = /^\[endif\s*\]$/i;
-
-// 非IE的条件注释整体:  <!--[if !IE]> HTML <![endif]--> or  <!--[if false]> HTML <![endif]-->
-const NOT_IE_HIDDEN_CONDITIONAL_COMMENT_REGEXP = /^\[if\s+(!IE|false)\]>.*<!\[endif\]$/i;
-
-
-/* 正则 */
-const REG = {
-	//script标签
-    SCRIPT: /<script[^>]*>[\s\S]*?<\/[^>]*script>/gi,
-	//注释	
-    COMMENT: /<!--[\s\S]*?--\>/g,
-	//cssExpression
-    CSS_EXPRESSION: /expression[\s\r\n ]?\(/gi,
-	//textarea
-	TEXTAREA:/<textarea[^>]*>[\s\S]*?<\/[^>]*textarea>/gi,
-	//不合法的标签
-	INVALID_TAG:/<\W+>/gi
-};
-
-/**
- * 能够自动闭合的标签,就算不闭合也不影响兄弟节点的布局
- */
-const SELF_CLOSING_TAGS = [
-	'meta','link','area','base',
-	'col','input','img','br',
-	'hr','param','embed'
-];
-
-/**
- * 限定HTML嵌套的最大深度为30
- * @type Number
- */
-const HTML_DOM_MAX_DEPTH = 30;
-
-/**
- * 统计项
- */
-const LOG = {
-	//选项页面:【打开】
-	options_page_opened			:	"m_20111124_options_page_opened",
-	//选项页面:【保存】
-	options_page_btnsave		:	"m_20111124_options_page_btnsave",
-	//选项页面:【关闭】
-	options_page_btnclose		:	"m_20111124_options_page_btnclose",
-	
-	//popup页面:【显示】
-	popup_page_show				:	"m_20111124_popup_page_show",
-	//popup页面:【编码规范检测】
-	popup_page_fcp				:	"m_20111124_popup_page_fcp",
-	//popup页面:【栅格规范检测】
-	popup_page_grid				:	"m_20111124_popup_page_grid",
-	//popup页面:【FE文档检索】
-	popup_page_fdp				:	"m_20111124_popup_page_fdp",
-	//popup页面:【字符串编解码】
-	popup_page_endecode			:	"m_20111124_popup_page_endecode",
-	//popup页面:【网页加载耗时】
-	popup_page_loadtime			:	"m_20111124_popup_page_loadtime",
-	
-	//编解码工具:【打开】
-	endecode_page_opened		:	"m_20111124_endecode_page_opened",
-	//编解码工具:【Unicode编码】
-	endecode_page_uniEncode		:	"m_20111124_endecode_page_uniEncode",
-	//编解码工具:【Unicode解码】
-	endecode_page_uniDecode		:	"m_20111124_endecode_page_uniDecode",
-	//编解码工具:【UTF-8编码】
-	endecode_page_utf8Encode	:	"m_20111124_endecode_page_utf8Encode",
-	//编解码工具:【UTF-8解码】
-	endecode_page_utf8Decode	:	"m_20111124_endecode_page_utf8Decode",
-	//编解码工具:【Base64编码】
-	endecode_page_base64Encode	:	"m_20111124_endecode_page_base64Encode",
-	//编解码工具:【base64解码】
-	endecode_page_base64Decode	:	"m_20111124_endecode_page_base64Decode",
-	//编解码工具:【转换】
-	endecode_page_btnchange		:	"m_20111124_endecode_page_btnchange",
-	//编解码工具:【清空】
-	endecode_page_btnclear		:	"m_20111124_endecode_page_btnclear",
-	
-	//文档检索:【打开】
-	fdp_page_opened				:	"m_20111124_fdp_page_opened",
-	//文档检索:【空间FE文档】
-	fdp_page_spacedoc			:	"m_20111124_fdp_page_spacedoc",
-	//文档检索:【大FE文档】
-	fdp_page_fedoc				:	"m_20111124_fdp_page_fedoc",
-	//文档检索:【检索】
-	fdp_page_btnsearch			:	"m_20111124_fdp_page_btnsearch",
-	
-	//编码规范检测:【显示层】
-	fcp_detect_show				:	"m_20111124_fcp_detect_show",
-	//编码规范检测:【关闭检测结果】
-	fcp_detect_close			:	"m_20111124_fcp_detect_close",
-	//编码规范检测:【最小化检测结果】
-	fcp_detect_min				:	"m_20111124_fcp_detect_min",
-	//编码规范检测:【最大化检测结果】
-	fcp_detect_max				:	"m_20111124_fcp_detect_max",
-	//编码规范检测:【更多HTML规范】
-	fcp_detect_morehtml			:	"m_20111124_fcp_detect_morehtml",
-	//编码规范检测:【更多css规范】
-	fcp_detect_morecss			:	"m_20111124_fcp_detect_morecss",
-	//编码规范检测:【更多js规范】
-	fcp_detect_morejs			:	"m_20111124_fcp_detect_morejs",
-	
-	//栅格检测:【显示层】
-	grid_detect_show			:	"m_20111124_grid_detect_show",
-	//栅格检测:【ESC】
-	grid_detect_esc				:	"m_20111124_grid_detect_esc",
-	//栅格检测:【关闭栅格】
-	grid_detect_btnclose		:	"m_20111124_grid_detect_btnclose",
-	
-	//每天使用人数【粗略统计】
-	fehelper_user_count			:	"m_20111124_fehelper_user_count"
-};

Файлын зөрүү хэтэрхий том тул дарагдсан байна
+ 0 - 15
static/js/core/jquery-1.5.min.js


+ 0 - 34
static/js/core/log.js

@@ -1,34 +0,0 @@
-/**
- * 注册命名空间:baidu.log
- */
-baidu.namespace.register("baidu.log");
-
-/**
- * 百度前端统计
- * @author 赵先烈
- */
-baidu.log = (function(){
-	/**
-     * 空间统计,使用log平台
-     * <pre><code>
-     * qing.ext.stat.ns_trackerLink("m_20110709_enter","http://hi.baidu.com");
-     * </code></pre>
-     * @param {String} m m值,区别不同统计项。推荐格式为 m_时期_tag,如 m_20110709_showpop
-     * @param {String} url (optional) 统计对应的url,可以不填或为空字符串
-     */
-    var ns_trackerLink = function(m, url){ 
-        var pid = 109,  //space
-            type = 2009,    //暂定为普通的统计编号
-            srcUrl = 'http://nsclick.baidu.com/v.gif?pid='+pid+'&url='+encodeURIComponent(url)+'&type='+type+'&m='+m+'&_t='+Math.random();  //LOG统计地址
-		
-        var n = "imglog__"+ (new Date()).getTime(),
-            c = window[n] = new Image();
-        c.onload=(c.onerror=function(){window[n] = null;});  
-        c.src = srcUrl;  //LOG统计地址
-        c = null;//释放变量c,避免产生内存泄漏的可能
-    };
-	
-	return {
-		track : ns_trackerLink
-	};
-})();

+ 0 - 138
static/js/core/network.js

@@ -1,138 +0,0 @@
-/**
- * 注册命名空间:baidu.network
- */
-baidu.namespace.register("baidu.network");
-
-
-/**
- * 后端网络处理,ajax等
- * @author zhaoxianlie 
- */
-baidu.network = (function(){
-    /**
-     * 通过这个方法来读取服务器端的CSS文件内容,要这样做,前提是在manifest.json中配置permissions为:http://
-     * @param {String} link 需要读取的css文件
-     * @param {Function} callback 回调方法,格式为:function(respData){}
-     * @config {Object} respData 输出到客户端的内容,格式为{success:BooleanValue,content:StringValue}
-     * @return {Undefined} 无返回值
-     */
-    var _readFileContent = function(link,callback){
-        //创建XMLHttpRequest对象,用原生的AJAX方式读取内容
-        var xhr = new XMLHttpRequest();
-        //处理细节
-        xhr.onreadystatechange = function() {
-            //后端已经处理完成,并已将请求response回来了
-            if (xhr.readyState === 4) {
-                //输出到客户端的内容,格式为{success:BooleanValue,content:StringValue}
-                var respData;
-                //判断status是否为OK
-                if (xhr.status === 200 && xhr.responseText) {
-                    //OK时回送给客户端的内容
-                    respData = {
-                        success : true,	//成功
-                        type : FILE.LINK,	//<link>标签
-                        path : link,	//文件路径
-                        content : xhr.responseText	//文件内容
-                    };
-                } else {	//失败
-                    respData = {
-                        success : false,	//失败
-                        type : FILE.LINK,	//<link>标签
-                        path : link,	//文件路径
-                        content : "FcpHelper can't load such file."	//失败信息
-                    };
-                }
-                //触发回调,并将结果回送
-                callback(respData);
-            }
-        };
-        //打开读通道
-        xhr.open('GET', link, true);
-        //设置HTTP-HEADER
-        xhr.setRequestHeader("Content-Type","text/plain;charset=UTF-8");
-        xhr.setRequestHeader("Access-Control-Allow-Origin","*");
-        //开始进行数据读取
-        xhr.send();
-    };
-	
-    /**
-     * 从cookie中获取url
-     * @param {Object} cookie
-     */
-    var _urlFromCookie = function(cookie){
-        return "http" + (cookie.secure ? "s" : "") + "://" + cookie.domain + cookie.path;
-    };
-
-	/**
-	 * 获取页面上的所有cookie
-	 * @param {Object} callback
-	 */
-	var _getCookies = function(request,callback){
-		var arrCookies = [];
-		chrome.cookies.getAll({}, function(cookies){
-			for(var i=0,le=cookies.length;i<le;i++){
-				if(request.url.indexOf(cookies[i].domain.substring(1)) > -1) {
-					cookies[i].url = _urlFromCookie(cookies[i]);
-					arrCookies.push(cookies[i]);
-				}
-			}
-			
-			//排序
-			cookies.sort(function (a, b) { return a.domain.localeCompare(b.domain); });
-			
-			callback.call(null,{
-				cookie : arrCookies
-			});	
-        });
-	};
-	
-	/**
-	 * 移除某个cookie
-	 * @param {Object} request
-	 * @param {Object} callback
-	 */
-	var _removeCookie = function(request,callback){
-		chrome.cookies.getAll({}, function(cookies){
-			for(var i=0,le=cookies.length;i<le;i++){
-				var url = _urlFromCookie(cookies[i]);
-				var name = cookies[i].name;
-				if(url == request.url && name == request.name) {
-					chrome.cookies.remove({"url": url, "name": name});
-					if(callback && typeof callback == "function") {
-						callback.call(null);
-					}
-					return;
-				}
-			}
-        });
-	};
-	
-	/**
-	 * 设置某个cookie
-	 * @param {Object} request
-	 * @param {Object} callback
-	 */
-	var _setCookie = function(request,callback){
-		chrome.cookies.getAll({}, function(cookies){
-			for(var i=0,le=cookies.length;i<le;i++){
-				var url = _urlFromCookie(cookies[i]);
-				var name = cookies[i].name;
-				if(url == request.url && name == request.name) {
-					chrome.cookies.set(request);
-					if(callback && typeof callback == "function") {
-						callback.call(null);
-					}
-					return;
-				}
-			}
-        });
-	};
-	
-	return {
-		readFileContent : _readFileContent,
-		getCookies : _getCookies,
-		removeCookie : _removeCookie,
-		setCookie : _setCookie
-	};
-})();
-

+ 0 - 241
static/js/endecode/endecode-lib.js

@@ -1,241 +0,0 @@
-/**
- * 注册命名空间:baidu.endecode
- */
-baidu.namespace.register("baidu.endecode");
-
-/**
- * 本库提供几个常用方法:
- * 1、baidu.endecode.uniEncode(text);	将中文进行Unicode编码并输出
- * 2、baidu.endecode.base64Encode(text); 将文字进行base64编码并输出
- * 3、baidu.endecode.base64Decode(text); 将经过base64编码的文字进行base64解码并输出
- * 4、baidu.endecode.utf8Encode(text); 将文字进行utf-8编码并输出
- * 5、baidu.endecode.utf8Decode(text); 将经过utf-8编码的文字进行utf-8解码并输出
- */
-baidu.endecode = (function(){
-	//base64编码字符集
-	var _base64EncodeChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
-	//base64解码字符集
-    var _base64DecodeChars = new Array(
-		-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-		-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-		-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 62, -1, -1, -1, 63,
-		52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, -1, -1, -1,
-		-1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14,
-		15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1,
-		-1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40,
-		41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1, -1, -1);
-		
-		
-	/**
-	 * 此方法实现中文向Unicode的转码,与Jre中的"native2ascii"命令一样
-	 * @param {String} text 需要进行转码的字符串
-	 * @return {String} Unicode码
-	 */
-	var _uniEncode = function(text){
-	    text = escape(text.toString()).replace(/\+/g, "%2B");
-	    var matches = text.match(/(%([0-9A-F]{2}))/gi);
-	    if (matches) {
-	        for (var matchid = 0; matchid < matches.length; matchid++) {
-	            var code = matches[matchid].substring(1, 3);
-	            if (parseInt(code, 16) >= 128) {
-	                text = text.replace(matches[matchid], '%u00' + code);
-	            }
-	        }
-	    }
-	    text = text.replace('%25', '%u0025').replace(/%/g, "\\");
-	    
-	    return text;
-	};
-	
-	/**
-	 * 此方法用于将Unicode码解码为正常字符串
-	 * @param {Object} text
-	 */
-	var _uniDecode = function(text){
-	    text = text.replace(/\\/g, "%").replace('%u0025', '%25');
-		
-	    text = unescape(text.toString().replace(/%2B/g, "+"));
-	    var matches = text.match(/(%u00([0-9A-F]{2}))/gi);
-	    if (matches) {
-	        for (var matchid = 0; matchid < matches.length; matchid++) {
-	            var code = matches[matchid].substring(1, 3);
-	            var x = Number("0x" + code);
-				if (x >= 128) {
-	                text = text.replace(matches[matchid], code);
-	            }
-	        }
-	    }
-	    text = unescape(text.toString().replace(/%2B/g, "+"));
-	    
-	    return text;
-	};
-	
-	/**
-	 * 此方法用于将文字进行UTF-8编码
-	 * @param {Object} str 源码
-	 * @return {String} UTF-8码
-	 */
-	var _utf8Encode = function(str) {
-		var out, i, len, c;
-		out = "";
-		len = str.length;
-		for(i = 0; i < len; i++) {
-			c = str.charCodeAt(i);
-			if ((c >= 0x0001) && (c <= 0x007F)) {
-				out += str.charAt(i);
-			} else if (c > 0x07FF) {
-				out += String.fromCharCode(0xE0 | ((c >> 12) & 0x0F));
-				out += String.fromCharCode(0x80 | ((c >> 6) & 0x3F));
-				out += String.fromCharCode(0x80 | ((c >> 0) & 0x3F));
-			} else {
-				out += String.fromCharCode(0xC0 | ((c >> 6) & 0x1F));
-				out += String.fromCharCode(0x80 | ((c >> 0) & 0x3F));
-			}
-		}
-		return out;
-	};
-	
-	/**
-	 * 此方法用于将文字进行UTF-8解码
-	 * @param {Object} str
-	 * @return {String} 原文字
-	 */
-	var _utf8Decode = function(str){
-	    var out, i, len, c;
-	    var char2, char3;
-	    out = "";
-	    len = str.length;
-	    i = 0;
-	    while (i < len) {
-	        c = str.charCodeAt(i++);
-	        switch (c >> 4) {
-	            case 0:
-	            case 1:
-	            case 2:
-	            case 3:
-	            case 4:
-	            case 5:
-	            case 6:
-	            case 7:
-	                // 0xxxxxxx
-	                out += str.charAt(i - 1);
-	                break;
-	            case 12:
-	            case 13:
-	                // 110x xxxx  10xx xxxx
-	                char2 = str.charCodeAt(i++);
-	                out += String.fromCharCode(((c & 0x1F) << 6) | (char2 & 0x3F));
-	                break;
-	            case 14:
-	                // 1110 xxxx 10xx xxxx 10xx xxxx
-	                char2 = str.charCodeAt(i++);
-	                char3 = str.charCodeAt(i++);
-	                out += String.fromCharCode(((c & 0x0F) << 12) |
-	                ((char2 & 0x3F) << 6) |
-	                ((char3 & 0x3F) << 0));
-	                break;
-	        }
-	    }
-	    return out;
-	};
-		
-	/**
-	 * 此方法用于将文字进行base64编码
-	 * @param {Object} str 源码
-	 * @return {String} base64码
-	 */
-	var _base64Encode = function(str){
-	    var out, i, len;
-	    var c1, c2, c3;
-	    len = str.length;
-	    i = 0;
-	    out = "";
-	    while (i < len) {
-	        c1 = str.charCodeAt(i++) & 0xff;
-	        if (i == len) {
-	            out += _base64EncodeChars.charAt(c1 >> 2);
-	            out += _base64EncodeChars.charAt((c1 & 0x3) << 4);
-	            out += "==";
-	            break;
-	        }
-	        c2 = str.charCodeAt(i++);
-	        if (i == len) {
-	            out += _base64EncodeChars.charAt(c1 >> 2);
-	            out += _base64EncodeChars.charAt(((c1 & 0x3) << 4) | ((c2 & 0xF0) >> 4));
-	            out += _base64EncodeChars.charAt((c2 & 0xF) << 2);
-	            out += "=";
-	            break;
-	        }
-	        c3 = str.charCodeAt(i++);
-	        out += _base64EncodeChars.charAt(c1 >> 2);
-	        out += _base64EncodeChars.charAt(((c1 & 0x3) << 4) | ((c2 & 0xF0) >> 4));
-	        out += _base64EncodeChars.charAt(((c2 & 0xF) << 2) | ((c3 & 0xC0) >> 6));
-	        out += _base64EncodeChars.charAt(c3 & 0x3F);
-	    }
-	    return out;
-	};
-	    
-	/**
-	 * 此方法用于将文字进行base64解码
-	 * @param {Object} str 源码
-	 * @return {String} 源码
-	 */
-	var _base64Decode = function(str){
-	    var c1, c2, c3, c4;
-	    var i, len, out;
-	    len = str.length;
-	    i = 0;
-	    out = "";
-	    while (i < len) {
-	        /* c1 */
-	        do {
-	            c1 = _base64DecodeChars[str.charCodeAt(i++) & 0xff];
-	        }
-	        while (i < len && c1 == -1);
-	        if (c1 == -1) 
-	            break;
-	        /* c2 */
-	        do {
-	            c2 = _base64DecodeChars[str.charCodeAt(i++) & 0xff];
-	        }
-	        while (i < len && c2 == -1);
-	        if (c2 == -1) 
-	            break;
-	        out += String.fromCharCode((c1 << 2) | ((c2 & 0x30) >> 4));
-	        /* c3 */
-	        do {
-	            c3 = str.charCodeAt(i++) & 0xff;
-	            if (c3 == 61) 
-	                return out;
-	            c3 = _base64DecodeChars[c3];
-	        }
-	        while (i < len && c3 == -1);
-	        if (c3 == -1) 
-	            break;
-	        out += String.fromCharCode(((c2 & 0XF) << 4) | ((c3 & 0x3C) >> 2));
-	        /* c4 */
-	        do {
-	            c4 = str.charCodeAt(i++) & 0xff;
-	            if (c4 == 61) 
-	                return out;
-	            c4 = _base64DecodeChars[c4];
-	        }
-	        while (i < len && c4 == -1);
-	        if (c4 == -1) 
-	            break;
-	        out += String.fromCharCode(((c3 & 0x03) << 6) | c4);
-	    }
-		
-	    return out;
-	};
-
-	return {
-		uniEncode		: _uniEncode,
-		uniDecode		: _uniDecode,
-		base64Encode	: _base64Encode,
-		base64Decode	: _base64Decode,
-		utf8Encode		: _utf8Encode,
-		utf8Decode		: _utf8Decode
-	};
-})();
-

Энэ ялгаанд хэт олон файл өөрчлөгдсөн тул зарим файлыг харуулаагүй болно