Browse Source

厦门i健康1.4.8版本的代码作为初始版本

raolu 6 years ago
parent
commit
8ce5118251
100 changed files with 13676 additions and 0 deletions
  1. 33 0
      html/jkda/css/base.css
  2. 61 0
      html/jkda/css/event-profile.css
  3. 166 0
      html/jkda/css/info.css
  4. 9 0
      html/jkda/css/jianchabaogaoxiangqing.css
  5. 32 0
      html/jkda/css/jianchajianyan.css
  6. 13 0
      html/jkda/css/jiankangtijian.css
  7. 32 0
      html/jkda/css/jiankangtijianxiangqing.css
  8. 26 0
      html/jkda/css/jianyanbaogaoxiangqing.css
  9. 34 0
      html/jkda/css/jiuzhenjilu.css
  10. 51 0
      html/jkda/css/jiuzhenxiangqing.css
  11. 52 0
      html/jkda/css/shangchuanjiuzhenjilu-edit.css
  12. 51 0
      html/jkda/css/shangchuanjiuzhenjilu.css
  13. 445 0
      html/jkda/css/ss-style.css
  14. 1046 0
      html/jkda/css/template.css
  15. 573 0
      html/jkda/css/zx-style.css
  16. 154 0
      html/jkda/html/event-profile.html
  17. 73 0
      html/jkda/html/jianchajianyan.html
  18. 56 0
      html/jkda/html/jiankangtijian.html
  19. 1290 0
      html/jkda/html/jiankangtijianxiangqing.html
  20. 76 0
      html/jkda/html/jiuzhenjilu.html
  21. 241 0
      html/jkda/html/jiuzhenxiangqing.html
  22. 245 0
      html/jkda/html/shangchuanjiuzhenjilu-edit.html
  23. 261 0
      html/jkda/html/shangchuanjiuzhenjilu.html
  24. 52 0
      html/jkda/html/single-profile.html
  25. BIN
      html/jkda/images/baogaoxiangqing_icon.png
  26. BIN
      html/jkda/images/bingli_icon.png
  27. BIN
      html/jkda/images/binglibaogao_icon.png
  28. BIN
      html/jkda/images/bingqingmiaoshu_icon.png
  29. BIN
      html/jkda/images/checked_blue.png
  30. BIN
      html/jkda/images/chufang_icon.png
  31. BIN
      html/jkda/images/fenlei_btn.png
  32. BIN
      html/jkda/images/guanbi_btn.png
  33. BIN
      html/jkda/images/hongjiantou_icon.png
  34. BIN
      html/jkda/images/img/Rp.png
  35. BIN
      html/jkda/images/img/i-adm-sta.png
  36. BIN
      html/jkda/images/img/i-cli-dia.png
  37. BIN
      html/jkda/images/img/i-con-con.png
  38. BIN
      html/jkda/images/img/i-con-info.png
  39. BIN
      html/jkda/images/img/i-dia-basis.png
  40. BIN
      html/jkda/images/img/i-dia-rec.png
  41. BIN
      html/jkda/images/img/i-doc-info.png
  42. BIN
      html/jkda/images/img/i-down.png
  43. BIN
      html/jkda/images/img/i-drop-down.png
  44. BIN
      html/jkda/images/img/i-ess-info.png
  45. BIN
      html/jkda/images/img/i-hos-sum.png
  46. BIN
      html/jkda/images/img/i-ins-res.png
  47. BIN
      html/jkda/images/img/i-inspection-personnel.png
  48. BIN
      html/jkda/images/img/i-inspectors.png
  49. BIN
      html/jkda/images/img/i-ope-rec.png
  50. BIN
      html/jkda/images/img/i-pat-his.png
  51. BIN
      html/jkda/images/img/i-pat-info.png
  52. BIN
      html/jkda/images/img/i-pha-info.png
  53. BIN
      html/jkda/images/img/i-ref-info.png
  54. BIN
      html/jkda/images/img/i-switch.png
  55. BIN
      html/jkda/images/img/i-sym-rec.png
  56. BIN
      html/jkda/images/img/i-test-results.png
  57. BIN
      html/jkda/images/img/i-up.png
  58. BIN
      html/jkda/images/img/i-visiting-result.png
  59. BIN
      html/jkda/images/jianchabaogao_icon.png
  60. BIN
      html/jkda/images/jiankangxiangqing_icon.png
  61. BIN
      html/jkda/images/jianyanbaogao_icon.png
  62. BIN
      html/jkda/images/jianyanjieguo_icon.png
  63. BIN
      html/jkda/images/jiuzhenxinxi_icon.png
  64. BIN
      html/jkda/images/lvjiantou_icon.png
  65. BIN
      html/jkda/images/qita_icon.png
  66. BIN
      html/jkda/images/shanchu01_btn.png
  67. BIN
      html/jkda/images/shanchu02_btn.png
  68. BIN
      html/jkda/images/shou02_icon.png
  69. BIN
      html/jkda/images/shou_icon.png
  70. BIN
      html/jkda/images/shousuo_icon.png
  71. BIN
      html/jkda/images/shujuweikong_img.png
  72. BIN
      html/jkda/images/tianjiatupian_icon.png
  73. BIN
      html/jkda/images/weifenlei_icon.png
  74. BIN
      html/jkda/images/xuanfujiuzhenxiangqing_btn.png
  75. BIN
      html/jkda/images/xuanfuquedi_btn.png
  76. BIN
      html/jkda/images/xuanfutianjia_btn.png
  77. BIN
      html/jkda/images/xuanfuxiugai_btn.png
  78. BIN
      html/jkda/images/yingxiangjielun_icon.png
  79. BIN
      html/jkda/images/yingxiangshujian_icon.png
  80. BIN
      html/jkda/images/yiwen_btn.png
  81. BIN
      html/jkda/images/yiyuanjianzhu_icon.png
  82. BIN
      html/jkda/images/zhankai_icon.png
  83. BIN
      html/jkda/images/zhenduanjieguo_icon.png
  84. 5788 0
      html/jkda/js/avalon.modern.js
  85. 126 0
      html/jkda/js/elastic-columns.js
  86. 309 0
      html/jkda/js/event-profile.js
  87. 61 0
      html/jkda/js/info.js
  88. 234 0
      html/jkda/js/jianchajianyan.js
  89. 137 0
      html/jkda/js/jiankangtijian.js
  90. 67 0
      html/jkda/js/jiankangtijianxiangqing.js
  91. 257 0
      html/jkda/js/jiuzhenjilu.js
  92. 267 0
      html/jkda/js/jiuzhenxiangqing.js
  93. 315 0
      html/jkda/js/shangchuanjiuzhenjilu-edit.js
  94. 239 0
      html/jkda/js/shangchuanjiuzhenjilu.js
  95. 245 0
      html/jkda/js/single-profile.js
  96. 151 0
      html/jkda/js/upload-file.js
  97. 185 0
      html/jkda/template/0101.html
  98. 81 0
      html/jkda/template/0102.html
  99. 142 0
      html/jkda/template/0111.html
  100. 0 0
      html/jkda/template/0121.html

+ 33 - 0
html/jkda/css/base.css

@ -0,0 +1,33 @@
html { color: #000; font-size: 10px; font-family: sans-serif; -ms-text-size-adjust: 100%; -webkit-text-size-adjust: 100%; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
article, aside, blockquote, body, button, code, details, div, dl, em, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, input, label, legend, menu, nav, ol, p, pre, section, span, td, textarea, th, ul { margin: 0; padding: 0; box-sizing: border-box; }
body { margin: 0 auto; min-width: 320px; max-width: 640px; -webkit-touch-callout: none; -webkit-text-size-adjust: none; -webkit-tap-highlight-color: transparent; }
ul { list-style: none; }
table { border-collapse: collapse; }
a img { border: 0; }
a { text-decoration: none; }
img { max-width: 100%; }
h1, h2, h3, h4, h5, h6 { font-size: 100%; font-weight: 500; }
@media screen and (min-width: 321px) and (max-width: 375px) { html { font-size: 11px; } }
@media screen and (min-width: 376px) and (max-width: 414px) { html { font-size: 12px; } }
@media screen and (min-width: 415px) { html { font-size: 15px; } }
.j-body {padding-top:55px;background: #f3f3f3;width: 100vw;height: 100vh; }
.j-header { position: absolute; left: 0; right: 0; top: 0; height: 45px; background: #fff; z-index: 999; }
.j-header:before { content: " "; position: absolute; left: 0; bottom: -1px; right: 0; height: 1px; border-top: 1px solid #D9D9D9; color: #D9D9D9; -webkit-transform-origin: 0 0; -ms-transform-origin: 0 0; transform-origin: 0 0; -webkit-transform: scaleY(0.5); -ms-transform: scaleY(0.5); transform: scaleY(0.5); }
.j-back { position: absolute; width: 37px; height: 45px; top: 0; left: 0; }
.i-back { display: block; width: 17px; height: 15px; background-image: url(../img/i-back.png); background-repeat: no-repeat; background-position: center; background-size: contain; position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); }
.j-tit { height: 45px; line-height: 45px; text-align: center; font-size: 15px; font-weight: 600; color: #28405d; }
.j-close { height: 45px; line-height: 45px; position: absolute; top: 0; right: 0; padding: 0 14px; font-size: 15px; color: #1286ff; }

+ 61 - 0
html/jkda/css/event-profile.css

@ -0,0 +1,61 @@
.lin-down-arrow{
    position: relative;
    top: -2px;
    left: 5px;
    height: 10px;
    width: 10px;
    border-bottom: 3px solid #E1E1E1;
    border-right: 3px solid #E1E1E1;
    display: inline-block;
    transform:rotate(45deg);
	-ms-transform:rotate(45deg); 	/* IE 9 */
	-moz-transform:rotate(45deg); 	/* Firefox */
	-webkit-transform:rotate(45deg); /* Safari 和 Chrome */
	-o-transform:rotate(45deg); 		/* Opera */
	zoom: 1;
}
.lin-sel-group{
	position: fixed;
	top: 45px;
	background: #fff;
	width: 100%;
    height: -webkit-calc(100%);
    height: -moz-calc(100%);
    height: calc(100%);
    overflow-y: scroll;
    overflow-x: hidden;
	z-index: 11;
	display: none;
}
.lin-sel-group li{
	text-align: center;
	color: #17b3ec;
	height: 40px;
	line-height: 40px;
	font-size: 16px;
	border-bottom: 1px solid #f3f3f3;
}
.lin-sel-group img{
	width: 20px;
	margin: 10px;
	display: none;
}
.lin-sel-group li.checked img{
	display: inline;
}
.lin-mask{
	position: fixed;
	top: 45px;
	height: 100%;
	width: 100%;
	/*background: #000;*/
	height: 100%;
	z-index: 10;
	display: none;
	background-color: rgba(0,0,0,0.7);
}
.page-content { padding: 5px; }

+ 166 - 0
html/jkda/css/info.css

@ -0,0 +1,166 @@
.os-main, .el-main { font-size: 14px; color: #28405d; overflow: auto; -webkit-overflow-scrolling: touch; }
.info-list{background: #fff;border-top: solid 1px #d9d9d9;margin-bottom: 10px;border-bottom: solid 1px #d9d9d9;}
.info-list .il-item { position: relative; }
.info-list .il-item p { line-height: 20px; padding-bottom: 15px; }
.info-list .il-item.il-i-table:after { border: none; }
.os-tit-o {box-sizing: border-box; padding: 0px 10px;height: 35px;line-height: 35px; font-size: 16px; color: #28405d; border-bottom: solid 1px #dcdcdc;margin-bottom: 15px;}
.os-tit-o.o-t-o-nb { padding-bottom: 0; }
.os-t-o-name { vertical-align: middle; }
.os-base-info {padding: 0px 10px; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex;}
.os-base-info.pl0{padding-left: 0px;padding-right: 0px;}
.os-base-info li {-webkit-flex: 1; -webkit-box-flex: 1; -ms-flex: 1; flex: 1; display: inline-block;margin-bottom: 15px;}
.os-base-info li.flex2 { -webkit-flex: 2; -webkit-box-flex: 2; -ms-flex: 2; flex: 2; }
.os-base-info li.flex1 { -webkit-flex: 1; -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }
.os-base-info li .pd-r { padding-right: 25px; }
.os-base-info li:first-child { padding-right: 20px; }
.os-base-info label { color: #95a1b0; }
.os-tit-t, .os-tit-f { margin-bottom: 10px; color: #95a1b0; }
.os-tit-th { padding-bottom: 10px; color: #95a1b0; }
.os-tit-f { font-weight: 600; color: #28405d; }
.p-bottom { text-align: center; padding: 10px 0 20px 0; font-size: 10px; color: #95a1b0; }
.info-list-t { position: relative;background: #fff;border-top: solid 1px #d9d9d9;margin-bottom: 10px;border-bottom: solid 1px #d9d9d9;}
.il-t-item { position: relative; padding: 0 10px; }
.il-t-item.list-mt{margin-bottom: 10px;}
.il-t-item.list-mt:last-child{margin-bottom: 0px;}
.il-t-item:after { content: " "; position: absolute; left: 14px; bottom: 0; right: 14px; height: 1px; border-top: 1px solid #D9D9D9; color: #D9D9D9; -webkit-transform-origin: 0 0; -ms-transform-origin: 0 0; transform-origin: 0 0; -webkit-transform: scaleY(0.5); -ms-transform: scaleY(0.5); transform: scaleY(0.5); }
.il-t-item p { padding-bottom: 15px; line-height: 20px; }
.il-t-item p.ying-pb{padding-bottom: 10px;}
.il-t-item.jiancha-mt{margin-bottom:10px;}
.il-t-item:last-child:after { content: ""; border: none; }
.il-t-item.pl0{padding-left: 0px;padding-right: 0px;}
.sidebar-main {width: 100vw;height: 100vh; position: absolute; left: 0; top: 0px;bottom:0; background: transparent; z-index: -1; -webkit-transition: all 0.5s; transition: all 0.5s;overflow: hidden; }
.sidebar-main.active { background: rgba(0, 0, 0, 0.3); z-index: 500; }
.sidebar-body { position: absolute; width: 210px; top: 0; right: -210px;bottom:0; background: #fff;z-index: -1; padding-top: 45px; -webkit-transition: all 0.5s; transition: all 0.5s;min-height: 100%; }
.sidebar-body.active { position: absolute;top: 0; right: 0px;z-index: 500;  }
.sb-item { position: relative; text-align: center; font-size: 17px; }
.sb-item > a { color: #28405d; position: relative; display: block; height: 45px; line-height: 45px; overflow: hidden;text-overflow: ellipsis;white-space: nowrap;padding: 0 10px;}
.sb-item > a.active { background: #f5f7f9; }
.sb-i-list { display: none; text-align: left; }
.sb-i-list li a.active { background: #f5f7f9; }
.sb-i-list a { color: #95a1b0; display: block; height: 45px; line-height: 45px;font-size: 14px;}
.icon { display: inline-block; width: 16px; height: 16px; background-repeat: no-repeat; background-position: center; background-size: cover; vertical-align: middle; margin: 0 10px 0 0; }
.i-ess-info { background-image: url(../images/img/i-ess-info.png); }
.i-visiting-result { background-image: url(../images/img/i-visiting-result.png); }
.i-dia-basis { background-image: url(../images/img/i-dia-basis.png); }
.i-cli-dia { background-image: url(../images/img/i-cli-dia.png); }
.Rp { background-image: url(../images/img/Rp.png); }
.i-pha-info { background-image: url(../images/img/i-pha-info.png); }
.i-ins-res { background-image: url(../images/img/i-ins-res.png); }
.i-inspectors { background-image: url(../images/img/i-inspectors.png); }
.i-pat-info { background-image: url(../images/img/i-pha-info.png); }
.i-hos-sum { background-image: url(../images/img/i-hos-sum.png); }
.i-ope-rec { background-image: url(../images/img/i-ope-rec.png); }
.i-dia-rec { background-image: url(../images/img/i-dia-rec.png); }
.i-doc-info { background-image: url(../images/img/i-doc-info.png); }
.i-test-results { background-image: url(../images/img/i-test-results.png); }
.i-zdjl { background-image: url(../page/info/img/i-zdjl.png); }
.i-home { display: inline-block; width: 40px; height: 40px; position: absolute; right: 14px; bottom: 30px; background-repeat: no-repeat; background-position: center; background-size: cover; background-image: url(../images/img/i-go-home.png); border-radius: 50%; z-index: 888; }
.sidebar { display: inline-block; width: 48px; height: 48px; position: fixed; right: 14px; top: 72px; background-repeat: no-repeat; background-position: center; background-size: cover; background-image: url(../images/img/i-switch.png); border-radius: 50%; z-index: 400; }
.i-d { display: inline-block; width: 10px; height: 6px; position: absolute; right: 10px; top: 50%; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%); background-repeat: no-repeat; background-position: center; background-size: cover; background-image: url(../images/img/i-drop-down.png); -webkit-transition: all 0.5s; transition: all 0.5s; }
.i-d.active { -webkit-transform: rotate(-180deg); -ms-transform: rotate(-180deg); transform: rotate(-180deg); }
.cm-list { font-size: 0; }
.cm-list li { font-size: 13px; color: #28405d; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; }
.cm-list li div { -webkit-flex: 1; -webkit-box-flex: 1; -ms-flex: 1; flex: 1; text-align: center; padding-bottom: 20px; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; }
.cm-list li div span {-webkit-flex: 1; -webkit-box-flex: 1; -ms-flex: 1; flex: 1; display: inline-block; }
.cm-list li div span:first-child { text-align: right; }
.cm-list li div:first-child { border-right: 1px dotted #dce5f1; }
.cm-list li:first-child { padding-top: 15px; }
.cm-list li:last-child { padding-bottom: 30px; }
.cm-list li:last-child div { padding-bottom: 0; }
.i-i-list { overflow-x: auto; overflow-y: hidden; white-space: nowrap; }
.i-i-list li { display: inline-block; padding: 5px 10px 15px 0; text-align: center; }
.i-i-list li img { display: inline-block; height: 75px; width: 92px; border-radius: 5px; }
.el-main { background: #f4f6f9; }
.el-tit { height: 100px; background: #fff; padding-left: 20px; }
.el-t-l { font-size: 12px; color: #95a1b0; padding: 20px 0 5px 0; }
.el-t-m { font-size: 30px; color: #28405d; font-weight: 600; }
.el-list { padding-bottom: 20px; }
.el-item div.list { padding:5px 10px; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; position: relative; font-size: 14px; color: #95a1b0; }
.el-item div.list span {display: block; -webkit-flex: 1; -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }
.el-item div.list span:last-child { text-align: right; }
.el-item div.title span {display: block; -webkit-flex: 1; -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }
.el-item div.title span:last-child { text-align: right; }
.el-item div.title { height:40px;line-height:40px; font-size: 14px; color: #28405d; font-weight: 600;padding: 0px 10px;border-bottom:solid 1px #d9d9d9; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex;margin-bottom: 5px;}
.el-item .el-list{display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; padding: 5px 10px;font-size: 14px; color: #95a1b0;}
.el-item .el-list b{display: block;font-weight: normal;-webkit-flex: 1; -webkit-box-flex: 1; -ms-flex: 1; flex: 1;}
.el-item .el-list b:last-child { text-align: right; }
.el-item .el-title.noline{border-bottom:none;margin-bottom: 0px;}
.el-item .el-title{height:40px;line-height:40px; font-size: 14px; color: #28405d; font-weight: 600;padding: 0px 10px;border-bottom:solid 1px #d9d9d9; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex;margin-bottom: 5px;}
.el-item .el-title span{display: block;-webkit-flex: 1; -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }
.el-item .el-title span:last-child { text-align: right; }
.lto-con { box-shadow: 1px 1px 2px 0 #edf4fe; background: #fff; margin: 0px 10px 10px 10px;border-radius: 5px;}
.lto-tit { padding: 20px 0 15px 25px; font-size: 14px; color: #1286ff; }
.lto-info { padding: 0 10px 10px 25px; font-size: 14px; color: #28405d; line-height: 20px; position: relative; }
.lto-info span { color: #95a1b0; }
.lto-info:before { content: " "; display: block; width: 5px; height: 5px; background: #1286ff; position: absolute; border-radius: 50%; left: 10px; top: 7px; }
.hp-table { width: 100%; text-align: center; }
.hp-table tr { border: 1px solid #edf4fe; }
.hp-table tr th { height: 40px; background: #f5f7f9; font-size: 13px; color: #28405d; font-weight: 600; }
.hp-table tr td { height: 60px; font-size: 12px; color: #28405d; }
.hp-list { color: #28405d; padding-bottom: 10px; }
.hp-list li { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; }
.hp-list li span { text-align: center; padding-bottom: 10px; }
.hp-list li span:first-child { -webkit-flex: 1.5; -webkit-box-flex: 1.5; -ms-flex: 1.5; flex: 1.5; }
.hp-list li span:last-child { -webkit-flex: 2; -webkit-box-flex: 2; -ms-flex: 2; flex: 2; }
.hp-list li:first-child span { font-weight: 600; padding-bottom: 15px; }
.id-table { width: 100%; margin-bottom: 10px; }
.id-table tr { text-align: center; }
.id-table tr th { font-size: 13px; color: #28405d; padding: 10px 0; }
.id-table tr td { font-size: 12px; color: #28405d; padding: 10px 0; }
.id-table tr.up td { color: #ff7e7e; }
.id-table tr.down td { color: #67e39e; }
.up-icon { position: relative; }
.up-icon:after { content: ''; display: block; position: absolute; width: 11px; height: 12px; background-image: url(../images/img/i-up.png); background-position: center; background-repeat: no-repeat; background-size: cover; top: 2px; right: -15px; }
.down-icon { position: relative; }
.down-icon:after { content: ''; display: block; position: absolute; width: 11px; height: 12px; background-image: url(../images/img/i-down.png); background-position: center; background-repeat: no-repeat; background-size: cover; top: 2px; right: -15px; }
.ep-top{
	width: 100%;
	position: fixed;
	top: 0px;
	left: 0px;
	z-index: 999;
}

+ 9 - 0
html/jkda/css/jianchabaogaoxiangqing.css

@ -0,0 +1,9 @@
body { background: #F2F3F5; }
.c-fwb { font-weight: bold; }
.bc-fff { background: #FFF; }
.info-panel { border-bottom: 1px solid #DCDCDC; }
.info-panel p { height: 36px; line-height: 36px; border-top: 1px solid #DCDCDC; border-bottom: 1px solid #DCDCDC; }
.info-panel .title-icon { width: 20px; height: 20px; margin-top: 8px; }
.info-panel {  }
.img-list li img { width: 70px; height: 70px; }
#xiangqing_btn img { position:fixed; bottom:50px; right: 20px; width: 50px; height: 50px; }

+ 32 - 0
html/jkda/css/jianchajianyan.css

@ -0,0 +1,32 @@
body { color: #333; background-color: #f3f3f3; }
.f-fr { float: right; }
.vertical-line { top:0px; left: 62px; border-left: 1px solid #B9B9B9; position: absolute; height: 100%; }
.s-bc-ff6a56 { background-color: #FF6A56; }
.s-bc-74BF00 { background-color: #74BF00; }
.s-bc-FF9526 { background-color: #FF9526; }
.s-bc-ffffff { background-color: #FFF; }
.card-title{ background: cadetblue; }   
.jianyan .record-date { color: #DB6BBD;  }
.jianyan .inner-circle,
.jianyan .card-title { background-color: #DB6BBD; }
.jiancha .record-date { color: #47A8EF;  }
.jiancha .inner-circle,
.jiancha .card-title { background-color: #47A8EF; }
.yiyuan-icon { width: 12px; height: 12px; margin-top: 2px; }
.ul-consultation li{padding-left: 75px;margin-top: 10px;margin-right: 10px;position: relative;}
.ul-consultation .outer-circle{top: 4px;left: 57px;width: 12px;height: 12px;background-color: #F0F0F0;position: absolute;}
.ul-consultation .outer-circle .inner-circle{width: 100%;height: 100%;border-radius: 10px;}
.ul-consultation .record-card{height: 110px;margin-left: 6px;}
.ul-consultation .record-card .card-title{height: 20px;padding: 5px 10px;color: #FFF;border-top-left-radius: 5px;border-top-right-radius: 5px;font-size: 14px;line-height: 20px;}
.ul-consultation li.record-year { padding-left: 0; }
.record-card p{display: -moz-box;display: -webkit-box;background-color: #FFF;height: 68px;font-size: 14px;padding-top: 8px;padding-left: 10px;overflow: hidden; -webkit-line-clamp: 3;    -webkit-box-orient: vertical; color:#323232;word-break: break-all;}
.record-year { left: 44px; width: 35px; height: 35px; line-height: 35px; border-radius: 35px; border: 1px solid #909090; padding-left: 0; text-align: center; background: #FFF; font-size: 14px; }
.record-date { position: absolute; left: 0; top: 0; left: 6px; font-size: 14px; }
.no-result-img { display: block; width: 320px; height: 184px; margin: 0 auto; margin-top: 160px; }
#new_btn { position: fixed; bottom: 20px; right: 20px; width: 50px; height: 50px; z-index: 99; }
.pullUp { background: transparent; display: block; }
.pullUp .pullUpIcon { display: none; }

+ 13 - 0
html/jkda/css/jiankangtijian.css

@ -0,0 +1,13 @@
.c-list > .list-arrow-r:after, .c-list > .list-arrow-u:after, .c-list > .list-arrow-d:after { position: absolute; top: 50%; right: 10px; margin-top: -5px; content: ""; display: block; width: 8px; height: 8px; border: solid #cdcdcd; border-width: 2px 2px 0 0; -webkit-transform: rotate(45deg); transform: rotate(45deg);}
.c-arrow-r{position:absolute;top:50%;right:10px;margin-top:-5px;content:"";display:block;width:8px;height:8px;border:solid #cdcdcd;border-width:2px 2px 0 0;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg);}
.scroll-wrapper { top: 100px; }
.pullDown, .pullUp { background-color: transparent; }
#recent_event_list { margin: 0 10px;  border: 0; background-color: transparent; }
#recent_event_list .event-name { padding: 2px 5px; color: #FFF; background-color: #F0B548; border-radius: 5px; }
#recent_event_list.c-list .c-list-info > p { color: #323232; font-size: 16px; }
#recent_event_list.c-list > li { margin-left: 0; padding-left: 15px; border: 1px solid #e1e1e1; border-radius: 5px; margin-bottom: 10px; background-color: #FFF; }
.no-result-img { display: block; width: 320px; height: 184px; margin: 0 auto; margin-top: 160px; }
#new_btn { position: fixed; bottom: 20px; right: 20px; width: 50px; height: 50px; z-index: 99; }
.pullUp { background: transparent; display: block; }
.pullUp .pullUpIcon { display: none; }

+ 32 - 0
html/jkda/css/jiankangtijianxiangqing.css

@ -0,0 +1,32 @@
body { height: auto;}
body,
html {
	width: 100%;
	background: #f3f3f3;
	font-size: 16px;
	color: #333;
}
html, body, div, span, object, iframe, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, input, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video, h1, h2, h3, h4, h5, h6 {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
	-moz-tap-highlight-color: rgba(0, 0, 0, 0);
	-ms-touch-action: none;
	-webkit-touch-callout: none;
}
.f-w20 { width: 20px; }
.c-fwb { font-weight: bold; }
.c-border-r5 { border-radius: 5px; }
.c-max-w120 { max-width: 120px; }
.bc-fff { background-color: #FFF; }
.c-vam { vertical-align: middle; }
.up-icon { display: none; }
.expanding .up-icon { display: block; }
.expanding .down-icon { display: none; }
.card-item { border: 1px solid #ccc; border-radius: 5px; }
.card-layout { box-sizing: border-box; }
[auto-item] { display: none; }

+ 26 - 0
html/jkda/css/jianyanbaogaoxiangqing.css

@ -0,0 +1,26 @@
body { background: #F2F3F5; }
.c-table { width: 100%; border-collapse: collapse }
.c-table th { font-weight: 700; }
.c-table td, .c-table th { border-bottom: 1px solid #f1f1f1; border-right: 1px solid #f1f1f1; text-align: center; padding: .5rem; }
.c-table tr td:last-child, .c-table tr th:last-child { border-right: 0 }
.c-table tr:last-child td { border-bottom: 0 }
.glu-tab tbody{ font-size:.6rem;}
.glu-tab th{ vertical-align:middle;}
.glu-tab tbody td{ width:11.875%;}
.glu-tab tbody tr td:first-child{ width:auto;}
.bp-tab tbody{ font-size:.6rem;}
.bp-tab th{ vertical-align:middle;}
.bp-tab tbody td{ width:13.875%;}
.bp-tab tbody tr td:first-child{ width:auto;}
.c-fwb { font-weight: bold; }
.bc-fff { background: #FFF; }
.info-panel { border-bottom: 1px solid #DCDCDC; }
.info-panel p { height: 36px; line-height: 36px; border-top: 1px solid #DCDCDC; border-bottom: 1px solid #DCDCDC; }
.info-panel .title-icon { width: 20px; height: 20px; margin-top: 8px; }
.info-panel {  }
.img-list li img { width: 70px; height: 70px; }
#xiangqing_btn img { position:fixed; bottom:50px; right: 20px; width: 50px; height: 50px; }
#result,#result tr,#result td,#result th { border: 0; font-size: 14px; }
.num-value img { display: none; width: 7px; height: 11px; margin-left: 5px; margin-top: 5px; }
.num-value.over img.over-icon { display: inline; }
.num-value.lower img.lower-icon { display: inline; }

+ 34 - 0
html/jkda/css/jiuzhenjilu.css

@ -0,0 +1,34 @@
body { color: #333; background-color: #f3f3f3; }
.f-fr { float: right; }
.vertical-line { top: 0px; left: 62px; border-left: 1px solid #B9B9B9; position: absolute; height: 100%; }
.s-bc-ff6a56 { background-color: #FF6A56; }
.s-bc-74BF00 { background-color: #74BF00; }
.s-bc-FF9526 { background-color: #FF9526; }
.s-bc-ffffff { background-color: #FFF; }
.zhuyuan .record-date { color: #FF6A56;  }
.zhuyuan .inner-circle,
.zhuyuan .card-title { background-color: #FF6A56; }
.tijian .record-date { color: #74BF00;  }
.tijian .inner-circle,
.tijian .card-title { background-color: #74BF00; }
.menzhen .record-date { color: #FF9526;  }
.menzhen .inner-circle,
.menzhen .card-title { background-color: #FF9526; }
.yiyuan-icon { width: 12px; height: 12px; margin-top: 2px; }
.ul-consultation li{padding-left: 75px;margin-top: 10px;margin-right: 10px;position: relative;}
.ul-consultation .outer-circle{top: 4px;left: 57px;width: 12px;height: 12px;background-color: #F0F0F0;position: absolute;}
.ul-consultation .outer-circle .inner-circle{width: 100%;height: 100%;border-radius: 10px;}
.ul-consultation .record-card{height: 110px;margin-left: 6px;}
.ul-consultation .record-card .card-title{height: 20px;padding: 5px 10px;color: #FFF;border-top-left-radius: 5px;border-top-right-radius: 5px;font-size: 14px;line-height: 20px;}
.ul-consultation li.record-year { padding-left: 0; }
.record-card p{display: -moz-box;display: -webkit-box;background-color: #FFF;height: 68px;font-size: 14px;padding-top: 8px;padding-left: 10px;overflow: hidden; -webkit-line-clamp: 3;    -webkit-box-orient: vertical; color:#323232;word-break: break-all;}
.record-year { left: 44px; width: 35px; height: 35px; line-height: 35px; border-radius: 35px; border: 1px solid #909090; padding-left: 0; text-align: center; background: #FFF; font-size: 14px; }
.record-date { position: absolute; left: 0; top: 0; left: 6px; font-size: 14px; }
.no-result-img { display: block; width: 320px; height: 184px; margin: 0 auto; margin-top: 160px; }
#new_btn { position: fixed; bottom: 20px; right: 20px; width: 50px; height: 50px; z-index: 99; }
.pullUp { background: transparent; display: block; }
.pullUp .pullUpIcon { display: none; }

+ 51 - 0
html/jkda/css/jiuzhenxiangqing.css

@ -0,0 +1,51 @@
body { background: #F2F3F5; }
.c-74bf00 { color: #74BF00; }
.c-fwb { font-weight: bold; }
.bc-fff { background: #FFF; }
.info-panel { border-bottom: 1px solid #DCDCDC; }
.info-panel p { height: 36px; line-height: 36px; border-top: 1px solid #DCDCDC; border-bottom: 1px solid #DCDCDC; }
.info-panel .title-icon { width: 20px; height: 20px; margin-top: 8px; }
.info-panel {  }
.img-list li img { width: 70px; height: 70px; }
#edit_btn img { position:fixed; top:20px; right: 20px; width: 50px; height: 50px; }
.select-image-bar{ background: transparent; border-bottom: 1px solid #909090;}
.c-arrow-r {
    position: absolute;
    top: 50%;
    right: 10px;
    margin-top: -5px;
    content: "";
    display: block;
    width: 8px;
    height: 8px;
    border: solid #cdcdcd;
    border-width: 2px 2px 0 0;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}
.c-arrow-d {
	position: absolute;
	top: 50%;
	right: 10px;
	margin-top: -5px;
	content: "";
	display: block;
	width: 8px;
	height: 8px;
	border: solid #74BF00;
	border-width: 2px 2px 0 0;
	-webkit-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	-ms-transform: rotate(135deg);
	transform: rotate(135deg);
}
.del-icon { width: 16px; height: 16px; }
.c-btn-74bf00 {
	background-color: transparent;
	color: #74BF00;
	border: #74BF00 1px solid;
}
.c-btn-icon { width: 100%; padding: 8px 16px; border-radius: 5px; }
.c-btn-icon.active { background: #74BF00; color: #FFF; }

+ 52 - 0
html/jkda/css/shangchuanjiuzhenjilu-edit.css

@ -0,0 +1,52 @@
.c-75bf00 { color: #75BF00; }
.c-74bf00 { color: #74BF00; }
.c-border-75bf00 { border-color: #75BF00; }
.c-btn-ff6a56 { background: #FF6A56; }
.c-t-right { text-align: right; }
.select-image-bar{ background: transparent; border-bottom: 1px solid #909090;}
.c-arrow-r {
    position: absolute;
    top: 50%;
    right: 10px;
    margin-top: -5px;
    content: "";
    display: block;
    width: 8px;
    height: 8px;
    border: solid #cdcdcd;
    border-width: 2px 2px 0 0;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}
.c-arrow-d {
	position: absolute;
	top: 50%;
	right: 10px;
	margin-top: -5px;
	content: "";
	display: block;
	width: 8px;
	height: 8px;
	border: solid #74BF00;
	border-width: 2px 2px 0 0;
	-webkit-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	-ms-transform: rotate(135deg);
	transform: rotate(135deg);
}
.del-icon { width: 16px; height: 16px; }
.c-btn-74bf00 {
	background-color: transparent;
	color: #74BF00;
	border: #74BF00 1px solid;
}
.c-btn-icon { width: 100%; padding: 8px 16px; border-radius: 5px; }
#jian_yan_types .c-btn-icon,
#jian_cha_types .c-btn-icon { padding: 5px 16px;  }
.c-btn-icon.active { background: #74BF00; color: #FFF; }
.catalog-name { position: absolute; bottom: 0; font-size: 14px; color: #fff; width: 76px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; text-align: center; background: rgba(0,0,0,0.3); }
.upload-img ul li { padding: 0; margin: 0 10px 10px 0; overflow: hidden; }
#img_ul .del-wrap { position: absolute; top: -25px; right: -25px; width: 50px; height: 50px; background: rgba(0,0,0,0.3); border-radius: 50px; }
#img_ul .del-icon {position: absolute; bottom: 8px; left: 8px; width: 16px; height: 16px; }

+ 51 - 0
html/jkda/css/shangchuanjiuzhenjilu.css

@ -0,0 +1,51 @@
.c-75bf00 { color: #75BF00; }
.c-74bf00 { color: #74BF00; }
.c-border-75bf00 { border-color: #75BF00; }
.c-t-right { text-align: right; }
.select-image-bar{ background: transparent; border-bottom: 1px solid #909090;}
.c-arrow-r {
    position: absolute;
    top: 50%;
    right: 10px;
    margin-top: -5px;
    content: "";
    display: block;
    width: 8px;
    height: 8px;
    border: solid #cdcdcd;
    border-width: 2px 2px 0 0;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}
.c-arrow-d {
	position: absolute;
	top: 50%;
	right: 10px;
	margin-top: -5px;
	content: "";
	display: block;
	width: 8px;
	height: 8px;
	border: solid #74BF00;
	border-width: 2px 2px 0 0;
	-webkit-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	-ms-transform: rotate(135deg);
	transform: rotate(135deg);
}
.del-icon { width: 16px; height: 16px; }
.c-btn-74bf00 {
	background-color: transparent;
	color: #74BF00;
	border: #74BF00 1px solid;
}
.c-btn-icon { width: 100%; padding: 8px 16px; border-radius: 5px; }
#jian_yan_types .c-btn-icon,
#jian_cha_types .c-btn-icon { padding: 5px 16px;  }
.c-btn-icon.active { background: #74BF00; color: #FFF; }
.catalog-name { position: absolute; bottom: 0; font-size: 14px; color: #fff; width: 76px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; text-align: center; background: rgba(0,0,0,0.3); }
.upload-img ul li { padding: 0; margin: 0 10px 10px 0; overflow: hidden; } 
#img_ul .del-wrap { position: absolute; top: -25px; right: -25px; width: 50px; height: 50px; background: rgba(0,0,0,0.3); border-radius: 50px; }
#img_ul .del-icon {position: absolute; bottom: 8px; left: 8px; width: 16px; height: 16px; }

+ 445 - 0
html/jkda/css/ss-style.css

@ -0,0 +1,445 @@
/*---------cross.ui-------------------------*/
/* buttons color
-----------------------------------------------------------------------------*/
.c-btn-087eff { background-color: #087eff; }
.c-btn-087eff:hover { background-color: #0771e5; }
.c-btn-588cd5 { background-color: #588cd5; }
.c-btn-588cd5:hover { background-color: #4680d0; }
.c-btn-37a6ec { background-color: #37a6ec; }
.c-btn-37a6ec:hover { background-color: #3195d4; }
.c-btn-4dcd70 { background-color: #4dcd70; }
.c-btn-4dcd70:hover { background-color: #45b865; }
.c-btn-4db944 { background-color: #4db944; }
.c-btn-4db944:hover { background-color: #45a63d; }
.c-btn-309765 { background-color: #309765; }
.c-btn-309765:hover { background-color: #2b885b; }
.c-btn-ff9600 { background-color: #ff9600; }
.c-btn-ff9600:hover { background-color: #e58700; }
.c-btn-ff8100 { background-color: #ff8100; }
.c-btn-ff8100:hover { background-color: #e57400; }
.c-btn-fc6155 { background-color: #fc6155; }
.c-btn-fc6155:hover { background-color: #e2574c; }
.c-btn-ff3b2f { background-color: #ff3b2f; }
.c-btn-ff3b2f:hover { background-color: #e5352a; }
.c-btn-f9f9f9 { background-color: #f9f9f9; color: #087eff; border: #c0c0bc 1px solid; }
.c-btn-f9f9f9:hover { background-color: #e0e0e0; }
.c-btn-ffffff { background-color: #ffffff; color: #4dcd70; border: #e1e1e1 1px solid; }
.c-btn-ffffff:hover { background-color: #e5e5e5; }
.c-btn-fff { background-color: #ffffff; color: #999999; border: #e1e1e1 1px solid; }
.c-btn-fff:hover { background-color: #e5e5e5; }
.c-btn-ff3 { background-color: #ffffff; color: #ff3b2d; border: #e1e1e1 1px solid; }
.c-btn-ff3:hover { background-color: #e5e5e5; }
/**************************************************/
.c-border, .c-border-t, .c-border-b, .c-border-l, .c-border-r, .c-border-tb { border-color: #e1e1e1; border-style: solid; }
.ui-grid { display: -webkit-box; display: box; }
.ui-col-0 { -webkit-box-flex: 0; box-flex: 0; }
.ui-col-1 { -webkit-box-flex: 1; box-flex: 1; }
.ui-arrow, .ui-arrow s { position: relative; display: block; font-size: 0; line-height: 0; width: 0; height: 0; border-color: transparent; border-style: dashed; border-width: 5px; }
.ui-arrow-r, .ui-arrow-r s { border-left-color: #aaa; border-left-style: solid; }
.ui-arrow-r s { border-left-color: #fff; position: absolute; left: -7px; top: -5px; }
.c-btn-4dcd70 { background-color: #4dcd70; }
.c-btn-4dcd70:hover { background-color: #45b865; }
.c-btn-fff { background-color: #ffffff; color: #999999; border: #e1e1e1 1px solid; }
.c-btn-fff:hover { background-color: #e5e5e5; }
body, html { width: 100%; height: 100%; background: #f3f3f3; }
/* 健康管理师 */
.sdoc-top { height: 180px; background: url(../images/banner1.jpg) no-repeat; background-size: 100% 100%; -webkit-background-size: 100% 100%; -moz-background-size: 100% 100%; text-align: center; padding: 20px 15px 0 15px; font-size: 12px; color: #fff; text-shadow: 0px 0px 2px rgba(0,0,0,0.6); line-height: 23px; position: relative; }
.sdoc-top .sdimg { display: block; margin: 0 auto 10px auto; width: 60px; height: 60px; padding: 1px; background-color: rgba(250,250,250,.75); border-radius: 50%; }
.sdoc-top.smil { padding: 38px 15px 36px; height: 100px; background: url(../images/p-bg-top.png) no-repeat; background-size: 100% 100%; }
.sdoc-top.smil.short { height: 60px; }
.sdoc-top.smil .sdimg { margin: 0; width: 56px; height: 56px; border-radius: 56px; overflow: hidden; padding: 0; background: rgb(250,250,250) }
.sdoc-top.smil .sdimg img { width: 56px; height: 56px; }
.ff6600 { color: #ff6600; }
.pb60 { padding-bottom: 60px; }
.slider-detail h2 { color: #333333; }
.slider-detail p { color: #888888; }
.slider-detail li { padding: 10px 0 12px 0; position: relative; border-bottom: 1px solid #e1e1e1; }
.slider-detail li:last-child { border: none; }
.slider-detail li span { position: absolute; bottom: 0px; right: 15px; }
.slider-detail p.show { display: -webkit-box; overflow: hidden; text-overflow: ellipsis; -webkit-box-orient: vertical; -webkit-line-clamp: 2; }
.arrow-down, .arrow-up { display: inline-block; width: 8px; height: 8px; border: solid #cdcdcd; border-width: 2px 2px 0 0; cursor: pointer; -webkit-transform: rotate(135deg); -moz-transform: rotate(135deg); transform: rotate(135deg); }
.arrow-up { -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); transform: rotate(-45deg); }
.line-click { width: 100%; height: 15px; position: relative; }
.menu-boxer span { width: 60px; height: 60px; text-align: center; color: #fff; line-height: 60px; display: block; border-radius: 60px; margin: 15px auto 0; }
.menu-boxer span i { font-size: 40px; }
.menu-boxer p { color: #666666; font-size: 14px; text-align: center; padding-top: 5px; }
.menu-boxer span.green-bg { background: #38e4a5; }
.menu-boxer span.red-bg { background: #f2417f; }
.menu-boxer span.org-bg { background: #ffb30f; }
.menu-boxer span.blue-bg { background: #32a7f9; }
/*提交成功*/
.data-noticebox { padding-top: 15%; text-align: center; }
.data-noticebox i { color: #4dcd70; font-size: 80px; line-height: 80px; }
.data-noticebox p { padding-left: 48px; padding-right: 48px; }
.data-noticebox p span { color: #333333; }
.data-noticebox .bottom-box { padding: 30px 15px 0; }
.bottom-box a.c-btn { width: 45%; padding: 12px 30px; }
.bottom-box { box-sizing: border-box; }
.bottom-box a { box-sizing: border-box; }
.ts-boxer { max-width: 320px; width: 40%; margin: 0 auto; }
.ts-noti { background: url(../images/pingjia.png) no-repeat center center; height: 0; background-size: 100% auto; width: 100%; padding-bottom: 100%; display: block; }
/*评价*/
.evaluation-boxer { }
.evaluation-boxer .scoresr { padding: 6px 15px; color: #666666; line-height: 36px; }
.evaluation-boxer .scoresr i { font-size: 24px; color: #c5c3c3; }
.evaluation-boxer .scoresr li.checked i { color: #ff7200; }
.scoresr li { float: left; width: 31.4px; height: 24px; }
.words-box textarea { border: none; box-sizing: border-box; padding: 10px 15px; font-size: 14px; }
.com-bottom { padding: 0 15px; }
.ti-star { margin-top: 7px; background: url(../images/tip-star.png) no-repeat; text-align: left; width: 157px; height: 22px; background-size: cover; overflow: hidden; background-position: 0 -22px; }
.ti-star ul { background: url(../images/tip-star.png) no-repeat; width: 157px; height: 22px; background-size: cover; overflow: hidden; background-position: 0 -22px; }
.ti-star ul.one { background-position: -134px 0; }
.ti-star ul.two { background-position: -101px 0; }
.ti-star ul.three { background-position: -67px 0; }
.ti-star ul.four { background-position: -34px 0; }
.ti-star ul.five { background-position: 0 0; }
/*csx*/
.ptb12 { padding-top: 12px; padding-bottom: 12px; }
.n-list { background-color: #fff; }
.n-list > li, .n-list > .n-list-li { position: relative; display: -webkit-box; display: box; box-pack: center; padding-right: 15px; margin-left: 15px; border-top: 1px solid #f1f1f1; clear: both; }
.n-list > li:first-child, .n-list > .n-list-li:first-child { border-top: none; }
.n-list > .n-list-link:active { background-color: #f7f7f7; padding-left: 15px; margin-left: 0 }
.n-list > .n-list-cover { padding-left: 15px; margin-left: 0; }
.n-list > .list-arrow-r, .n-list > .list-arrow-d, .n-list > .list-arrow-u { padding-right: 30px }
.n-list > .list-arrow-r:after, .n-list > .list-arrow-d:after, .n-list > .list-arrow-u:after { position: absolute; top: 50%; right: 15px; margin-top: -5px; content: ""; display: block; width: 8px; height: 8px; border: solid #cdcdcd; border-width: 2px 2px 0 0; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); -ms-transform: rotate(45deg); transform: rotate(45deg); }
.n-list > .list-arrow-d:after { right: 13px; margin-top: -8px; -webkit-transform: rotate(135deg); -moz-transform: rotate(135deg); -ms-transform: rotate(135deg); transform: rotate(135deg); }
.n-list > .list-arrow-u:after { right: 13px; margin-top: -2px; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); -ms-transform: rotate(-45deg); transform: rotate(-45deg); }
.n-list-title { display: -webkit-box; display: -moz-box; display: box; -webkit-box-orient: vertical; -moz-box-orient: vertical; box-orient: vertical; -webkit-box-pack: start; -moz-box-pack: start; box-pack: start; }
.n-list-key, .n-list-info { display: -webkit-box; display: -moz-box; display: box; -webkit-box-orient: vertical; -moz-box-orient: vertical; box-orient: vertical; -webkit-box-pack: center; -moz-box-pack: center; box-pack: center; }
.n-list-info { display: -webkit-box; display: -moz-box; display: box; -webkit-box-flex: 1; -moz-box-flex: 1; box-flex: 1; }
.n-list-flex { display: -webkit-box; display: -moz-box; display: box; -webkit-box-flex: 1; -moz-box-flex: 1; box-flex: 1; }
.n-list > .n-list-function { border-top: none; padding-right: 0; }
.n-list > .n-list-function .n-list-flex { border-top: 1px solid #f1f1f1; }
.n-list > .n-list-function:first-child .n-list-flex { border-top: none; }
.n-list > li:first-child, .n-list > .n-list-function:first-child, .n-list > .n-list-function:first-child .n-list-info, .n-list > div:first-child { border: 0; }
.n-list > .n-list-label { border-top: none; padding-right: 0; }
.n-list .n-list-img { width: 100px; height: 68px; overflow: hidden; position: relative }
.n-list .n-list-img img { width: 100%; height: auto; }
.required { position: relative; }
.required:before { content: "*"; position: absolute; color: #f00; font-size: 14px; height: 12px; line-height: 12px; vertical-align: middle; left: -10px; top: 50%; margin-top: -5px; }
.n-avatar-s, .n-avatar-m, .n-avatar-l { width: 26px; height: 26px; display: -webkit-box; -webkit-box-pack: center; -webkit-box-align: center; }
.n-avatar-m { width: 43px; height: 43px; }
.n-avatar-l { width: 54px; height: 54px; }
.n-avatar-s img, .n-avatar-m img, .n-avatar-l img { width: 100%; height: 100%; }
/* 填写信息 */
.edit-info>li .n-list-key:first-child { width: 4em; color: #333; }
.edit-info>li .n-list-info { color: #5b5b5b; }
.add-member { color: #5b5b5b; line-height: 24px; vertical-align: middle; }
.add-member .iconfont { font-size: 24px; line-height: 24px; margin-left: 5px; }
.sel-sex li { display: inline-block; line-height: 24px; vertical-align: middle; margin-right: 30px; }
.sel-sex li i { font-family: "iconfont" !important; font-size: 24px; line-height: 24px; font-style: normal; -webkit-font-smoothing: antialiased; -webkit-text-stroke-width: 0.2px; -moz-osx-font-smoothing: grayscale; color: #dfdfdf; margin-right: 5px; }
.sel-sex li i.sex-male:before { content: "\d607"; }
.sel-sex li i.sex-female:before { content: "\d608"; }
.sel-sex li.selected i.sex-male:before { color: #4dcd70; content: "\d60a"; }
.sel-sex li.selected i.sex-female:before { color: #ee90ff; content: "\d60b"; }
.doc-avatar { width: 50px; height: 50px; border-radius: 50%; overflow: hidden; }
.doc-avatar img { width: 100%; height: 100%; }
/*投诉*/
.ts-box { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; width: 100%; padding: 0; border: none; }
.upload-img { overflow: hidden; display: inline-block; }
.upload-img ul li { position: relative; display: inline; float: left; width: 76px; height: 76px; padding: 0 10px 10px 0; }
.upload-img ul li img { width: 100%; height: 100%; }
.add-btn { position: relative; display: block; width: 74px; height: 74px; font-size: 0; color: #b8b8b8; border: 1px dashed #a0a0a0; background: #fff; }
.add-btn:before { content: ""; display: block; position: absolute; top: 34px; left: 22px; width: 30px; height: 2px; background: #a0a0a0; }
.add-btn:after { content: ""; display: block; position: absolute; top: 20px; left: 36px; width: 2px; height: 30px; background: #a0a0a0; }
.doc-tab li { width: 50%; }
.doc-tab li.hit { border-bottom: 3px solid #4dcd70; }
.doc-tab li.hit a { color: #4dcd70; }
.doc-list-sm { padding: 10px 15px; }
.doc-list-sm span { color: #666; }
.doc-list-sm b { color: #333; font-weight: normal; }
.delimgpop { position: fixed; width: 100%; height: 100%; left: 0; top: 0; background: #000; text-align: center; z-index: 2200; }
.del-img-box { width: 100%; height: 100%; display: table; }
.del-img-con { display: table-cell; vertical-align: middle; }
.del-img-con img { width: auto; height: auto; }
.del-img-con p { position: relative; display: inline-block; min-width: 100px; text-align: center; }
.del-img-box p:after { position: absolute; top: 0; left: 0; content: ""; background: rgba(255,255,255,.6); width: 100%; height: 40px; z-index: 10; }
.del-img-btn { display: inline-block; height: 40px; line-height: 40px; position: absolute; top: 0; right: 0; z-index: 20; padding: 0 15px; text-align: right; color: #000; }
.del-img-btn .iconfont { font-size: 20px; margin-right: 4px; }
/*2015.10.9*/
.w4em { width: 4em; }
.c-ff5bd3 { color: #ff5bd3; }
.c-images-cycle { border-radius: 50%; overflow: hidden; }
.word-bread { white-space: pre-wrap; word-wrap: break-word; word-wrap: break-all; }
/*健康指导*/
.histroy-title { padding: 8px 15px; color: #5b5b5b; font-size: 13px; }
.histroy-title .iconfont { color: #c5c5c5; }
.doctor-talk { padding: 6px 15px; font-size: 13px; }
.doctor-talk .iconfont { color: #37a6ed; font-size: 20px; }
/*已建档*/
.common-title { font-size: 13px; padding: 8px 15px; color: #5b5b5b; }
.tz-record-list .n-list-key { padding: 12px 20px 12px 0; }
.tz-record-list .n-avatar-m { font-size: 16px; border-radius: 50%; overflow: hidden; text-align: center; }
.tz-record-list .n-list-flex { padding: 12px 0; }
.tz-record-list .n-list-info { padding-right: 25px; }
.tz-record-list .n-list-info p { font-size: 13px; color: #909090; white-space: pre-wrap; word-wrap: break-word; }
.doctor-zd-list .n-list-key { padding: 12px 20px 12px 0; }
.doctor-zd-list .n-avatar-m { border-radius: 50%; overflow: hidden; }
.doctor-zd-list .n-list-flex { padding: 12px 0; }
.doctor-zd-list .n-list-info p { font-size: 13px; color: #909090; white-space: pre-wrap; word-wrap: break-word; }
.health-border-1 { border: 1px solid #ff9806; }
.health-border-2 { border: 1px solid #ff0606; }
.health-border-3 { border: 1px solid #4dcd70; }
.health-border-4 { border: 1px solid #ea68a2; }
.health-border-5 { border: 1px solid #1dbdbf; }
.health-border-6 { border: 1px solid #37a6ed; }
.health-border-7 { border: 1px solid #ae5da1; }
.dis-more-box { background: #fff; border-top: 1px solid #f1f1f1; }
.dis-more { display: block; padding: 10px 15px; }
.dis-more span { position: relative; color: #007cd9; font-size: 13px; display: inline-block; padding-right: 20px; }
.dis-more span:after { display: inline-block; position: absolute; right: 0; top: 2px; content: ""; width: 8px; height: 8px; border: solid #007cd9; border-width: 2px 2px 0 0; cursor: pointer; -webkit-transform: rotate(135deg); -moz-transform: rotate(135deg); transform: rotate(135deg); transition: all 0.5s; -webkit-transition: all 0.5s; }
.dis-more span.rotate:after { top: 8px; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); transform: rotate(-45deg); transition: all 0.5s; -webkit-transition: all 0.5s; }
.no-data { width: 100%; font-size: 13px; color: #909090; text-align: center; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
.no-data-img { width: 40%; max-width: 320px; margin: 0 auto; }
.no-zhidao-icon { width: 100%; height: 0; padding-bottom: 100%; background: url(../images/no-zhidao.png) no-repeat 0 0; background-size: 100% auto; }
.no-data p { padding-top: 10px; }
/*曲线*/
.curve-tab { padding: 10px 7px; background: #f3f3f3; overflow: hidden; }
.curve-tab li { float: left; width: 25%; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; padding: 0 8px; }
.curve-tab li a { display: inline-block; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; width: 100%; height: 28px; line-height: 28px; font-size: 14px; border-radius: 3px; text-align: center; color: #333; border: 1px solid #e1e1e1; background: #fff; }
.curve-tab li.current a { background: #4dcd70; border: 1px solid #4dcd70; color: #fff; }
.curve-box { padding: 10px 0 0 5px; }
.curve-charts { width: 100%; height: 300px; }
.curve-box .swiper-container { padding-bottom: 30px; }
.chart-zt { text-align: right; padding: 10px 15px; }
.chart-zt li { display: inline-block; margin-left: 15px; }
.chart-zt li i { display: inline-block; width: 10px; height: 10px; border-radius: 50%; }
.chart-title { text-align: center; padding: 10px 15px; }
.chart-title li { display: inline-block; margin-right: 15px; }
.chart-title li i { display: inline-block; width: 16px; height: 4px; margin-bottom: 3px; }
.bgc-0ad800 { background: #0ad800; }
.bgc-f00 { background: #f00; }
.bgc-0ad800 { background: #0ad800; }
.bgc-f00 { background: #f00; }
.bgc-b6a2de { background: #b6a2de; }
.bgc-5dd1d2 { background: #5dd1d2; }
/*健康头条*/
.news-list li { padding-top: 12px; padding-bottom: 12px; }
.news-pic { width: 60px; height: 60px; border-radius: 4px; overflow: hidden; }
.news-pic img { width: 100%; height: 100%; }
.pull-more { display: block; text-align: center; color: #5b5b5b; font-size: 14px; padding: 10px 0; }
.pull-more:active { background: rgba(0,0,0,.05); }
.art-detil { padding: 15px; }
.art-detil h1 { font-size: 18px; line-height: 30px; color: #333; }
.art-detil a { color: #137bf2; }
.art-detil img { max-width: 100%; display: block; margin: 10px auto; }
.art-con p { color: #666; font-size: 14px; line-height: 1.5em; padding: 5px 0; text-indent: 2em; white-space: pre-wrap; word-wrap: break-word; word-wrap: break-all; }
.art-con a { display: block; clear: both; color: #137bf2; }
/* 个人中心 */
.addp-list .input-group-addon { min-width: 100%; width: 90px; text-align: right; }
.mem-top { background-color: #fafafa; position: relative; }
.men-list li { position: relative; }
.men-list .mltb1 { background: #34aadc; }
.men-list .mltb2 { background: #4fdb67; }
.men-list .mltb3 { background: #ff9501; }
.men-list .mltb4 { background: #017aff; }
.men-list .mltb5 { background: #49cc6d; }
.men-list .mltb6 { background: #ff6600; }
.men-list .mltb7 { background: #4579f0; }
.men-list .mltb8 { background: #ff9501; }
.men-list .mltb9 { background: #2caddf; }
.men-list .mltb10 { background: #f39800; }
.men-list .mltb11 { background: #ed2100; }
.men-list li .c-avatar-s { position: relative; overflow: inherit; vertical-align: middle; }
.men-list li .c-list-action { top: 0px; }
.mlnum { position: absolute; top: -4px; right: -4px; width: 12px; height: 12px; background: #ec4300; text-align: center; line-height: 12px; font-size: 8px; color: #fff; }
.men-list li .iconfont { font-size: 18px; color: #fff; }
.men-list li .qytimes { display: block; position: absolute; right: 15px; top: 50%; margin-top: -10px; font-size: 12px; color: #fff; }
/*健康历程*/
.main {  }
.health-course { position: relative; min-height: 100%; padding: 0 15px; z-index: 100; }
.health-course:after { position: absolute; content: ""; width: 2px; height: 100%; background: #4dcd70; top: 0; left: 36px; z-index: 101; }
.course-year { position: relative; z-index: 200; width: 100%; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; margin-top: 15px; }
.course-year i { display: inline-block; width: 46px; height: 46px; line-height: 46px; font-size: 14px; text-align: center; color: #fff; border-radius: 50%; background: #4dcd70; }
.course-date-list { padding-bottom: 5px; }
.course-date-list li { position: relative; padding-left: 40px; z-index: 200; margin-bottom: 15px; }
.course-date-list li:after { position: absolute; content: ""; width: 12px; height: 12px; border-radius: 50%; background: #4dcd70; top: 30px; left: 16px; z-index: 201; }
.coruse-date { height: 20px; font-size: 13px; color: #909090; padding-left: 1em; }
.coruse-con { position: relative; background: #fff; border: 1px solid #e1e1e1; border-radius: 4px; padding: 7px 10px; }
.coruse-con:after { position: absolute; top: 10px; left: -6px; content: ""; width: 10px; height: 10px; border: 1px solid #e1e1e1; border-width: 0 0 1px 1px; background: #fff; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); -ms-transform: rotate(45deg); transform: rotate(45deg); }
.coruse-con p { font-size: 13px; color: #5b5b5b; white-space: pre-wrap; word-wrap: break-word; word-wrap: break-all; padding: 3px 0; }
.coruse-con p span { color: #333; padding-right: 5px; }
/*门诊详情*/
.outp-details-top { position: fixed; width: 100%; top: 0; left: 0; background: #fff; height: 72px; border-bottom: 1px solid #e1e1e1; color: #333; font-size: 14px; padding: 8px 15px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; z-index: 100; }
.outp-details-top li { width: 50%; height: 28px; line-height: 28px; float: left; padding-right: 5px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
.outp-details-top li span { margin-right: 5px; }
.outp-details-top:before { position: absolute; top: 72px; left: 0; content: ""; width: 100%; height: 15px; background: #f3f3f3; border-bottom: 1px solid #e1e1e1; }
.outp-details-top:after { position: absolute; top: 88px; left: 0; content: ""; width: 100%; height: 10px; background: #fff; }
.outp-details-box { padding: 0 15px 30px 15px; background: #fff; margin-top: 97px; }
.outp-details-con { width: 100%; }
.outp-details-con dl { padding-bottom: 10px; }
.outp-details-con dl dt { position: relative; color: #333; font-size: 15px; padding-left: 15px; }
.outp-details-con dl dt:before { position: absolute; content: ""; width: 8px; height: 8px; border-radius: 50%; background: #4dcd70; top: 50%; left: 0; margin-top: -4px; }
.outp-details-con dl dd { color: #666; font-size: 13px; white-space: pre-wrap; word-wrap: break-word; word-wrap: break-all; }
.outp-doctor-info { color: #5b5b5b; font-size: 14px; padding-top: 15px; margin-top: 5px; border-top: 1px dotted #e1e1e1; }
.outp-doctor-info span { color: #333; margin-right: 10px; }
.outp-doctor-info .iconfont { color: #007cd9; margin-right: 5px; }
/*我的圈子*/
.quanzi-top { position: fixed; width: 100%; top: 0; left: 0; background: #fff; height: 75px; border-bottom: 1px solid #e1e1e1; color: #333; font-size: 14px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; z-index: 100; }
.quanzi-top li { width: 50%; height: 75px; padding-top: 12px; text-align: center; font-size: 15px; color: #5b5b5b; float: left; border-right: 1px solid #e1e1e1; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
.quanzi-top li:last-child { border-right: none; }
.quanzi-top li .iconfont { font-size: 30px; line-height: 30px; color: #4dcd70; }
.quanzi-top li:last-child .iconfont { color: #37a6ec; }
.quanzi-top:before { position: absolute; top: 75px; left: 0; content: ""; width: 100%; height: 15px; background: #f3f3f3; border-bottom: 1px solid #e1e1e1; }
.quanzi-box { background: #fff; margin-top: 90px; }
.quanzi-list .n-list-key { padding: 12px 20px 12px 0; }
.quanzi-list .n-avatar-m { border-radius: 50%; overflow: hidden; }
.quanzi-list .n-list-flex { padding: 12px 0; }
.quanzi-list .n-list-info { padding-right: 15px; }
/*体重*/
ul.fosx-li .input-group .form-select-arrow { top: 17px; right: 0; }
ul.fosx-li .form-control { text-align: left; padding-right: 30px; }
.ptb8 { padding-top: 8px; padding-bottom: 8px; }
.input-group.bor-radius-tic .form-control { border-radius: 0; }
.no-border { border: none !important; }
.patient-list .form-control { font-size: 17px !important; }
.dwfl { min-width: 53.33px !important; }
.patient-list input { color: #5b5b5b !important; }
.wis-fix .c-list .c-list-value { min-width: 65px; }
.c5b { color: #5b5b5b; }
.c-table.pos td, .c-table.pos th { border-bottom: 1px solid #f1f1f1; border-right: 1px solid #f1f1f1; text-align: center; padding: 10px 5px; font-weight: normal; }
/*体重历史*/
.health-table-blue { background: #32aa6d; color: #fff; overflow: hidden; }
.bg-fff { background-color: #fff; }
.bg-32aa6d { background: #32aa6d; }
.c-333 { color: #333 !important; }
.ptb8 { padding-top: 8px; padding-bottom: 8px; }
/*选择医生*/
.c-ser-into { border: none; }
.hd85 { height: 85px; }
.sarea-box { width: 100%; height: 40px; line-height: 40px; background: #fff; position: fixed; left: 0; top: 0; padding: 0 15px; z-index: 800; }
.sarea-box i.icon-ditudingwei { font-size: 22px; vertical-align: middle; margin: 0 0 4px 0; color: #888; }
.sarea-box i.icon-dingwei { font-size: 22px; vertical-align: middle; margin: 0 0 4px 0; color: #007cd9; }
.sarea-box .list-icon { display: inline-block; vertical-align: middle; margin: 0 0 7px 5px; position: relative; left: 0; top: 0; -webkit-transform: rotate(135deg); -moz-transform: rotate(135deg); -ms-transform: rotate(135deg); -o-transform: rotate(135deg); transform: rotate(135deg); }
.sarea-box .arrow-right { border-color: #cbcbcb; }
.sseach-box { width: 100%; height: 45px; background: #fff; position: fixed; left: 0; top: 40px; padding: 0px 15px 0 15px; z-index: 800; }
.shcom-list ul li .c-list-img { width: 50px; height: 50px; border-radius: 50px; overflow: hidden; }
.shcom-list ul li .c-list-img img { width: 50px; height: 50px; }
.shcom-list ul li .c-list-info { padding-right: 30px; }
.r-15 { right: 15px; }
.c-ccc { color: #ccc; }
.pl25 { padding-left: 25px; }
.c888 { color: #888; }
.c-000 { color: #000; }
.list-icon { height: 8px; width: 8px; position: absolute; display: inline-block; margin-top: -4px; top: 50%; }
.serch-hold { width: 100%; height: 66px; background: #fff; position: fixed; left: 0; top: 0; z-index: 600; padding: 15px 15px 0 15px; display: box; display: -webkit-box; }
.ser-box { border: 1px solid #e1e1e1; border-radius: 4px; height: 36px; font-size: 13px; box-flex: 1; -webkit-box-flex: 1; -moz-box-flex: 1; padding: 0 10px; position: relative; }
.ser-box a.s-initial { display: block; line-height: 34px; /*color:#dfdfdf;*/ position: relative; }
.ser-box .ser-icon { position: absolute; /*right:15px;*/ top: 50%; margin-top: -8px; }
.ser-box .ser-icon:before { content: ""; position: absolute; background: transparent; font-size: 1px; left: 1px; top: 0px; width: 10px; height: 10px; border: 2px solid #ccc; border-radius: 50%; }
.ser-box .ser-icon:after { content: ""; position: absolute; background: transparent; font-size: 1px; left: 11px; top: 12px; width: 6px; height: 2px; background: #ccc; transform: rotate(45deg); -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); -o-transform: rotate(45deg); -ms-transform: rotate(45deg); }
.ser-box .input-clear { position: absolute; right: 6px; top: 9px; background: #7e7e7e; border-radius: 50%; width: 16px; height: 16px; text-align: center; }
.ser-box .input-clear .close { position: relative; display: inline-block; width: 10px; height: 10px; overflow: hidden; top: -2px; }
.ser-box .input-clear .close:before, .ser-box .input-clear .close:after { content: ''; position: absolute; height: 2px; width: 100%; top: 50%; left: 0px; margin-top: -1px; background: #fff; border-radius: 6px; }
.ser-box .input-clear .close:before { -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); -ms-transform: rotate(45deg); -o-transform: rotate(45deg); transform: rotate(45deg); }
.ser-box .input-clear .close:after { -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); -ms-transform: rotate(-45deg); -o-transform: rotate(-45deg); transform: rotate(-45deg); }
.ser-text { width: 100%; height: 34px; line-height: normal; }
.s-cancle { display: inline-block; box-flex: 0; -webkit-box-flex: 0; -moz-box-flex: 0; width: 40px; line-height: 40px; text-align: right; color: #007cd9; font-size: 14px; }
.disa-space { width: 100%; background: #eff1f3; height: 10px; position: fixed; left: 0; top: 66px; z-index: 500; }
.disea-div { width: 100%; height: 100%; position: fixed; left: 0; top: 0; padding-top: 76px; z-index: 10; }
.disea-first { width: 32%; height: 100%; background: #f5f5f5; border-top: 1px solid #e1e1e1; float: left; }
.disea-first li a { display: block; height: 50px; line-height: 50px; padding-left: 15px; color: #333; position: relative; font-size: 14px; }
.disea-first li a.hit { background: #fff; color: #4dcd70; }
.disea-first li a .arrow { position: absolute; display: block; font-size: 0; line-height: 0; width: 0; height: 0; border-color: transparent; border-style: dashed; border-width: 6px; right: 0; top: 50%; margin-top: -6px; border-right-color: #ebebeb; border-right-style: solid; }
.disea-first li a.hit .arrow { border-right-color: #fff; }
.disea-sec { width: 68%; height: 100%; background: #fff; border-top: 1px solid #e1e1e1; float: left; padding: 0 0 0 20px; }
.disea-sec li a { display: block; height: 43px; line-height: 43px; color: #666; box-sizing: border-box; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; border-bottom: 1px solid #f2f2f2; position: relative; font-size: 14px; }
.result-list { }
.result-list li { line-height: 40px; border-top: 1px solid #f2f2f2; background: #fff; padding: 0 15px; }
.result-list li:first-child { border-top: none; }
.result-list li a { display: block; color: #666; font-size: 14px; }
.no-serch { text-align: center; line-height: 23px; padding: 0 15px; }
.icon-noserch { display: inline-block; width: 110px; height: 110px; background: url(../images/noser.png) no-repeat; background-size: 100% 100%; -webkit-background-size: 100% 100%; -moz-background-size: 100% 100%; -ms-background-size: 100% 100%; margin: 40px 0 5px 0; }
.doc-choo .c-avatar-m { margin: 10px 10px 10px 0; }
/*2015.10.10*/
/*个人中心-选择联系人*/
.ql-boxer { position: fixed; top: 0; width: 100%; left: 0; }
.ql-boxer .c-serdet { padding: 7px 15px 0 15px; }
.choose-chat li i { display: block; width: 20px; height: 20px; }
.choose-chat li i.circ { border: 1px solid #d3d3d3; }
.choose-chat { padding-top: 43px; }
.choose-chat li { position: relative; }
.choose-chat li input { display: none; }
.choose-chat li .c-avatar-m { overflow: hidden; padding-left: 32px; }
.choose-chat li .c-avatar-m img { border-radius: 50%; overflow: hidden; }
.choose-chat li i { position: absolute; width: 20px; height: 20px; top: 18px; left: 15px; border-radius: 20px; }
.choose-chat li i.icon-dagou { text-align: center; color: #fff; background: #4dcd70; line-height: 22px; width: 22px; height: 22px; }
.ts-noda { background: url(../images/no-search.png) no-repeat center center; height: 0; background-size: 100% auto; width: 100%; padding-bottom: 100%; display: block; }
.c-dcdcdc { color: #dcdcdc; }
.choose-chat .search-li li .c-avatar-m { padding-left: 0 }
.c-888 { color: #888888; }
a.a-more { color: #007cd9; display: block; width: 100%; text-align: center; padding: 10px 0; color: #007cd9; font-size: 12px;/* border-top: 1px solid #f1f1f1; */ }
/* 对话 */
.my-team-top { width: 100%; height: 79px; background: #fff; border-bottom: 1px solid #e1e1e1; overflow-x: auto; overflow-y: hidden; }
.my-team-top ul { height: 79px; width: 100%; }
.my-team-top li { float: left; width: 33.33%; height: 70px; padding-top: 9px; text-align: center; color: #666; font-size: 13px; }
.my-team-top li img { width: 40px; height: 40px; border-radius: 50%; overflow: hidden; }
.advis-dialog-box { overflow-y: auto; }
.advis-dialog .ditime { text-align: center; font-size: 12px; color: #aeaeae; line-height: 18px; padding-bottom: 8px; }
.advis-dialog .ditime:before, .advis-dialog .ditime:after { content: ""; display: inline-block; width: 50px; height: 4px; background: transparent; margin: 0 10px; border-top: 1px solid #e6e4e1; }
.dial-left .dialog { padding: 0 0 0 55px; position: relative; overflow: hidden; }
.dial-left .dihead { width: 40px; height: 40px; position: absolute; left: 0; top: 5px; border-radius: 50%; overflow: hidden; }
.dial-left .dihead img { width: 100%; height: 100%; }
.dial-left .diname { display:block; font-size:12px; color:#909090; width:100%; height:20px;}
.dial-left .dicon { font-size: 13px; background: #fff; border: 1px solid #e1e1e1; padding: 10px; border-radius: 4px; -webkit-border-radius: 4px; -moz-border-radius: 4px; color: #333; float: left; word-break: break-all; }
.dial-left .dicon:before { position: absolute; content: ""; top: 30px; left: 50px; width: 10px; height: 10px; border: 1px solid #e1e1e1; border-width: 0 0 1px 1px; background: #fff; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); -ms-transform: rotate(45deg); transform: rotate(45deg); }
.dial-right .dialog { padding: 0 55px 0 0; position: relative; overflow: hidden; }
.dial-right .dihead { width: 40px; height: 40px; position: absolute; right: 0; top: 5px; }
.dial-right .dihead img { width:100%; height:100%; }
.dial-right .diname { display:block; text-align:right; font-size:12px; color:#909090; width:100%; height:20px;}
.dial-right .dicon { font-size: 13px; background: #bce0ff; border: 1px solid #81bdf7; padding: 10px; border-radius: 4px; -webkit-border-radius: 4px; -moz-border-radius: 4px; color: #5b5b5b; float: right; word-break: break-all; }
.dial-right .dicon:before { position: absolute; content: ""; top: 30px; right: 50px; width: 10px; height: 10px; border: 1px solid #81bdf7; border-width: 1px 1px 0 0; background: #bce0ff; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); -ms-transform: rotate(45deg); transform: rotate(45deg); }
.dicon img{ max-height:120px; max-width:120px;}
.advis-end { background: #e6eef9; line-height: 20px; text-align: center; }
.advis-end i { font-size: 18px; color: #ff8100; vertical-align: middle; margin: 0 5px 0 0; }
.advis-end a { font-size: 14px; color: #157efb; }
.advis-bot { width: 100%; height: 63px; background: #fff; position: fixed; left: 0; bottom: 0; padding: 14px 93px 0 15px; }
.advis-bot a { display: block; position: absolute; right: 15px; top: 14px; color: #333; font-size: 14px; padding: 0 18px; height: 33px; line-height: 33px !important; background: #f5f5f5; border: 1px solid #bebebe; border-radius: 5px; -webkit-border-radius: 5px; -moz-border-radius: 5px; }
.advis-bot .askbtn { width: 100%; height: 35px; line-height: normal; border: 1px solid #bebebe; border-radius: 5px; -webkit-border-radius: 5px; -moz-border-radius: 5px; padding: 5px 10px; appearance: none; -webkit-appearance: none; -moz-appearance: none; background: #fff; }
.chat-form { height: 45px; padding-left: 10px; padding-right: 10px; }
.nopos { position: relative; bottom: auto; left: auto; }
.chat-form .ui-col-0 { width: 44px; text-align: center; }
.chat-form .ui-col-0 a { display: inline-block; height: 30px; width: 30px; line-height: 30px; position: relative; top: 8px; color: #808080; }
.chat-form .ui-col-0 a .iconfont { font-size: 30px; line-height: 30px; }
.chat-input { height: 22px; font-size: 13px; line-height: 22px; border: 0; border-bottom: #4dcd70 1px solid; position: relative; top: 14px; }
.chat-pictures-wrap { height: 100%; z-index: 2323; top: 0; left: 0; display: none; }
.chat-pictures-bg { height: 100%; background-color: rgba(0, 0, 0, 0.7); }
.chat-pictures-btn { bottom: 10px; left: 0 }
.chat-pictures-a { overflow: hidden }
.chat-pictures-a a { height: 45px; line-height: 45px; display: block; font-size: 15px; color: #00a1d8; text-align: center; width: 100%; background-color: #fff; border-bottom: #e1e1e1 1px solid }
.chat-pictures-a a:last-child { border-bottom: 0 }
.chat-pictures-a a em { display: inline-block; border: #00a1d8 1px solid; border-radius: 50%; line-height: 12px; position: relative; top: -2px }
.chat-pictures-a a i.iconfont { font-size: 18px; margin-right: 5px; }
.chat-form .ui-col-0 a.chat-send { display: inline-block; width: 44px; height: 31px; line-height: 31px; background: #4dcd70; text-align: center; font-size: 13px; color: #fff; border: none; border-radius: 3px; float: left; }
.view-more { display: inline-block; width: 100%; text-align: center; color: #5b5b5b; padding: 15px 0 10px 0; }
.c-ser-main.onlytext { background-color: transparent; border: 1px solid transparent; color: #5b5b5b; padding-left: 0; }
.curve-box .swiper-container { width:100% !important;}
.curve-box .swiper-pagination{ clear:both;}
/* 暂无信息 */
.nomess{ text-align:center; line-height:30px; padding:120px 0 60px 0; color:#5b5b5b;}
.nomess i{ display:block; width:90px; height:90px; background-position:-1px -30px; margin:0 auto;}
.icon{ background:url(../images/icon.png) no-repeat; background-size:250px 250px; -webkit-background-size:250px 250px; -moz-background-size:250px 250px; -ms-background-size:250px 250px;}
/*2015.11.24*/
.edit-info.registered>li .n-list-key:first-child{width:5em;}
.fi-btnbox{bottom:0;left:0;width:100%;padding:5px 15px;box-sizing:border-box;background:#e1e1e1;}
.bottom-box.fi-btnbox a.c-btn{padding:12px 16px;}
.pb47{padding-bottom:47px;}
.getmore{ width:100%;}
.getmore a{ display:block; width:100%; line-height:40px; color:#5b5b5b; text-align:center; font-size:14px; background:#f3f3f3;}
/*2015.12.25*/
.sigl-up .n-list-key{width:6.5em !important;}
.sigl-up .n-list-key i.iconfont{color:#4dcd70;}
.c-btn-fff.c-333{color:#333;}
.doc-tab-les{ margin-left:10px; margin-right:10px; margin-top:10px; border:1px solid #4dcd70; border-radius:5px; background:#fff;}
.doc-tab-les li a{ color:#4dcd70;}
.doc-tab-les li.hit{ background:#4dcd70;}
.doc-tab-les li.hit a{ color:#fff;}
.doc-tab-les li{ border-left:1px solid #4dcd70;}

+ 1046 - 0
html/jkda/css/template.css

@ -0,0 +1,1046 @@
.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9 {
    position: relative;
    min-height: 1px;
    padding-right: 15px;
    padding-left: 15px
}
.col-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9 {
    float: left
}
.col-xs-12 {
    width: 100%
}
.col-xs-11 {
    width: 91.66666667%
}
.col-xs-10 {
    width: 83.33333333%
}
.col-xs-9 {
    width: 75%
}
.col-xs-8 {
    width: 66.66666667%
}
.col-xs-7 {
    width: 58.33333333%
}
.col-xs-6 {
    width: 50%
}
.col-xs-5 {
    width: 41.66666667%
}
.col-xs-4 {
    width: 33.33333333%
}
.col-xs-3 {
    width: 25%
}
.col-xs-2 {
    width: 16.66666667%
}
.col-xs-1 {
    width: 8.33333333%
}
.col-xs-pull-12 {
    right: 100%
}
.col-xs-pull-11 {
    right: 91.66666667%
}
.col-xs-pull-10 {
    right: 83.33333333%
}
.col-xs-pull-9 {
    right: 75%
}
.col-xs-pull-8 {
    right: 66.66666667%
}
.col-xs-pull-7 {
    right: 58.33333333%
}
.col-xs-pull-6 {
    right: 50%
}
.col-xs-pull-5 {
    right: 41.66666667%
}
.col-xs-pull-4 {
    right: 33.33333333%
}
.col-xs-pull-3 {
    right: 25%
}
.col-xs-pull-2 {
    right: 16.66666667%
}
.col-xs-pull-1 {
    right: 8.33333333%
}
.col-xs-pull-0 {
    right: auto
}
.col-xs-push-12 {
    left: 100%
}
.col-xs-push-11 {
    left: 91.66666667%
}
.col-xs-push-10 {
    left: 83.33333333%
}
.col-xs-push-9 {
    left: 75%
}
.col-xs-push-8 {
    left: 66.66666667%
}
.col-xs-push-7 {
    left: 58.33333333%
}
.col-xs-push-6 {
    left: 50%
}
.col-xs-push-5 {
    left: 41.66666667%
}
.col-xs-push-4 {
    left: 33.33333333%
}
.col-xs-push-3 {
    left: 25%
}
.col-xs-push-2 {
    left: 16.66666667%
}
.col-xs-push-1 {
    left: 8.33333333%
}
.col-xs-push-0 {
    left: auto
}
.col-xs-offset-12 {
    margin-left: 100%
}
.col-xs-offset-11 {
    margin-left: 91.66666667%
}
.col-xs-offset-10 {
    margin-left: 83.33333333%
}
.col-xs-offset-9 {
    margin-left: 75%
}
.col-xs-offset-8 {
    margin-left: 66.66666667%
}
.col-xs-offset-7 {
    margin-left: 58.33333333%
}
.col-xs-offset-6 {
    margin-left: 50%
}
.col-xs-offset-5 {
    margin-left: 41.66666667%
}
.col-xs-offset-4 {
    margin-left: 33.33333333%
}
.col-xs-offset-3 {
    margin-left: 25%
}
.col-xs-offset-2 {
    margin-left: 16.66666667%
}
.col-xs-offset-1 {
    margin-left: 8.33333333%
}
.col-xs-offset-0 {
    margin-left: 0
}
.ff{
	width:100px;
	text-align:right;
}
@media (min-width: 768px) {
    .col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9 {
        float:left
    }
    .col-sm-12 {
        width: 100%
    }
    .col-sm-11 {
        width: 91.66666667%
    }
    .col-sm-10 {
        width: 83.33333333%
    }
    .col-sm-9 {
        width: 75%
    }
    .col-sm-8 {
        width: 66.66666667%
    }
    .col-sm-7 {
        width: 58.33333333%
    }
    .col-sm-6 {
        width: 50%
    }
    .col-sm-5 {
        width: 41.66666667%
    }
    .col-sm-4 {
        width: 33.33333333%
    }
    .col-sm-3 {
        width: 25%
    }
    .col-sm-2 {
        width: 16.66666667%
    }
    .col-sm-1 {
        width: 8.33333333%
    }
    .col-sm-pull-12 {
        right: 100%
    }
    .col-sm-pull-11 {
        right: 91.66666667%
    }
    .col-sm-pull-10 {
        right: 83.33333333%
    }
    .col-sm-pull-9 {
        right: 75%
    }
    .col-sm-pull-8 {
        right: 66.66666667%
    }
    .col-sm-pull-7 {
        right: 58.33333333%
    }
    .col-sm-pull-6 {
        right: 50%
    }
    .col-sm-pull-5 {
        right: 41.66666667%
    }
    .col-sm-pull-4 {
        right: 33.33333333%
    }
    .col-sm-pull-3 {
        right: 25%
    }
    .col-sm-pull-2 {
        right: 16.66666667%
    }
    .col-sm-pull-1 {
        right: 8.33333333%
    }
    .col-sm-pull-0 {
        right: auto
    }
    .col-sm-push-12 {
        left: 100%
    }
    .col-sm-push-11 {
        left: 91.66666667%
    }
    .col-sm-push-10 {
        left: 83.33333333%
    }
    .col-sm-push-9 {
        left: 75%
    }
    .col-sm-push-8 {
        left: 66.66666667%
    }
    .col-sm-push-7 {
        left: 58.33333333%
    }
    .col-sm-push-6 {
        left: 50%
    }
    .col-sm-push-5 {
        left: 41.66666667%
    }
    .col-sm-push-4 {
        left: 33.33333333%
    }
    .col-sm-push-3 {
        left: 25%
    }
    .col-sm-push-2 {
        left: 16.66666667%
    }
    .col-sm-push-1 {
        left: 8.33333333%
    }
    .col-sm-push-0 {
        left: auto
    }
    .col-sm-offset-12 {
        margin-left: 100%
    }
    .col-sm-offset-11 {
        margin-left: 91.66666667%
    }
    .col-sm-offset-10 {
        margin-left: 83.33333333%
    }
    .col-sm-offset-9 {
        margin-left: 75%
    }
    .col-sm-offset-8 {
        margin-left: 66.66666667%
    }
    .col-sm-offset-7 {
        margin-left: 58.33333333%
    }
    .col-sm-offset-6 {
        margin-left: 50%
    }
    .col-sm-offset-5 {
        margin-left: 41.66666667%
    }
    .col-sm-offset-4 {
        margin-left: 33.33333333%
    }
    .col-sm-offset-3 {
        margin-left: 25%
    }
    .col-sm-offset-2 {
        margin-left: 16.66666667%
    }
    .col-sm-offset-1 {
        margin-left: 8.33333333%
    }
    .col-sm-offset-0 {
        margin-left: 0
    }
}
@media (min-width: 992px) {
    .col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9 {
        float:left
    }
    .col-md-12 {
        width: 100%
    }
    .col-md-11 {
        width: 91.66666667%
    }
    .col-md-10 {
        width: 83.33333333%
    }
    .col-md-9 {
        width: 75%
    }
    .col-md-8 {
        width: 66.66666667%
    }
    .col-md-7 {
        width: 58.33333333%
    }
    .col-md-6 {
        width: 50%
    }
    .col-md-5 {
        width: 41.66666667%
    }
    .col-md-4 {
        width: 33.33333333%
    }
    .col-md-3 {
        width: 25%
    }
    .col-md-2 {
        width: 16.66666667%
    }
    .col-md-1 {
        width: 8.33333333%
    }
    .col-md-pull-12 {
        right: 100%
    }
    .col-md-pull-11 {
        right: 91.66666667%
    }
    .col-md-pull-10 {
        right: 83.33333333%
    }
    .col-md-pull-9 {
        right: 75%
    }
    .col-md-pull-8 {
        right: 66.66666667%
    }
    .col-md-pull-7 {
        right: 58.33333333%
    }
    .col-md-pull-6 {
        right: 50%
    }
    .col-md-pull-5 {
        right: 41.66666667%
    }
    .col-md-pull-4 {
        right: 33.33333333%
    }
    .col-md-pull-3 {
        right: 25%
    }
    .col-md-pull-2 {
        right: 16.66666667%
    }
    .col-md-pull-1 {
        right: 8.33333333%
    }
    .col-md-pull-0 {
        right: auto
    }
    .col-md-push-12 {
        left: 100%
    }
    .col-md-push-11 {
        left: 91.66666667%
    }
    .col-md-push-10 {
        left: 83.33333333%
    }
    .col-md-push-9 {
        left: 75%
    }
    .col-md-push-8 {
        left: 66.66666667%
    }
    .col-md-push-7 {
        left: 58.33333333%
    }
    .col-md-push-6 {
        left: 50%
    }
    .col-md-push-5 {
        left: 41.66666667%
    }
    .col-md-push-4 {
        left: 33.33333333%
    }
    .col-md-push-3 {
        left: 25%
    }
    .col-md-push-2 {
        left: 16.66666667%
    }
    .col-md-push-1 {
        left: 8.33333333%
    }
    .col-md-push-0 {
        left: auto
    }
    .col-md-offset-12 {
        margin-left: 100%
    }
    .col-md-offset-11 {
        margin-left: 91.66666667%
    }
    .col-md-offset-10 {
        margin-left: 83.33333333%
    }
    .col-md-offset-9 {
        margin-left: 75%
    }
    .col-md-offset-8 {
        margin-left: 66.66666667%
    }
    .col-md-offset-7 {
        margin-left: 58.33333333%
    }
    .col-md-offset-6 {
        margin-left: 50%
    }
    .col-md-offset-5 {
        margin-left: 41.66666667%
    }
    .col-md-offset-4 {
        margin-left: 33.33333333%
    }
    .col-md-offset-3 {
        margin-left: 25%
    }
    .col-md-offset-2 {
        margin-left: 16.66666667%
    }
    .col-md-offset-1 {
        margin-left: 8.33333333%
    }
    .col-md-offset-0 {
        margin-left: 0
    }
}
@media (min-width: 1200px) {
    .col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9 {
        float:left
    }
    .col-lg-12 {
        width: 100%
    }
    .col-lg-11 {
        width: 91.66666667%
    }
    .col-lg-10 {
        width: 83.33333333%
    }
    .col-lg-9 {
        width: 75%
    }
    .col-lg-8 {
        width: 66.66666667%
    }
    .col-lg-7 {
        width: 58.33333333%
    }
    .col-lg-6 {
        width: 50%
    }
    .col-lg-5 {
        width: 41.66666667%
    }
    .col-lg-4 {
        width: 33.33333333%
    }
    .col-lg-3 {
        width: 25%
    }
    .col-lg-2 {
        width: 16.66666667%
    }
    .col-lg-1 {
        width: 8.33333333%
    }
    .col-lg-pull-12 {
        right: 100%
    }
    .col-lg-pull-11 {
        right: 91.66666667%
    }
    .col-lg-pull-10 {
        right: 83.33333333%
    }
    .col-lg-pull-9 {
        right: 75%
    }
    .col-lg-pull-8 {
        right: 66.66666667%
    }
    .col-lg-pull-7 {
        right: 58.33333333%
    }
    .col-lg-pull-6 {
        right: 50%
    }
    .col-lg-pull-5 {
        right: 41.66666667%
    }
    .col-lg-pull-4 {
        right: 33.33333333%
    }
    .col-lg-pull-3 {
        right: 25%
    }
    .col-lg-pull-2 {
        right: 16.66666667%
    }
    .col-lg-pull-1 {
        right: 8.33333333%
    }
    .col-lg-pull-0 {
        right: auto
    }
    .col-lg-push-12 {
        left: 100%
    }
    .col-lg-push-11 {
        left: 91.66666667%
    }
    .col-lg-push-10 {
        left: 83.33333333%
    }
    .col-lg-push-9 {
        left: 75%
    }
    .col-lg-push-8 {
        left: 66.66666667%
    }
    .col-lg-push-7 {
        left: 58.33333333%
    }
    .col-lg-push-6 {
        left: 50%
    }
    .col-lg-push-5 {
        left: 41.66666667%
    }
    .col-lg-push-4 {
        left: 33.33333333%
    }
    .col-lg-push-3 {
        left: 25%
    }
    .col-lg-push-2 {
        left: 16.66666667%
    }
    .col-lg-push-1 {
        left: 8.33333333%
    }
    .col-lg-push-0 {
        left: auto
    }
    .col-lg-offset-12 {
        margin-left: 100%
    }
    .col-lg-offset-11 {
        margin-left: 91.66666667%
    }
    .col-lg-offset-10 {
        margin-left: 83.33333333%
    }
    .col-lg-offset-9 {
        margin-left: 75%
    }
    .col-lg-offset-8 {
        margin-left: 66.66666667%
    }
    .col-lg-offset-7 {
        margin-left: 58.33333333%
    }
    .col-lg-offset-6 {
        margin-left: 50%
    }
    .col-lg-offset-5 {
        margin-left: 41.66666667%
    }
    .col-lg-offset-4 {
        margin-left: 33.33333333%
    }
    .col-lg-offset-3 {
        margin-left: 25%
    }
    .col-lg-offset-2 {
        margin-left: 16.66666667%
    }
    .col-lg-offset-1 {
        margin-left: 8.33333333%
    }
    .col-lg-offset-0 {
        margin-left: 0
    }
}
table {
    background-color: transparent
}
caption {
    padding-top: 8px;
    padding-bottom: 8px;
    color: #777;
    text-align: left
}
th {
    text-align: left
}
.table {
    width: 100%;
    max-width: 100%;
    margin-bottom: 20px
}
.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th {
    padding: 8px 2px;
    line-height: 1.42857143;
    vertical-align: top;
    border-top: 1px solid #ddd
}
.table>thead>tr>th {
    vertical-align: bottom;
    border-bottom: 2px solid #ddd
}
.table>caption+thead>tr:first-child>td,.table>caption+thead>tr:first-child>th,.table>colgroup+thead>tr:first-child>td,.table>colgroup+thead>tr:first-child>th,.table>thead:first-child>tr:first-child>td,.table>thead:first-child>tr:first-child>th {
    border-top: 0
}
.table>tbody+tbody {
    border-top: 2px solid #ddd
}
.table .table {
    background-color: #fff
}
.table-condensed>tbody>tr>td,.table-condensed>tbody>tr>th,.table-condensed>tfoot>tr>td,.table-condensed>tfoot>tr>th,.table-condensed>thead>tr>td,.table-condensed>thead>tr>th {
    padding: 5px
}
.table-bordered {
    border: 1px solid #ddd
}
.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th {
    border: 1px solid #ddd
}
.table-bordered>thead>tr>td,.table-bordered>thead>tr>th {
    border-bottom-width: 2px
}
.table-striped>tbody>tr:nth-of-type(odd) {
    background-color: #f9f9f9
}
.table-hover>tbody>tr:hover {
    background-color: #f5f5f5
}
table col[class*=col-] {
    position: static;
    display: table-column;
    float: none
}
table td[class*=col-],table th[class*=col-] {
    position: static;
    display: table-cell;
    float: none
}
.table>tbody>tr.active>td,.table>tbody>tr.active>th,.table>tbody>tr>td.active,.table>tbody>tr>th.active,.table>tfoot>tr.active>td,.table>tfoot>tr.active>th,.table>tfoot>tr>td.active,.table>tfoot>tr>th.active,.table>thead>tr.active>td,.table>thead>tr.active>th,.table>thead>tr>td.active,.table>thead>tr>th.active {
    background-color: #f5f5f5
}
.table-hover>tbody>tr.active:hover>td,.table-hover>tbody>tr.active:hover>th,.table-hover>tbody>tr:hover>.active,.table-hover>tbody>tr>td.active:hover,.table-hover>tbody>tr>th.active:hover {
    background-color: #e8e8e8
}
.table>tbody>tr.success>td,.table>tbody>tr.success>th,.table>tbody>tr>td.success,.table>tbody>tr>th.success,.table>tfoot>tr.success>td,.table>tfoot>tr.success>th,.table>tfoot>tr>td.success,.table>tfoot>tr>th.success,.table>thead>tr.success>td,.table>thead>tr.success>th,.table>thead>tr>td.success,.table>thead>tr>th.success {
    background-color: #dff0d8
}
.table-hover>tbody>tr.success:hover>td,.table-hover>tbody>tr.success:hover>th,.table-hover>tbody>tr:hover>.success,.table-hover>tbody>tr>td.success:hover,.table-hover>tbody>tr>th.success:hover {
    background-color: #d0e9c6
}
.table>tbody>tr.info>td,.table>tbody>tr.info>th,.table>tbody>tr>td.info,.table>tbody>tr>th.info,.table>tfoot>tr.info>td,.table>tfoot>tr.info>th,.table>tfoot>tr>td.info,.table>tfoot>tr>th.info,.table>thead>tr.info>td,.table>thead>tr.info>th,.table>thead>tr>td.info,.table>thead>tr>th.info {
    background-color: #d9edf7
}
.table-hover>tbody>tr.info:hover>td,.table-hover>tbody>tr.info:hover>th,.table-hover>tbody>tr:hover>.info,.table-hover>tbody>tr>td.info:hover,.table-hover>tbody>tr>th.info:hover {
    background-color: #c4e3f3
}
.table>tbody>tr.warning>td,.table>tbody>tr.warning>th,.table>tbody>tr>td.warning,.table>tbody>tr>th.warning,.table>tfoot>tr.warning>td,.table>tfoot>tr.warning>th,.table>tfoot>tr>td.warning,.table>tfoot>tr>th.warning,.table>thead>tr.warning>td,.table>thead>tr.warning>th,.table>thead>tr>td.warning,.table>thead>tr>th.warning {
    background-color: #fcf8e3
}
.table-hover>tbody>tr.warning:hover>td,.table-hover>tbody>tr.warning:hover>th,.table-hover>tbody>tr:hover>.warning,.table-hover>tbody>tr>td.warning:hover,.table-hover>tbody>tr>th.warning:hover {
    background-color: #faf2cc
}
.table>tbody>tr.danger>td,.table>tbody>tr.danger>th,.table>tbody>tr>td.danger,.table>tbody>tr>th.danger,.table>tfoot>tr.danger>td,.table>tfoot>tr.danger>th,.table>tfoot>tr>td.danger,.table>tfoot>tr>th.danger,.table>thead>tr.danger>td,.table>thead>tr.danger>th,.table>thead>tr>td.danger,.table>thead>tr>th.danger {
    background-color: #f2dede
}
.table-hover>tbody>tr.danger:hover>td,.table-hover>tbody>tr.danger:hover>th,.table-hover>tbody>tr:hover>.danger,.table-hover>tbody>tr>td.danger:hover,.table-hover>tbody>tr>th.danger:hover {
    background-color: #ebcccc
}
.table-responsive {
    min-height: .01%;
    overflow-x: auto
}
@media screen and (max-width: 767px) {
    .table-responsive {
        width:100%;
        margin-bottom: 15px;
        overflow-y: hidden;
        -ms-overflow-style: -ms-autohiding-scrollbar;
        border: 1px solid #ddd
    }
    .table-responsive>.table {
        margin-bottom: 0
    }
    .table-responsive>.table>tbody>tr>td,.table-responsive>.table>tbody>tr>th,.table-responsive>.table>tfoot>tr>td,.table-responsive>.table>tfoot>tr>th,.table-responsive>.table>thead>tr>td,.table-responsive>.table>thead>tr>th {
        white-space: nowrap
    }
    .table-responsive>.table-bordered {
        border: 0
    }
    .table-responsive>.table-bordered>tbody>tr>td:first-child,.table-responsive>.table-bordered>tbody>tr>th:first-child,.table-responsive>.table-bordered>tfoot>tr>td:first-child,.table-responsive>.table-bordered>tfoot>tr>th:first-child,.table-responsive>.table-bordered>thead>tr>td:first-child,.table-responsive>.table-bordered>thead>tr>th:first-child {
        border-left: 0
    }
    .table-responsive>.table-bordered>tbody>tr>td:last-child,.table-responsive>.table-bordered>tbody>tr>th:last-child,.table-responsive>.table-bordered>tfoot>tr>td:last-child,.table-responsive>.table-bordered>tfoot>tr>th:last-child,.table-responsive>.table-bordered>thead>tr>td:last-child,.table-responsive>.table-bordered>thead>tr>th:last-child {
        border-right: 0
    }
    .table-responsive>.table-bordered>tbody>tr:last-child>td,.table-responsive>.table-bordered>tbody>tr:last-child>th,.table-responsive>.table-bordered>tfoot>tr:last-child>td,.table-responsive>.table-bordered>tfoot>tr:last-child>th {
        border-bottom: 0
    }
}
fieldset {
    min-width: 0;
    padding: 0;
    margin: 0;
    border: 0
}
legend {
    display: block;
    width: 100%;
    padding: 0;
    margin-bottom: 20px;
    font-size: 21px;
    line-height: inherit;
    color: #333;
    border: 0;
    border-bottom: 1px solid #e5e5e5
}
.ms-controller,.ms-important,[ms-controller],[ms-important]{
     visibility: hidden;
 }
 
.f-tac{	text-align:center;}
.f-tal{ text-align:left;}
.f-tar{ text-align:right;}
.f-w450{ width:450px;}
.f-m15{ margin:auto,auto;}
 
.split{
	background-color:#808080;
	height:30px;
	padding-top:20px;
	padding-bottom:12px;
}

+ 573 - 0
html/jkda/css/zx-style.css

@ -0,0 +1,573 @@
body { background: #f9f9f9; font-size: 16px; }
.c-btn-maincolor { background-color: #37a6ed; color: #fff; }/*蓝色按钮样式*/
.c-btn-maincolor:hover { background-color: #3099dd; }
.c-37a6ec { color: #37a6ec; }
.c-bfbfbf { color: #bfbfbf; }
.c-fa383d { color: #fa383d; }
.c-007dda { color: #007dda; }
.c-ff8011 { color: #ff8011; }
.c-087eff { color: #087eff; }
.c-ff8100 { color: #ff8100;}
.c-fff { color:#fff;}
.c-ccc { color: #ccc; }
.c-333 { color: #333; }
.c-btn-75BF00 {background-color: #75BF00;}
.bgc-00c1a5 { background-color: #00c1a5; }
.bgc-ebebeb { background-color: #ebebeb; }
.bgc-087eff { background-color: #087eff; }
.bgc-97caff { background-color: #97caff; }
.c-tag { color: #fff; font-size: 16px; padding: 2px 10px; border-radius: 4px; }
.c-tag-blue { background: #3da3ee; }
.line-22 { line-height: 22px; }
.line-40 { line-height: 40px; }
.mr40 { margin-right: 40px; }
.r-15 { right: 15px; }
.pt1 { padding-top:1px;}
.add-model .title-word-limit { position: absolute;right: 15px; top: 12px;}
.arrow-left { display: block;width: 8px;height: 8px;border: solid #fff;border-width: 0 0 2px 2px;-webkit-transform: rotate(45deg);-moz-transform: rotate(45deg);-ms-transform: rotate(45deg);-o-transform: rotate(45deg);transform: rotate(45deg);}
/* css3-Grid
-----------------------------------------------------------------------------*/
.ui-grid { display: -webkit-box; display: box; }
.ui-grid-middle { -webkit-box-pack: center; -webkit-box-align: center; box-pack: center; box-align: center; }
.ui-grid-vertical { -webkit-box-orient: vertical; box-orient: vertical; }
.ui-grid-label { -webkit-box-flex: 0; box-flex: 0; width: 100px; font-weight: 600; }
.ui-col-0 { -webkit-box-flex: 0; box-flex: 0; }
.ui-col-1 { -webkit-box-flex: 1; box-flex: 1; }
/*n-list*/
.ptb12 { padding-top: 12px; padding-bottom: 12px; }
.n-list { background-color: #fff; }
.n-list > li, .n-list > .n-list-li { position: relative; display: -webkit-box; display: box; box-pack: center; padding-right: 15px; margin-left: 15px; border-top: 1px solid #f1f1f1; clear: both; }
.n-list > li:first-child, .n-list > .n-list-li:first-child { border-top: none; }
.n-list > .n-list-link:active { background-color: #f7f7f7; padding-left: 15px; margin-left: 0 }
.n-list > .n-list-cover { padding-left: 15px; margin-left: 0; }
.n-list > .list-arrow-r, .n-list > .list-arrow-d, .n-list > .list-arrow-u { padding-right: 30px }
.n-list > .list-arrow-r:after, .n-list > .list-arrow-d:after, .n-list > .list-arrow-u:after { position: absolute; top: 50%; right: 15px; margin-top: -5px; content: ""; display: block; width: 8px; height: 8px; border: solid #cdcdcd; border-width: 2px 2px 0 0; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); -ms-transform: rotate(45deg); transform: rotate(45deg); }
.n-list > .list-arrow-d:after { right: 13px; margin-top: -8px; -webkit-transform: rotate(135deg); -moz-transform: rotate(135deg); -ms-transform: rotate(135deg); transform: rotate(135deg); }
.n-list > .list-arrow-u:after { right: 13px; margin-top: -2px; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); -ms-transform: rotate(-45deg); transform: rotate(-45deg); }
.n-list-title { display: -webkit-box; display: -moz-box; display: box; -webkit-box-orient: vertical; -moz-box-orient: vertical; box-orient: vertical; -webkit-box-pack: start; -moz-box-pack: start; box-pack: start; }
.n-list-key, .n-list-info { display: -webkit-box; display: -moz-box; display: box; -webkit-box-orient: vertical; -moz-box-orient: vertical; box-orient: vertical; -webkit-box-pack: center; -moz-box-pack: center; box-pack: center; }
.n-list-info { display: box; -webkit-box-flex: 1; -moz-box-flex: 1; box-flex: 1; }
.n-list-flex { display: -webkit-box; display: -moz-box; display: box; -webkit-box-flex: 1; -moz-box-flex: 1; box-flex: 1; }
.n-list > .n-list-function { border-top: none; padding-right: 0; }
.n-list > .n-list-function .n-list-flex { border-top: 1px solid #f1f1f1; }
.n-list > .n-list-function:first-child .n-list-flex { border-top: none; }
.n-list > li:first-child, .n-list > .n-list-function:first-child, .n-list > .n-list-function:first-child .n-list-info, .n-list > div:first-child { border: 0; }
.n-list > .n-list-label { display: block; border-top: none; padding-right: 0; }
.n-list .n-list-img { width: 100px; height: 68px; overflow: hidden; position: relative }
.n-list .n-list-img img { width: 100%; height: auto; }
.required { position: relative; }
.required:before { content: "*"; position: absolute; color: #f00; font-size: 14px; height: 12px; line-height: 12px; vertical-align: middle; left: -10px; top: 50%; margin-top: -5px; }
.n-avatar-s, .n-avatar-m, .n-avatar-l { width: 26px; height: 26px; display: -webkit-box; -webkit-box-pack: center; -webkit-box-align: center; }
.n-avatar-m { width: 40px; height: 40px; }
.n-avatar-l { width: 54px; height: 54px; }
.n-avatar-s img, .n-avatar-m img, .n-avatar-l img { width: 100%; height: 100%; }
.word-bread { word-wrap: break-word; }
/* 电话咨询 */
.doc-avatar { width: 50px; height: 50px; border-radius: 50%; text-align:center; overflow: hidden; }
.doc-avatar img { width: auto; height: 100%; }
.view-more { display: inline-block; width: 100%; text-align: center; padding: 15px 0; }
.doc-detail .list-arrow-d:after { top: 15px; margin-top: 0; }
.doc-detail .list-arrow-u:after { top: 20px; margin-top: 0; }
.level, .honor { display: inline-block; width: 20px; height: 20px; }
.level img, .honor img { width: 100%; height: 100%; }
/* 指定咨询 */
.upload-img { overflow: hidden; display: inline-block; }
.upload-img ul li { position: relative; display: inline; float: left; width: 76px; height: 76px; padding: 0 10px 10px 0; }
.upload-img ul li img { width: 100%; height: 100%; }
.upload-img .del-img { position: absolute; top: 0; right: 10px; text-align: center; width: 26px; height: 26px; line-height: 20px; z-index: 10; background: rgba(0,0,0,.5); border-radius: 0 0 0 90%; overflow: hidden; }
.upload-img .del-img .iconfont { color: #fff; font-size: 14px; line-height: 14px; margin-left: 4px; }
.add-btn { position: relative; display: block; width: 74px; height: 74px; font-size: 0; color: #b8b8b8; border: 1px dashed #a0a0a0; background: #fff; }
.add-btn:before { content: ""; display: block; position: absolute; top: 34px; left: 22px; width: 30px; height: 2px; background: #a0a0a0; }
.add-btn:after { content: ""; display: block; position: absolute; top: 20px; left: 36px; width: 2px; height: 30px; background: #a0a0a0; }
.doc-tab li { width: 50%; }
.doc-tab li.hit { border-bottom: 3px solid #4dcd70; }
.doc-tab li.hit a { color: #4dcd70; }
.doc-list-sm { padding: 10px 15px; }
.doc-list-sm span { color: #666; }
.doc-list-sm b { color: #333; font-weight: normal; }
.delimgpop { position: fixed; width: 100%; height: 100%; left: 0; top: 0; background: rgba(0,0,0,.8); text-align: center; z-index: 2200; }
.del-img-box { width: 100%; height: 100%; display: table; }
.del-img-con { display: table-cell; vertical-align: middle; }
.del-img-con img { width: auto; height: auto; border:2px solid #000; }
.del-img-con p { position: relative; display: inline-block !important; -webkit-animation: myfirst .3s ease; }
.del-img-box p:after { font-family: "iconfont" !important; content: "\d605"; position: absolute; display: block; top: 5px; right: 10px; width: 32px; height: 32px; z-index: 5000; color: #fff; font-size: 32px; font-style: normal; -webkit-font-smoothing: antialiased; -webkit-text-stroke-width: 0.2px; -moz-osx-font-smoothing: grayscale; -webkit-text-shadow:0 0 1px #f00;text-shadow:0 0 1px #000;  }
.del-img-btn { display: inline-block; height: 40px; line-height: 40px; position: absolute; top: 0; right: 0; z-index: 20; padding: 0 15px; text-align: right; color: #000; }
.del-img-btn .iconfont { font-size: 20px; margin-right: 4px; }
.r-input { width: 100%; text-align: right; }
.r-textarea { width: 100%; border: 0; padding: 0; resize: none; }
.over-lay, .over-lay[id] { position: fixed; top: 0; left: 0; z-index: 3000; width: 100%; height: 100%; background: rgba(0,0,0,.7); }
.ins-img-btn { position: fixed; width: 100%; bottom: 0; left: 0; z-index: 3100; }
.ins-img-btn .c-btn { border-radius: 4px; border: none; color: #157efb; font-size: 20px; }
.ins-img-btn .c-btn:first-child { border-radius: 4px 4px 0 0; }
.ins-img-btn .c-btn:nth-child(2) { border-top: 1px solid #e1e1e1; border-radius: 0 0 4px 4px; }
.zx-notes { text-align: left; color: #5b5b5b; font-size: 12px; }
.ui-popup .zx-notes li { padding: 0 !important; margin: 0 !important; }
/* 咨询信息 */
.talk-box { position: relative; width: 100%; padding: 10px; background: #fff; border-radius: 5px; border: 1px solid #e6bc5d; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
.talk-box:after { position: absolute; content: ""; top: -6px; left: 30px; font-size: 13px; color: #5b5b5b; width: 10px; height: 10px; border: 1px solid #e6bc5d; border-width: 1px 1px 0 0; background: #fff; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); -ms-transform: rotate(-45deg); -o-transform: rotate(-45deg); transform: rotate(-45deg); }
.icon-round { display: inline-block; width: 24px; height: 24px; text-align: center; line-height: 24px; vertical-align: middle; color: #fff; font-size: 14px; border-radius: 50%; overflow: hidden; }
.upload-img ul li.upload-btn-box { width: 240px; height: 76px; }
.upload-img ul li.upload-btn-box p { width: 150px; font-size: 13px; color: #5b5b5b; display: block; padding: 18px 0 0 10px; }
.pingjia { font-size: 13px; color: #ff8100; }
.pingjia .iconfont { font-size: 20px; line-height: 20px; color: #ff8100; }
.bottom-iconbtn { position: fixed; bottom: 0; left: 0; width: 100%; height: 44px; border-top: 1px solid #e1e1e1; background: #fff; z-index: 1000; }
.bottom-iconbtn a { display: inline-block; width: 49%; height: 44px; line-height: 44px; text-align: center; vertical-align: middle; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; border-right: 1px solid #e1e1e1; overflow: hidden; }
.bottom-iconbtn a:last-child { border: none; }
.bottom-iconbtn a .iconfont { font-size: 18px; line-height: 18px; vertical-align: middle; }
.sel-phiz { overflow: hidden; }
.sel-phiz li { width: 33.33%; float: left; text-align: center; color: #333; font-size: 15px; }
.sel-phiz li .iconfont { font-size: 40px; line-height: 40px; color: #ccc; }
.sel-phiz li p { line-height:1.1;}
.padding-fixed { width: 100%; height: 70px; }
.tel-zx-list>li .n-list-key{ min-width:6em;}
.sel-phiz li i{ display:inline-block; background:url(../images/sel-phiztb.png) no-repeat; background-size:126px 92px;}
.sel-phiz li i.icon-flower{ width:42px; height:46px; background-position:0 0;}
.sel-phiz li i.icon-flag{ width:44px; height:46px; background-position:-42px 0;}
.sel-phiz li i.icon-gife{ width:39px; height:46px; background-position:-87px 0;}
.sel-phiz li.selected i.icon-flower{ background-position:0 -46px;}
.sel-phiz li.selected i.icon-flag{ background-position:-42px -46px;}
.sel-phiz li.selected i.icon-gife{ background-position:-87px -46px;}
/*爱心咨询*/
.common-title { font-size: 12px; padding: 10px 15px; color: #5b5b5b; }
.ax-consultation li { position: relative; }
.ax-consultation select, .ax-consultation input { color: #909090 !important; }
.ax-consultation li input.short { border: 1px solid #000; width: 50%; box-sizing: border-box; }
.ax-consultation li .input-group .form-select { height: 30px; box-sizing: border-box; padding: 2px 13px 2px 5px; }
.ax-consultation li .form-select-arrow { top: 9px; right: 7px; }
.ax-consultation li .c-list-value h4{ min-width:4em;}
.ax-consultation li .input-group { position: relative; }
.arrow-down { display: block; width: 8px; height: 8px; border: solid #cdcdcd; border-width: 2px 2px 0 0; -webkit-transform: rotate(135deg); -moz-transform: rotate(135deg); -ms-transform: rotate(135deg); -o-transform: rotate(135deg); transform: rotate(135deg); }
.ax-consultation li .list-icon { position: absolute; right: 15px; top: 50%; margin-top: -4px; }
.ax-consultation li .input-group .list-icon { position: absolute; right: 10px; top: 50%; margin-top: -4px; }
.pl40 { padding-left: 40px; }
.ml40 { margin-left: 40px; }
.ax-consultation li .input-group-addon { padding: 0 10px; }
.pm_age { display: inline-block; width: 138px; height: 30px; border: 1px solid #ddd; border-radius: 5px; -webkit-border-radius: 5px; vertical-align: middle; overflow: hidden; position: relative; }
.ageinput { width: 65px; height: 30px; line-height: 30px; background: #fff; border: none; float: left; font-size: 15px; color: #333; border-right: 1px solid #ddd; padding-left: 10px; border-radius:5px 0 0 5px; }
.pm_age .agesel { width: 60px; height: 30px; line-height: 30px; float: left; font-size: 15px; color: #808080; border: none; -webkit-appearance: none; -moz-appearance: none; appearance: none; font-family: "\5FAE\8F6F\96C5\9ED1", Helvetica; background: url(/images/point_d.png) 94% center no-repeat #fff; background-size: 13px 8px; -webkit-background-size: 13px 8px; padding: 0 0 0 10px; }
.pt2 { padding-top: 2px; }
/*问医生*/
.bg-9dcd82 { background: #9dcd82; }
.bg-ff7aac { background: #ff7aac; }
.bg-8ebcf8 { background: #8ebcf8; }
.bg-ffbc16 { background: #ffbc16; }
.ask-doctors-boxer .c-avatar-m i { width: 40px; height: 40px; border-radius: 40px; text-align: center; line-height: 40px; display: block; color: #fff; font-size: 24px; }
.ask-doctors-boxer .tiper-words { width: 100%; box-sizing: border-box; }
.ask-doctors-boxer .tiper-words img { width: 100%; }
/*专家列表*/
.professor-listhead { height: 45px; background: #fff; width: 100%; z-index: 99;position:fixed;bottom:0;left:0; }
.professor-listhead li { float: left; line-height: 45px; box-sizing: border-box; border-right: 1px solid #f2f2f2; text-align: center; color: #5b5b5b; font-size: 14px; height: 45px; }
.professor-listhead li span { text-overflow: ellipsis; overflow: hidden; height: 45px; line-height: 45px; white-space: nowrap; max-width: 80%; display: inline-block; position: relative; padding: 0 15px 0 0; box-sizing: border-box; }
.professor-listhead li:last-child { border: none; }
.professor-listhead li em.cur { color: #37a6eb; }
.professor-listhead li i { display: block; position: absolute; top: 20px; right: 0; }
.professor-listhead li.cur i.s-arrow-down { width: 0; height: 0; border-left: 5px solid transparent; border-right: 5px solid transparent; border-bottom: 5px solid #b4b4b4; border-top: 0; }
.s-arrow-down { width: 0; height: 0;  border-left: 5px solid transparent; border-right: 5px solid transparent; border-bottom: 5px solid #b4b4b4; border-top: 0;}
.professor-main .c-avatar-m { padding: 6px 0 6px; }
.professor-main .c-avatar-m img { border-radius: 40px; overflow: hidden; width: 40px; height: 40px; }
.professor-main .c-list-indent-s { padding-right: 15px !important; }
.pt35 { padding-top: 35px; }
.c-ff8100 { color: #ff8100; }
.professor-main .c-5b5b5b { color: #5b5b5b !important; }
.list-addmore { color: #007cd9; font-size: 13px; width: 100%; text-align: center; line-height: 34px; }
.professor-main .c-list-info { padding: 6px 0 6px; }
.professor-main li { padding-left: 15px !important; margin-left: 0 !important; }
/*专家列表iscroll*/
.shadow-panel { position: fixed; top: 0; left: 0; bottom: 45px; width: 100%; z-index: 90; background-color: rgba(0,0,0,.35); }
.scroll-fixed { position: fixed; bottom: 45px; left: 0; z-index: 98;}
.scroll-citybox, .scroll-hospbox { width: 100%; height: 352px; overflow: hidden; }
.scroll-specbox{ width: 100%; height: 352px; overflow: hidden; }
.scroll-citybox li, .scroll-hospbox li { text-overflow: ellipsis; white-space: nowrap; overflow: hidden; }
.city-box-leftwrapper { width: 40%; background: #f5f5f5; }
.city-box-rightwrapper { width: 60%; background: #ffffff; }
.hosp-box-leftwrapper { width: 50%; background: #f5f5f5; }
.hosp-box-rightwrapper { width: 50%; background: #ffffff; }
.spec-box-leftwrapper { width: 100%; background: #ffffff; font-size:14px; }
.cc-lef li { padding: 11px 20px; color: #5b5b5b; font-size: 14px; border-right: 1px solid #e1e1e1; border-bottom: 1px solid #e1e1e1; width: 100%; box-sizing: border-box; }
.cc-lef li:last-child { border-bottom: none; }
.cc-lef li span { display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; white-space: normal; overflow: hidden; }
.cc-rig li { margin-left: 15px; border-bottom: 1px solid #e1e1e1; height: 43px; line-height: 43px; color: #5b5b5b; font-size: 14px; }
.cc-rig li:last-child { border-bottom: none; }
.cc-lef li.cur { background: #fff; border-right: 1px solid #fff; }
.cc-rig li.cur { color: #37a6eb; }
.city-box-leftwrapper, .city-box-rightwrapper, .hosp-box-leftwrapper, .hosp-box-rightwrapper, .spec-box-leftwrapper { float: left; position: relative; height: 352px; overflow: hidden; /* Prevent native touch events on Windows */
-ms-touch-action: none; /* Prevent the callout on tap-hold and text selection */
-webkit-touch-callout: none; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; /* Prevent text resize on orientation change, useful for web-apps */
-webkit-text-size-adjust: none; -moz-text-size-adjust: none; -ms-text-size-adjust: none; -o-text-size-adjust: none; text-size-adjust: none; }
.city-leftscroller, .city-rightscroller, .hosp-leftscroller, .hosp-rightscroller, .spec-leftscroller { position: absolute; width: 100%; /* Prevent elements to be highlighted on tap */
-webkit-tap-highlight-color: rgba(0,0,0,0); /* Put the scroller into the HW Compositing layer right from the start */
-webkit-transform: translateZ(0); -moz-transform: translateZ(0); -ms-transform: translateZ(0); -o-transform: translateZ(0); transform: translateZ(0); }
.shadow-panel { display: none; }
.spec-leftscroller div.c-33 { color: #5b5b5b; float: left; box-sizing: border-box; border-right: 1px solid #e1e1e1; border-bottom: 1px solid #e1e1e1; text-align: center; text-overflow: ellipsis; white-space: nowrap; overflow: hidden; height: 36px; line-height: 36px;font-size:14px;}
.spec-leftscroller div.c-33.cur { color: #37a6eb; }
.main-scrollboxer{-webkit-overflow-scrolling:touch;}
/*医生列表搜索无数据*/
.search-nodata { width: 100%; font-size: 16px; color: #5b5b5b; text-align: center; padding: 100px 0 40px 0; }
.search-nodata-img { width: 40%; max-width: 320px; margin: 0 auto; }
.search-nodata-icon { background: url(../images/no-data.png) no-repeat 100% 0; width: 100%; height: 0; padding-bottom: 100%; background-size: 100% auto; }
/*网络咨询详情页*/
.c-avatar-m { width: 40px; height: 40px; border-radius: 50%; overflow: hidden; }
.doctor_detail_intro { font-size: 15px; background: #fff; margin-top: 20px; }
.doctor_detail_intro .tit { color: #909090; display: inline-block; float: left; width: 75px; }
.doctor_detail_intro .tit2 { color: #909090; display: inline-block; float: left; width: auto; }
.doctor_detail_intro .words { -webkit-box-flex: 1; box-flex: 1; display: box; display: -webkit-box; -webkit-box-orient: vertical; -webkit-box-pack: center; padding-right: 15px; box-sizing: border-box; color: #333; overflow: hidden; }
.doctor_detail_intro .main_good_at, .doctor_detail_intro .main_intro { margin-left: 15px; padding: 15px 0 }
.report-img, .report-img img { width: 70px; height: 70px; float: left; margin-right: 10px; }
.time-title { width: 22px; height: 22px; border-radius: 50%; line-height: 20px; text-align: center; display: inline-block; background-color: #4dcd70 }
.time-title i, iconfont { font-size: 13px; }
.review { width: 100%; margin-top: 10px; }
.review .hd { height: 5px; position: relative; }
.review .hd .ui-arrow { position: absolute; top: -5px; left: 10px; border-bottom-color: #ff8100; }
.review .hd .ui-arrow s { top: -4px; }
.review .bd { border: 1px solid #ff8100; padding: 10px; -webkit-border-radius: 5px; -moz-border-radius: 5px; border-radius: 5px; }
/*电话咨询记录*/
.doctor_detail_intro .record-tit { color: #909090; display: inline-block; float: left; width: 85px; }
.no-record { text-align: center; line-height: 23px; padding: 0 15px; }
.icon-record { display: inline-block; width: 125px; height: 125px; background: url(../images/no-data.png) no-repeat; background-size: 100% 100%; -webkit-background-size: 100% 100%; -moz-background-size: 100% 100%; -ms-background-size: 100% 100%; margin: 60px 0 5px 0; }
/*电话咨询-登记成功*/
.win-register { text-align: center; }
.win-register i, iconfont { font-size: 60px; }
.b-height { height: 80px; }
.s-height { height: 40px; line-height: 40px; text-align: center }
.c-49 { width: 49% }
/*确认就诊人信息*/
.demo-input-merge .input-group-addon { min-width: 90px; width: 90px; text-align: left; }
.l-span { top: 17px; left: 0px; position: absolute; color: #f00 }
.words-box { padding-top: 8px; border-top: 1px solid #e1e1e1 ;}
.words-box .form-textarea2 { height: 100px; border: 0px; resize: none }
.input-merge .input-group.input-border .input-group-addon, .input-merge .input-group.input-border .form-control, .input-merge .input-group.input-border .form-select, .input-merge .input-group.input-border .form-textarea, .input-merge .input-group.input-border .form-control, .input-merge .input-group.input-border .form-select, .input-merge .input-group.input-border .form-textarea, .input-merge .input-group.input-border .input-group-addon { border-radius: 0px; }
.input-merge .input-group.input-border { padding-left: 15px; }
.input-merge .input-group.input-border .input-group-addon { padding-left: 0 }
.t-14 { top: 14px; }
.t-12 { top: 12px; position: absolute; color: #ff8100; }
.words-box .form-textarea2::-webkit-input-placeholder, .words-box .r-textarea::-webkit-input-placeholder {
color: #bfbfbf;
}
.words-box .form-textarea2:-moz-placeholder,.words-box .r-textarea:-moz-input-placeholder  {
color: #bfbfbf;
}
.words-box .form-textarea2:-ms-input-placeholder, .words-box .r-textarea:-ms-input-placeholder {
color: #bfbfbf;
}
.number-r-b { right: 15px; bottom: -15px; position: absolute; }
/*网络咨询*/
.hz-header { height: 45px; background: #fff; }
.hz-header li { font-size: 13px; color: #5b5b5b; }
.hz-header li.cur { border-bottom: 2px solid #37a6ed; }
.hz-header li.cur span { color: #007cd9; }
.hz-header li span { margin: 12px 0; border-right: 1px solid #e1e1e1; text-align: center; display: block; box-sizing: border-box; }
.visit-list { }
.visit-list li { border-top: 1px solid #e1e1e1; border-bottom: 1px solid #e1e1e1; background: #fff; padding-left: 15px; margin-top: 15px; }
.visit-list li .vlname { line-height: 45px; border-bottom: 1px solid #f2f2f2; position: relative; padding-right: 15px; }
.visit-list li .vlname .arrow-right { position: absolute; right: 15px; top: 50%; margin-top: -4px; }
.visit-list li .vlcard { line-height: 40px; color: #bfbfbf; padding-right: 15px; }
.c-btn-r, .c-btn-full-r { display: inline-block; zoom: 1; *display:inline;
vertical-align: baseline; outline: none; cursor: pointer; border: 0; background: none; text-align: center; text-decoration: none; padding: 5px 10px; color: #fff; position: relative; font: 14px/1 \5FAE\8F6F\96C5\9ED1, tahoma, arial, \5b8b\4f53; line-height: normal !important; background-color: #37a6ec; border-radius: 4px; }
.r-w100 { width: 100px; text-align: right;}
.bgc-fffae8{background:#fffae8;}
.pb3{ padding-bottom:3px;}
.pb2{ padding-bottom:2px;}
.c-ser-btn a{ height:28px; line-height:28px; border:1px solid #e8e8e8;}
.c-avatar-s img, .c-avatar-m img, .c-avatar-l img { width: 100%; height: auto; }
.test-boxer .c-avatar-m{ text-align:center; padding:0;}
.test-boxer .c-avatar-m img{ width:auto; height:100%; border-radius:0;}
/*2015.11.9*/
.scroll-include{height:260px;overflow:hidden;}
@media (device-height:480px) and (-webkit-min-device-pixel-ratio:2){/* 兼容iphone4/4s */
	.scroll-include{height:200px;}
}
/*2015.11.18*/
.c-nowrap.c-f16{font-size:16px !important;}
/*2.12专家列表*/
.c-ser-main i.left-42{left:42%;}
.professor-listhead.professor-list-listhead{ }
.professor-list-btn { height: 28px;line-height: 28px;border-radius: 4px;padding: 5px 10px;margin-left: 10px;}
/*2.12编辑模板*/
.list-arrow-r.ml0 { margin-left:0;}
/*2.12回复模块*/
.icon-look { background:url(../images/icon-look.png) no-repeat 0 0;background-size:100%;width:22px;height:23px;display:block;margin:10px auto 0;}
.talk-box.reply-talk-box { padding:0;border-color:#e1e1e1;}
.talk-box.reply-talk-box:after { border-color:#e1e1e1;left:15px;}
.talk-box.reply-talk-box.right:after { right:15px;left:auto;}
.reply-talk-box.n-list>li { padding-left:15px;margin-left:0;border-top:0;}
.reply-talk-box .look-report li { float:left;width:57px;text-align:center;}
.reply-talk-box .look-report li div { height:56px;border:1px solid #e3e3e3;}
.icon-homan { display:block;background:#e1e1e1 url(../images/icon-homan.png) no-repeat 50% 50%;width:40px;height:40px;border-radius:50%;background-size:50%;}
.btn-voice { background:url(../images/btn-voice.jpg) no-repeat 0 0;background-size:100%;width:85px;height:34px;display:block;}
.icon-reply { width:15px;height:15px;display:block;background:url(../images/icon-reply.jpg) no-repeat 0 0;background-size:100%;}
.icon-broadcast {background:url(../images/icon-broadcast.png) no-repeat 0 0;background-size:100%;width:12px;height:16px;}
.icon-border { width:1px;height:14px;margin:5px 12px 0;background-color: #ddd;}
.reply-title {position:relative;background:#97caff;color:#fff;font-size: 14px;padding:10px 0;padding-left:25px;}
.reply-title:after { position: absolute;top: 50%;left: 15px;margin-top: -5px;content: "";display: block;width: 8px;height: 8px;border:1px solid #fff;border-width: 0 0 2px 2px;-webkit-transform: rotate(45deg);-moz-transform: rotate(45deg);-ms-transform: rotate(45deg);transform: rotate(45deg);}
.c-tag-blue.c-f13{ font-size: 13px;}
/*2.12关注*/
.heed { background:url(../images/heed.png) no-repeat 0 0;background-size:100%;width:26px;height:26px;display:block;margin:0 auto 5px;}
.heed-orange { background:url(../images/heed-orange.png) no-repeat 0 0;background-size:100%;width:26px;height:26px;display:block;margin:0 auto 5px;}
#heed,#heed-orange { width:40px;text-align: center;padding-top:12px;}
.pm_age .agesel.w-70 { width:70px;}
/*2.12回复录音*/
.win-broadcast { position:fixed;outline: 0px;top:50%;left:50%;margin:-113px 0 0 -135px;width:269px;height:226px;border-radius: 5px;z-index:100;}
.win-broadcast .bg { background-color: #fff;width:269px;height:226px;border-radius: 5px;display:block;}
.win-broadcast .broadcast { background:url(../images/broadcast.png) no-repeat 0 -2px;width:85px;height:85px;display:block;background-size: 100%; position:absolute;top:67px;left:34%;border-radius: 50%;z-index:99;}
.win-broadcast .word { position: absolute;bottom: 0;border-radius: 5px;border-top: 1px solid #e1e1e1;border-top-right-radius: 0;border-top-left-radius: 0;color: #666;background-color: #fff;height: 35px;width: 100%;line-height: 35px;}
.win-broadcast .word.title { top:0;border-top-left-radius:5px;border-top-right-radius:5px;}
.delete {display: block;position: absolute;height: 12px;width: 12px;border-radius: 50%;background-color: #fff;right: 6px;top: 6px;z-index: 10;text-align: center;line-height: 9px;color: #919191;font-size: 12px;}
.broadcast-shadow-panel {width:100%;position:absolute;overflow:hidden;z-index:10;top:0;background-color: rgba(0,0,0,.35);}
/*动画*/
.win-broadcast .broadcast
{
    animation: broadcast 2s infinite;
    -webkit-animation: broadcast 2s infinite;  /* Safari 和 Chrome */
}
@-webkit-keyframes broadcast /* Safari 和 Chrome */
{
    0%   { background-color:#ccf5ff;box-shadow: 0 0 0  0px #ccf5ff,0 0 0 0 #c3e9f2, 0 0 0  0px #e9fffe,0 0 0 0 #ddf5f4;}
    25%  { background-color:#ccf5ff;box-shadow: 0 0 0 5px #ccf5ff,0 0 0 1px #c3e9f2, 0 0 0 20px #e9fffe,0 0 0 1px #ddf5f4;}
    50%  { background-color:#ccf5ff;box-shadow: 0 0 0 10px #ccf5ff,0 0 0 1px #c3e9f2, 0 0 0 25px #e9fffe,0 0 0 1px #ddf5f4;}
    100% { background-color:#ccf5ff;box-shadow: 0 0 0 15px #ccf5ff,0 0 0 1px #c3e9f2, 0 0 0 30px #e9fffe,0 0 0 1px #ddf5f4;}
}
/* 12-18 */
.nxz-voice{ line-height:21px; text-align:right;}
.nzx-tb{ display:inline-block; width:15px; height:21px; background:url(../images/icon-broadcast.png) no-repeat; background-size:100% auto; -webkit-background-size:100% auto; -moz-background-size:100% auto; -ms-background-size:100% auto; vertical-align:middle;}
.win-broadcast-mb{ width:100%; height:100%; position:fixed; left:0; top:0; z-index:10; background:rgba(0,0,0,.35); display:none;}
.myorder li .vlname { line-height: 20px; border-bottom: 1px solid #f2f2f2; position: relative; padding-right: 15px; padding-top:10px; padding-bottom:10px;}
/* 1-12 */
.myaks-top{}
.myaks-top li{ background:#fff; border-top:1px solid #e1e1e1; border-bottom:1px solid #e1e1e1; margin-top:10px;}
.myaks-top li:first-child{ margin-top:0;}
.mt-mess{ margin-left:10px; padding:10px 0;}
.mt-con{ margin-left:10px; padding:10px 10px 10px 0; border-top:1px solid #f2f2f2;}
.mtime{ line-height:25px;}
.mtime em{ display:inline-block; width:14px; height:14px; background:url(../images/sex.png) no-repeat; background-size:29px 14px; vertical-align:middle; margin:0 5px 5px 0;}
.mtime em.sex-male{ background-position:0 0;}
.mtime em.sex-female{ background-position:-15px 0;}
.msympt{ position:relative; padding-left:40px; min-height:20px;}
.msympt h4{ display:block; position:absolute; left:0; top:0; color:#909090;}
.mt-state{ line-height:40px; text-align:center; border-top:1px solid #f2f2f2; color:#17b3ec;}
.mreport-list .c-list-link .c-list-value{ padding-right:0;}
.h35{ height:35px;}
.myask-lab{ width:100%; height:35px; background:#fff;}
.myask-lab li{ display:block; width:33.33%; float:left; font-size:13px; color:#5b5b5b; line-height:34px; text-align:center; position:relative; z-index:600;}
.labfixed{ position:fixed; left:0; top:0; z-index:600;}
.myask-lab li.curr{ border-bottom:2px solid #17b3ec; color:#17b3ec;}
.myask-lab:before{ content:''; display:block; width:33.33%; height:22px; position:absolute; left:33.33%; top:6px; border-left:1px solid #f2f2f2; border-right:1px solid #f2f2f2; z-index:500;}
.myask-visit li{ margin-top:10px;}
.myask-visit li:first-child{ margin-top:0;}
/* 再次咨询弹窗 */
.botpop{ position:fixed; left:0; bottom:0; width:100%; z-index:700; -webkit-animation:choopop .2s ease; animation:choopop .2s ease; display:none;}
@-webkit-keyframes choopop{
	0%{ bottom:-200px;}
	100%{ bottom:0px;}
}
@keyframes choopop{
	0%{ bottom:-200px;}
	100%{ bottom:0px;}
}
.botpop li{ line-height:50px; background:#fff; border-top:1px solid #f2f2f2; padding:0 15px;}
.botpop li.curr{ color:#17b3ec;}
.botpopmb{ width:100%; height:100%; background:rgba(0,0,0,.4); position:fixed; left:0; top:0; z-index:650; display:none;}
/* index */
.bgc-f3f3f3{ background-color:#f3f3f3;}
.bor-f2-r{ border-right:1px solid #f2f2f2;}
.bor-f2-b{ border-bottom:1px solid #f2f2f2;}
.bor-f2-tb{ border-top:1px solid #f2f2f2; border-bottom:1px solid #f2f2f2;}
.lih43{ line-height:43px;}
.icon-mindex{ display:inline-block; background:url(../images/icon-mindex.png) no-repeat; background-size:250px 250px; vertical-align:text-top;}
.icon-mpart1{ width:91px; height:100px; background-position:0 0; margin-bottom:5px;}
.icon-mpart2{ width:49px; height:40px; background-position:-95px 0; margin-top:-21px;}
.icon-mpart3{ width:40px; height:39px; background-position:-150px 0; margin-bottom:2px;}
.icon-mpart4{ width:41px; height:39px; background-position:-195px 0; margin-bottom:2px;}
.icon-mpart5{ width:45px; height:35px; background-position:-95px -41px; margin-top:-21px; margin-left:4px;}
.icon-msearch{ width:15px; height:15px; background-position:0 -155px; margin:1px 5px 0 0;}
.mindex-search{ width:100%; padding:8px 7px; background-color:#fff;}
.mindex-search div{ height:27px; line-height:27px; background-color:#f2f2f2; border-radius:3px;}
.mindex-search div{ position:relative; padding:0 10px 0 30px;}
.mindex-search .icon-msearch{ position:absolute; left:8px; top:5px;}
.mindex-search .search-text{ display:block; width:100%; height:100%; background-color:#f2f2f2; appearance:none; -webkit-appearance:none; border-radius:3px;}
.mindex-top{ background:#fff; line-height:20px; height:187px;}
.mt-center{ display:box; display:-webkit-box; -webkit-box-orient:vertical; -webkit-box-pack:center; text-align:center;}
.mt-part1-1{ width:47%; height:100%; float:left;}
.mt-part1-2{ width:53%; height:100%; float:left;}
.mt-part2{ width:100%; height:50%;}
.mt-part3{ width:50%; height:100%; float:left;}
.mt-freeask{ display:inline-block;}
.mindex-img{ position:relative;}
.mindex-img .bd li{ display:block; width:100%; height:61px;}
.mindex-img .bd li img{ width:100%; height:100%;}
.mindex-img .hd{ position:absolute; height:7px; line-height:7px; bottom:5px; left:50%; font-size:1px; transform:translateX(-50%); -webkit-transform:translateX(-50%); -moz-transform:translateX(-50%); -ms-transform:translateX(-50%);}
.mindex-img .hd li{ display:inline-block; width:7px; height:7px; line-height:7px; background:#cacaca; border-radius:50%; margin:0 5px; font-size:0px; overflow:hidden; color:#cacaca;}
.mindex-img .hd li.on{ background:#17b3ec; color:#17b3ec;}
.mindex-list{ background-color:#fff;}
.mindex-list li{ display:block; width:25%; height:80px; float:left; box-sizing:border-box; -webkit-box-sizing:border-box; -moz-box-sizing:border-box; -ms-box-sizing:border-box; display:box; display:-webkit-box; -webkit-box-orient:vertical; -webkit-box-pack:center; text-align:center; border-right:1px solid #f2f2f2; border-top:1px solid #f2f2f2; color:#909090;}
.mindex-list li:nth-child(4n){ border-right:0;}
.mindex-list li i{ width:25px; height:25px;}
.icon-mlist3{ background-position:0 -105px;}
.icon-mlist4{ background-position:-25px -105px;}
.icon-mlist5{ background-position:-50px -105px;}
.icon-mlist80{ background-position:-75px -105px;}
.icon-mlist10{ background-position:-100px -105px;}
.icon-mlist11{ background-position:-125px -105px;}
.icon-mlist12{ background-position:-150px -105px;}
.icon-mlist19{ background-position:-175px -105px;}
.icon-mlist13{ background-position:-200px -105px;}
.icon-mlist50{ background-position:-225px -105px;}
.icon-mlist16{ background-position:0 -130px;}
.icon-mlist54{ background-position:-25px -130px;}
.icon-mlist27{ background-position:-50px -130px;}
.icon-mlist14{ background-position:-75px -130px;}
.icon-mlist21{ background-position:-100px -130px;}
.icon-mlist52{ background-position:-125px -130px;}
.icon-mlist15{ background-position:-150px -130px;}
.icon-mlist81{ background-position:-175px -130px;}
.icon-mlist78{ background-position:-200px -130px;}
.mindex-recom{ background-color:#fff; padding:10px;}
.mindex-recom .mrtit{ line-height:23px;}
.mindex-recom ul{ display:block;}
.mindex-recom li{ display:block; width:25%; float:left; text-align:center; box-sizing:border-box; -webkit-box-sizing:border-box; -moz-box-sizing:border-box; -ms-box-sizing:border-box; padding:0 2px; margin-top:10px; line-height:1.4;}
.mindex-recom li img{ width:40px; height:40px; border-radius:50%; margin-bottom:2px;}
/*2.15专家列表*/
.cc-lef li.cur span{padding-left:15px;background:url(../images/cs-jtright.png) no-repeat left center;}
.spec-box-leftwrapper .c-100{text-align:center;padding:15px 15px;color:#5b5b5b;font-size:14px;border-bottom:1px solid #e1e1e1;box-sizing:border-box;}
.spec-box-leftwrapper .c-100.cur{color:#37a6eb;}
.scroll-itemchoscbox {width: 100%; height:302px; overflow: hidden;background:#fff;font-size:14px;}
.itemchos-box-leftwrapper{position: relative; height: 302px; overflow: hidden; /* Prevent native touch events on Windows */
-ms-touch-action: none; /* Prevent the callout on tap-hold and text selection */
-webkit-touch-callout: none; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; /* Prevent text resize on orientation change, useful for web-apps */
-webkit-text-size-adjust: none; -moz-text-size-adjust: none; -ms-text-size-adjust: none; -o-text-size-adjust: none; text-size-adjust: none; }
.itemchos-leftscroller{ position: absolute; width: 100%; /* Prevent elements to be highlighted on tap */
-webkit-tap-highlight-color: rgba(0,0,0,0); /* Put the scroller into the HW Compositing layer right from the start */
-webkit-transform: translateZ(0); -moz-transform: translateZ(0); -ms-transform: translateZ(0); -o-transform: translateZ(0); transform: translateZ(0); }
.itemch-tit h2{line-height:28px;}
.itemchos-leftscroller .disp-tit-box{color:#5b5b5b;}
.itemchos-leftscroller .disp-tit-box em{color:#37a6ec;}
.itemchos-leftscroller .disp-mainbox{padding:15px 0 10px;}
.itemchos-leftscroller .disp-sloer .c-33{border-radius:3px;text-align:center;background:#f2f2f2;color:#333333;padding:3px 0;margin-bottom:15px;}
.itemchos-leftscroller .disp-sloer .c-33.cur{background:#37a6ec;color:#fff;}
.disp-sloer .c-row .c-33:last-child{margin-left:0;}
.disp-sloer .c-row .c-33.tipsl{margin-right:3%;}
.c-ffa800{color:#ffa800;}
.itemch-tit .c-btn-tiny{width:65px;}
.c-lab-mor li.doctor a{border-left:1px solid #f2f2f2;}
.test-boxer.second .c-avatar-m img{border-radius:100%;}
.second .cc-lef li.cur span{background:none;}
/* 绿色风格皮肤样式  */
/*green*/
.wdz-green .c-btn-maincolor { background: #4dcd70; }/*微导诊按钮绿色*/
.wdz-green .c-btn-maincolor:hover { background-color: #4dc86f; }
.wdz-green .c-btn-wordcolor { color: #4dcd70; }/*微导诊文字绿色*/
.wdz-green .professor-listhead li em.cur { color: #4dcd70; }
.wdz-green .cc-rig li.cur { color: #4dcd70; }/*专家列表按城市文字绿色*/
.wdz-green .spec-leftscroller div.c-33.cur { color: #4dcd70; }/*专家列表按专科文字绿色*/
.wdz-green .c-37a6ed, .wdz-green c-007cd9{ color: #4dcd70; }
.wdz-green .c-lab-les {border: 1px solid #4dc86f; }
.wdz-green .c-lab-les li { border-left: 1px solid #4dc86f; }
.wdz-green .c-lab-les li a { color: #4dc86f; }
.wdz-green .c-lab-les li.hit { background-color: #4dc86f; }
.wdz-green .c-lab-les li.hit a { color: #fff; }
.wdz-green .c-lab-mor li.hit { border-bottom: 3px solid #4dc86f; }
.wdz-green .c-lab-mor li.hit a { color: #4dc86f; }
.wdz-green .hz-header li.cur { border-bottom: 2px solid #4dc86f; }
.wdz-green .hz-header li.cur span { color: #4dc86f; }
.wdz-green .c-ser-btn a{background:#4dc86f;}
.wdz-green .view-more a{color:#4dc86f;}
.wdz-green .c-4dc86f{color:#4dc86f;}
.wdz-green .spec-box-leftwrapper .c-100.cur{color:#4dc86f;}
.wdz-green .scroll-itemchoscbox .c-btn-37a6ec{background: #4dcd70;}
.wdz-green .itemchos-leftscroller .disp-sloer .c-33.cur{background: #4dcd70;}
.wdz-green .itemchos-leftscroller .disp-tit-box em{color: #4dc86f;}
.swiper-container { width: 100%; margin: 10px auto 0 auto !important;}
.swiper-slide { text-align: center; font-size: 18px; background: #fff; display: -webkit-box; display: -ms-flexbox; display: -webkit-flex; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; -webkit-justify-content: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; -webkit-align-items: center; align-items: center;}
.swiper-slide div{ text-align:center;}
.swiper-container .swiper-slide div img{ width:40px; height:40px; border-radius:50%;}
/* 医患沟通开始 */
.c-chat-box { border: none; padding-left: 15px; padding-right: 15px; }
.time-tips { margin: 10px 0 0 0; text-align: center; clear: both; }
.time-tips span { position: relative; display: inline-block; padding: 0 60px; color: #aeaeae; font-size: 13px; }
.time-tips span:before, .time-tips span:after { position: absolute; content: ""; display: block; width: 50px; height: 1px; background: #e6e4e1; top: 50%; }
.time-tips span:before { left: 0; }
.time-tips span:after { right: 0; }
.chat-left, .chat-right { clear: both; overflow: hidden; padding: 10px 0; }
.chat-left > dt, .chat-right > dt { width: 40px; height: 40px; }
.chat-left > dt { float: left; margin-right: 15px; }
.chat-right > dt { float: right; margin-left: 15px; }
.chat-left > dt img, .chat-right > dt img { width: 40px; height: 40px; border-radius: 50%; }
.chat-left > dd, .chat-right > dd { position: relative; min-height: 18px; font-size: 14px; display: inline-block; max-width: 65%; background: #fff; border: 1px solid #e1e1e1; border-radius: 6px; padding: 8px 10px; box-shadow: 1px 1px 1px rgba(0,0,0,.1); }
.chat-left > dd { float: left; white-space: pre-wrap; word-wrap: break-word; }
.chat-right > dd { float: right; background: #bce0ff; border: 1px solid #81bdf7; white-space: pre-wrap; word-wrap: break-word; }
.chat-left > dd:after { content: ""; position: absolute; top: 14px; left: -6px; display: block; width: 8px; height: 8px; background: #fff; border-color: #e1e1e1; border-style: solid; border-width: 1px 0 0 1px; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); transform: rotate(-45deg); }
.chat-right > dd:after { content: ""; position: absolute; top: 14px; right: -6px; display: block; width: 8px; height: 8px; background: #bce0ff; border-color: #81bdf7; border-style: solid; border-width: 1px 0 0 1px; -webkit-transform: rotate(135deg); -moz-transform: rotate(135deg); transform: rotate(135deg); }
.chat-left > dd p img, .chat-right > dd p img { max-width: 150px; max-height: 150px; margin: 5px 0; }
.pull-more { text-align: center; color: #5b5b5b; font-size: 14px; padding: 14px 0; }
.chat-btm-box { position: fixed; bottom: 0; left: 0; z-index: 2100; width: 100%; background: #fafafa; border-top: 1px solid #e1e1e1; }
.nopos { position: relative; bottom: auto; left: auto; }
.chat-text { position: relative; padding: 10px 15px 10px 15px; width: 100%; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
.insert-more { position: absolute; display: block; width: 30px; height: 30px; top: 6px; right: 25px; }
.insert-more i { font-size: 30px; line-height: 30px; color: #a9a9a9; }
.send-text { position: absolute; width: 50px; padding: 8px 0; display: block; bottom: 10px; right: 15px; background: #37a6ec; border-radius: 4px; }
.word-count { font-size: 12px; text-align: right; padding: 0 5px; color: #bfbfbf; }
.insert-img { position: absolute; display: block; width: 30px; height: 30px; top: 6px; right: 15px; border: 1px solid #737373; border-radius: 50%; }
.insert-img:before { position: absolute; content: ""; width: 16px; height: 2px; background: #737373; top: 14px; left: 7px; }
.insert-img:after { position: absolute; content: ""; width: 2px; height: 16px; background: #737373; top: 7px; left: 14px; }
.insert-img span { display: none; }
.chat-text-inp { padding: 0 65px 0 0; }
.chat-text-box { border: 1px solid #e1e1e1; background: #fff; border-radius: 4px;}
.chat-txt-con { width: 100%; height: 31px; outline: 0; font-size: 14px !important; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; border: none; padding:0 5px; white-space: pre-wrap; word-wrap: break-word; word-wrap: break-all; }
.ins-img-btn { position: fixed; width: 100%; bottom: 0; left: 0; z-index: 3100; }
.ins-img-btn .c-btn { border-radius: 4px; border: none; color: #157efb; font-size: 20px; }
.ins-img-btn .c-btn:first-child { border-radius: 4px 4px 0 0; }
.ins-img-btn .c-btn:nth-child(2) { border-top: 1px solid #e1e1e1; border-radius: 0 0 4px 4px; }
.pull-more { text-align: center; color: #5b5b5b; font-size: 14px; padding: 14px 0; }
.bgc-f7f5f2 { background: #f7f5f2; }
.more-opt { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: #fafafa; z-index: 2200; }
.m-close { position: absolute; top: 8px; right: 8px; display: block; width: 20px; height: 20px; }
.m-close i.ico-close { position: static; width: 20px; height: 20px; background-color: #afafaf; }
i.ico-close:before { width: 12px; height: 2px; left: 4px; top: 9px; }
i.ico-close:after { width: 2px; height: 12px; left: 9px; top: 4px; }
.more-opt-list { clear: both; padding: 58px 30px 0 30px; text-align: center; overflow: hidden; }
.more-opt-list.normal { clear: both; padding: 7px 30px 0 30px; text-align: center; overflow: hidden; }
.dh-nav { width: 100%; height: 40px; line-height:40px; border-bottom: 1px solid #e1e1e1; background: #fff; font-size:14px;}
.dh-nav li{ display:block; float:left; padding:0 20px;}
.dh-nav li.curr{ color:#4dcd70; position:relative;}
.dh-nav li.curr:before{ content:''; display:block; position:absolute; width:100%; height:2px; background:#4dcd70; left:0; bottom:-1px;}
.dh-list { width:100%; background:#fff; z-index:1;}
.dh-list-box { width: 100%; }
.dh-list li{ overflow:hidden; padding:15px 0 5px 0; font-size:14px; color:#333; display:block;}
.dh-list li label{ display:block; width:25%; float:left; text-align:center; margin-bottom:10px;}
.dh-list li label img{ width:40px; height:40px; border-radius:50%;}
.prerecord{ padding-left:10px; border-top:1px solid #f2f2f2; background:#fff;}
.prerecord:first-child{ border-top:0; margin-top:0;}
.prerecord div{ text-align:left !important;}
.pd-top{ line-height:25px; padding:5px 0; padding-right:10px;}
.pb-mid{ display:box; display:-webkit-box; padding-right:10px;}
.pd-img{ width:40px; height:40px; margin:10px 10px 10px 0; box-flex:0; -webkit-box-flex:0;}
.pd-img img{ width:40px; height:40px; border-radius:50%;}
.pd-mess{ box-flex:1; -webkit-box-flex:1; display: box; display: -webkit-box; -webkit-box-orient: vertical; -webkit-box-pack: center;}
.pd-btn{ width:60px; box-flex:0; -webkit-box-flex:0; display: box; display: -webkit-box; -webkit-box-orient: vertical; -webkit-box-pack: center;}
.pd-btn a{ display:block; width:60px; height:25px; line-height:25px; text-align:center; color:#fff; background:#4cd079; font-size:13px; border-radius:4px;}
.pd-bot{ border-top:1px solid #f2f2f2; line-height:40px; padding-right:10px;}
.pd-bot a{ display:inline-block; width:60px; height:30px; line-height:30px; background:#4dcd70; border-radius:4px; text-align:center; color:#fff; float:right; margin-top:5px;}
.pd-bot a.disab{ background:#ccc;}
.scoresr{ line-height:45px; border-top:1px dashed #f2f2f2; border-bottom:1px dashed #f2f2f2; padding:0 15px 0 28px;}
.ti-star { background: url(../images/tip-star.png) no-repeat; text-align: left; width: 157px; background-size: cover; overflow: hidden; background-position: 0 -22px; margin-top:12px; margin-left:15px;}
.ti-star ul { background: url(../images/tip-star.png) no-repeat; width: 157px; height: 22px; background-size: cover; overflow: hidden; background-position: 0 -22px; }
.ti-star ul.one { background-position: -134px 0; }
.ti-star ul.two { background-position: -101px 0; }
.ti-star ul.three { background-position: -67px 0; }
.ti-star ul.four { background-position: -34px 0; }
.ti-star ul.five { background-position: 0 0; }
.scoresr li { float: left; width: 31.4px; height: 24px; }
.nxz-voice-hold{ position:absolute; left:10px; bottom:8px;}

+ 154 - 0
html/jkda/html/event-profile.html

@ -0,0 +1,154 @@
<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>就诊记录</title>
		<meta name="author" content="yihu.com" />
		<meta name="format-detection" content="telephone=no" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0" />
		<meta name="apple-mobile-web-app-capable" content="yes" />
		<meta name="apple-mobile-web-app-status-bar-style" content="black" />
		<link rel="stylesheet" type="text/css" href="../../../iconfont/iconfont.css">
		<link rel="stylesheet" href="../../../css/cross.ui.css" type="text/css" />
		<link rel="stylesheet" type="text/css" href="../../../widget/artDialog/6.0.5/css/ui-dialog.min.css">
		<link rel="stylesheet" type="text/css" href="../css/base.css" />
		<link rel="stylesheet" type="text/css" href="../css/info.css" />
	</head>
	<body>
		<div class="h45 ep-top">
			<div class="demo-comtop">
				<h1><span id="selected_profile_name"></span></h1>
			</div>
		</div>
		
		<div class="j-body">    
        	<div class="page-content" ms-controller="viewController"></div>
        
        	<!--侧边栏-->
	        <div class="sidebar"></div>
	        <div class="sidebar-main">
	            <ul class="sidebar-body lin-sel-group">
	            	
	            </ul>
	        </div>
	    </div>
		
		<script type="text/html" id="profile_item_tmpl">
		{{if arr[0]}}
			<li data-code="{{arr[0].catalog}}" data-name="{{arr[0].title}}" data-serial="{{arr[0].serial}}" class="j-hascode sb-item" ><a href="javascript:;">门诊摘要</a></li>	
		{{/if}}
		{{if arr[1]}}
			<li data-code="{{arr[1].catalog}}" data-name="{{arr[1].title}}" data-serial="{{arr[1].serial}}" class="j-hascode sb-item" ><a href="javascript:;">门诊处方</a></li>	
		{{/if}}
		{{if arr[2].length >1}}
			<li class="sb-item">
                <a href="javascript:;">门诊检查<i class="i-d"></i></a>
                <ul class="sb-i-list">
                	{{each arr[2] as v i}}
                    <li data-code="{{v.catalog}}" data-name="{{v.title}}" data-serial="{{v.serial}}" class="j-hascode sb-item" ><a href="javascript:;">{{v.title}}</a></li>
                    {{/each}}
                </ul>
            </li>
        {{else}}
	        {{each arr[2] as v i}}
            	<li data-code="{{v.catalog}}" data-name="{{v.title}}" data-serial="{{v.serial}}" class="j-hascode sb-item" ><a href="javascript:;">门诊检查</a></li>
            {{/each}}
        {{/if}}
        {{if arr[3].length >1}}
			<li class="sb-item">
                <a href="javascript:;">门诊检验<i class="i-d"></i></a>
                <ul class="sb-i-list">
                	{{each arr[3] as v i}}
                    <li data-code="{{v.catalog}}" data-name="{{v.title}}" data-serial="{{v.serial}}" class="j-hascode sb-item" ><a href="javascript:;">{{v.title}}</a></li>
                    {{/each}}
                </ul>
            </li>
        {{else}}
	        {{each arr[3] as v i}}
            	<li data-code="{{v.catalog}}" data-name="{{v.title}}" data-serial="{{v.serial}}" class="j-hascode sb-item" ><a href="javascript:;">门诊检验</a></li>
            {{/each}}
        {{/if}}
        {{if arr[4]}}
			<li data-code="{{arr[4].catalog}}" data-name="{{arr[4].title}}" data-serial="{{arr[4].serial}}" class="j-hascode sb-item" ><a href="javascript:;">费用清单</a></li>	
		{{/if}}
		
		{{if arr2[0]}}
			<li data-code="{{arr2[0].catalog}}" data-name="{{arr2[0].title}}" data-serial="{{arr2[0].serial}}" class="j-hascode sb-item" ><a href="javascript:;">基本信息</a></li>	
		{{/if}}
		{{if arr2[1]}}
			<li data-code="{{arr2[1].catalog}}" data-name="{{arr2[1].title}}" data-serial="{{arr2[1].serial}}" class="j-hascode sb-item" ><a href="javascript:;">病案首页</a></li>	
		{{/if}}
		{{if arr2[2]}}
			<li data-code="{{arr2[2].catalog}}" data-name="{{arr2[2].title}}" data-serial="{{arr2[2].serial}}" class="j-hascode sb-item" ><a href="javascript:;">长期医嘱</a></li>	
		{{/if}}
		{{if arr2[3]}}
			<li data-code="{{arr2[3].catalog}}" data-name="{{arr2[3].title}}" data-serial="{{arr2[3].serial}}" class="j-hascode sb-item" ><a href="javascript:;">临时医嘱</a></li>	
		{{/if}}
		{{if arr2[4]}}
			<li data-code="{{arr2[4].catalog}}" data-name="{{arr2[4].title}}" data-serial="{{arr2[4].serial}}" class="j-hascode sb-item" ><a href="javascript:;">住院用药</a></li>	
		{{/if}}
		{{if arr2[5]}}
			<li data-code="{{arr2[5].catalog}}" data-name="{{arr2[5].title}}" data-serial="{{arr2[5].serial}}" class="j-hascode sb-item" ><a href="javascript:;">入院记录</a></li>	
		{{/if}}
		{{if arr2[6]}}
			<li data-code="{{arr2[6].catalog}}" data-name="{{arr2[6].title}}" data-serial="{{arr2[6].serial}}" class="j-hascode sb-item" ><a href="javascript:;">出院小结</a></li>	
		{{/if}}
		{{if arr2[7].length >1}}
			<li class="sb-item">
                <a href="javascript:;">住院检查<i class="i-d"></i></a>
                <ul class="sb-i-list">
                	{{each arr2[7] as v i}}
                    <li data-code="{{v.catalog}}" data-name="{{v.title}}" data-serial="{{v.serial}}" class="j-hascode sb-item" ><a href="javascript:;">{{v.title}}</a></li>
                    {{/each}}
                </ul>
            </li>
        {{else}}
	        {{each arr2[7] as v i}}
            	<li data-code="{{v.catalog}}" data-name="{{v.title}}" data-serial="{{v.serial}}" class="j-hascode sb-item" ><a href="javascript:;">住院检查</a></li>
            {{/each}}
        {{/if}}
        {{if arr2[8].length >1}}
			<li class="sb-item">
                <a href="javascript:;">住院检验<i class="i-d"></i></a>
                <ul class="sb-i-list">
                	{{each arr2[8] as v i}}
                    <li data-code="{{v.catalog}}" data-name="{{v.title}}" data-serial="{{v.serial}}" class="j-hascode sb-item" ><a href="javascript:;">{{v.title}}</a></li>
                    {{/each}}
                </ul>
            </li>
        {{else}}
	        {{each arr2[8] as v i}}
            	<li data-code="{{v.catalog}}" data-name="{{v.title}}" data-serial="{{v.serial}}" class="j-hascode sb-item" ><a href="javascript:;">住院检验</a></li>
            {{/each}}
        {{/if}}
        {{if arr2[9].length >1}}
			<li class="sb-item">
                <a href="javascript:;">手术记录<i class="i-d"></i></a>
                <ul class="sb-i-list">
                	{{each arr2[9] as v i}}
                    <li data-code="{{v.catalog}}" data-name="{{v.title}}" data-serial="{{v.serial}}" class="j-hascode sb-item" ><a href="javascript:;">{{v.title}}</a></li>
                    {{/each}}
                </ul>
            </li>
        {{else}}
	        {{each arr2[9] as v i}}
            	<li data-code="{{v.catalog}}" data-name="{{v.title}}" data-serial="{{v.serial}}" class="j-hascode sb-item" ><a href="javascript:;">手术记录</a></li>
            {{/each}}
        {{/if}}
		{{if arr2[10]}}
			<li data-code="{{arr2[10].catalog}}" data-name="{{arr2[10].title}}" data-serial="{{arr2[10].serial}}" class="j-hascode sb-item" ><a href="javascript:;">费用清单</a></li>	
		{{/if}}
		</script>
		
		<script src="../../../js/jquery/2.1.3/jquery.js"></script>
		<script type="text/javascript" src="../../../js/weixin_common.js" ></script>
		<script src="../../../widget/artDialog/6.0.5/js/dialog-plus.min.js"></script>
		<script src="../../../js/es6-promise.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/underscore.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/template.js"></script>
		<script src="../../../js/common_http.js" type="text/javascript" charset="utf-8"></script>
		<script src="../js/avalon.modern.js"></script>
		<script src="../js/event-profile.js"></script>
		<script src="../js/info.js"></script>
	</body>
</html>

+ 73 - 0
html/jkda/html/jianchajianyan.html

@ -0,0 +1,73 @@
<!DOCTYPE html>
<html>
	<head>
		<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
		<meta charset="utf-8">
		<title>检查检验</title>
		<link rel="stylesheet" type="text/css" href="../../../css/cross.css" />
		<link rel="stylesheet" type="text/css" href="../../../iconfont/iconfont.css" />
		<link rel="stylesheet" type="text/css" href="../../../css/iscroll.css" />	
		<link rel="stylesheet" type="text/css" href="../../../widget/artDialog/6.0.5/css/ui-dialog.min.css">
		<link rel="stylesheet" type="text/css" href="../../../widget/mobiscroll/2.15.1/css/mobiscroll.css">
		<link rel="stylesheet" type="text/css" href="../css/jianchajianyan.css?v=1.3.4">
	</head>
	<body>
		<div id="memberContainer"></div>
		<div class="div-content">
			<div class="f-pa f-hh vertical-line"></div>
            <div id="wrapper"> 
        		<div class="iScroller">
		          	 <ul class="ul-consultation" id="records">
		          	 	
		            </ul>
				</div>
			</div>	
		</div>
		<div id="no_result_wrap" style="display: none;">
			<img class="no-result-img" src="../images/shujuweikong_img.png" />
			<div class="f-fs14 c-323232 c-t-center">抱歉,暂未找到符合条件的结果。</div>
		</div>
		<a href="shangchuanjiuzhenjilu.html?eventType=2">
			<img id="new_btn" src="../images/xuanfutianjia_btn.png" />
		</a>
		<script type="text/html" id="li_tmpl">
			{{each list as it}}
			<li class="{{it | getEventTypeClass}}" data-json="{{it | toJson}}">
        		<div class="record-date">{{it.eventDate | getMD}}</div>
        		<div class="outer-circle">
					<div class="inner-circle"></div>
				</div>
				<div class="record-card">
		        	<div class="card-title">
		        		<span class="span-date"></span>
		        	    <span >{{it | getEventTypeName}}</span>
		        	    {{if it.dataFrom==2 }}
		        	    <span class="fr">上传</span>
		        	    {{/if}}
		        	</div>
		    		<div class="c-content-warp s-bc-ffffff pl10 pb10">
						<span class="c-323232 c-f16 c-nowrap">{{it.label}}</span>
						<div class="c-909090 c-f12"><img src="../images/yiyuanjianzhu_icon.png" class="yiyuan-icon mr5"/>{{it.orgName}}</div>
		    		</div>
		       </div>
        	</li>
        	{{/each}}
		</script>
		<script src="../../../js/jquery/2.1.3/jquery.js"></script>
		<script src="../../../js/app.js" type="text/javascript" charset="utf-8"></script>
		<script type="text/javascript" src="../../../js/mui.min.js"></script>
		<script src="../../../widget/artDialog/6.0.5/js/dialog-plus.min.js"></script>
		<script src="../../../widget/marques/marquee.js"></script>
		<script type="text/javascript" src="../../../js/common_http.js" ></script>
		<script type="text/javascript" src="../../../js/weixin_common.js" ></script>
		<script src="../../../js/es6-promise.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/underscore.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/template.js"></script>
		<script src="../../../widget/mobiscroll/2.15.1/js/mobiscroll.js"></script>
		<script src="../../../js/iscroll-probe.js"></script>
		<script src="http://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script>
		<script src="../../../js/iscroll-pull-up-down.js"></script>
		<script src="../../../js/family-members.js"></script>
		<script src="../js/jianchajianyan.js"></script>
	</body>
</html>

+ 56 - 0
html/jkda/html/jiankangtijian.html

@ -0,0 +1,56 @@
<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>健康体检</title>
		<meta name="author" content="yihu.com" />
		<meta name="format-detection" content="telephone=no" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0" />
		<meta name="apple-mobile-web-app-capable" content="yes" />
		<meta name="apple-mobile-web-app-status-bar-style" content="black" />
		<link rel="stylesheet" type="text/css" href="../../../css/cross.css">
		<link rel="stylesheet" href="../../../css/cross.ui.css" type="text/css" />
		<link rel="stylesheet" type="text/css" href="../../../widget/artDialog/6.0.5/css/ui-dialog.min.css">
		<link rel="stylesheet" href="../../../css/pull-up-down.css" type="text/css"/>
		<link rel="stylesheet" type="text/css" href="../css/jiankangtijian.css?v=1.3.4">
	</head>
	<body>
		<div id="memberContainer"></div>
		<div id="recent_event_list_wrap">
			<div id="recent_event_scroller" class="scroll-wrapper">
				<div class="list-wrap iScroller">
					<ul id="recent_event_list" class="c-list c-border-tb">
					</ul>
				</div>
			</div>
		</div>
		<div id="no_result_wrap" class="c-hide">
			<img class="no-result-img" src="../../../images/shujuweikong_img.png" />
			<div class="f-fs14 c-323232 c-t-center">抱歉,暂未找到符合条件的结果。</div>
		</div>
		<script type="text/htmo" id="recent_event_tmpl">
			{{each list as v i}}
			<li class="c-list-link list-arrow-r ptb12" data-json="{{v | toJson}}">
	            <div class="c-list-info">
	                <h4 class="c-f15"><a class="event-name c-f14 mr10">体检</a><span class="c-909090 c-f14">{{v.medicalTime}}</span></h4>
	                <p class="mt10 c-f16">{{v.orgName}}</p>
	            </div>
	        </li>
	        {{/each}}
		</script>
		<script src="../../../js/jquery/2.1.3/jquery.js"></script>
		<script type="text/javascript" src="../../../js/mui.min.js"></script>
		<script src="../../../widget/artDialog/6.0.5/js/dialog-plus.min.js"></script>
		<script src="../../../js/es6-promise.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/underscore.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/template.js"></script>
		<script src="../../../js/weixin_common.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/common_http.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/app.js"></script>
		<script src="../../../js/iscroll-probe.js"></script>
		<script src="../../../js/iscroll-pull-up-down-new.js"></script>
		<script src="../../../js/pull-up-down.js"></script>
		<script src="../../../js/family-members.js?v=1.3.4"></script>
		<script src="../js/jiankangtijian.js?v=1.3.4" type="text/javascript" charset="utf-8"></script>
	</body>
</html>

+ 1290 - 0
html/jkda/html/jiankangtijianxiangqing.html

@ -0,0 +1,1290 @@
<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>健康体检详情</title>
		<meta name="author" content="yihu.com" />
		<meta name="format-detection" content="telephone=no" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0" />
		<meta name="apple-mobile-web-app-capable" content="yes" />
		<meta name="apple-mobile-web-app-status-bar-style" content="black" />
		<link rel="stylesheet" type="text/css" href="icon">
		<link rel="stylesheet" type="text/css" href="../../../css/cross.css">
		<link rel="stylesheet" href="../../../css/cross.ui.css" type="text/css" />
		<link rel="stylesheet" type="text/css" href="../../../widget/artDialog/6.0.5/css/ui-dialog.min.css">
		<link rel="stylesheet" type="text/css" href="../css/jiankangtijianxiangqing.css" />
	</head>
	<body>
		<div ms-controller="viewController">
			<div class="bc-fff mt10 ">
				<div class="c-border-t c-border-b pl10 ptb5">
					<img class="f-w20 c-vam" src="../images/jiankangxiangqing_icon.png"/>
					<span class="c-333 c-vam c-fwb c-f18">报告信息</span>
				</div>
				<div class="c-border-b pb10">
					<div class="mt5 pl10">
						<span>时间:</span><span ms-text="data.medicalTime"></span>
					</div>
					<div class="mt5 pl10">
						<span>医生:</span><span ms-text="data.doctorName"></span>
					</div>
					<div class="mt5 pl10">
						<span>医院:</span><span ms-text="data.orgName"></span>
					</div>
				</div>
			</div>
			<!--
            	健康评价
            -->
			<div class="bc-fff mt10 c-panel expanding" auto-item>
				<div class="c-border-b pl10 ptb5 c-panel-bar">
					<img class="f-w20 c-vam" src="../images/jiankangxiangqing_icon.png"/>
					<span class="c-333 c-vam c-fwb c-f18">健康评价</span>
					<img class="f-w20 c-vam fr mt5 mr10 down-icon" src="../images/shou02_icon.png"/>
					<img class="f-w20 c-vam fr mt5 mr10 up-icon" src="../images/shou_icon.png"/>
				</div>
				<div class="c-panel-content pb10 c-border-b">
					<div class="mt5 pl10" auto-item >
						<div class="c-f16 c-909090" item-value>
							<span ms-if="data.isExaminationExcep==0">体检无异常</span>
						</div>
					</div>
					<div class="mt5 pl10" auto-item ms-repeat="data.examinationList">
						<div class="c-f16 c-fwb">异常<span ms-text="new Array('一','二','三','四')[$index]"></span></div>
						<div class="c-f14 c-909090" item-value ms-text="el">
							
						</div>
					</div>
				</div>
			</div>
			
			<!--
            	健康指导
            -->
			<div class="bc-fff mt10 c-panel" auto-item>
				<div class="c-border-b pl10 ptb5 c-panel-bar">
					<img class="f-w20 c-vam" src="../images/jiankangxiangqing_icon.png"/>
					<span class="c-333 c-vam c-fwb c-f18">健康指导</span>
					<img class="f-w20 c-vam fr mt5 mr10 down-icon" src="../images/shou02_icon.png"/>
					<img class="f-w20 c-vam fr mt5 mr10 up-icon" src="../images/shou_icon.png"/>
				</div>
				<div class="c-panel-content c-hide pb10 c-border-b" style="margin-top: -6px;">
					<div class="mt5 pl10 mt10" auto-item>
						<div class="c-f16 c-909090" item-value>
							<span ms-if="data.healthGuidanceSlowDisease=='1'">纳入慢性病患者健康管理;</span>
							<span ms-if="data.healthGuidanceInhospital=='1'">建议复查;</span>
							<span ms-if="data.healthGuidanceReview=='1'">建议复查;</span>
							<span ms-if="data.healthRegularFollowUp=='1'">定期随访;</span>
						</div>
					</div>
					<div class="mt5 pl10 " auto-item>
						<div class="c-f16 c-fwb c-border-t ptb5">危险因素控制</div>
						<div class="c-f16 c-909090" item-value>
							<span ms-if="data.hazardQuitSmocking =='1'">戒烟;</span>
							<span ms-if="data.hazardHealthDrink  =='1'">健康饮酒;</span>
							<span ms-if="data.hazardFood =='1'">饮食;</span>
							<span ms-if="data.hazardHardening =='1'">锻炼;</span>
							<span ms-if="data.hazardLoseWeight  =='1'">减体重;</span>
							<span ms-if="data.hazardVaccination  =='1'">建议接种疫苗;</span>
							<span ms-if="data.hazardOthers =='1'" ms-text="data.hazardOthersStr"></span>
						</div>
					</div>
				</div>
			</div>
			
			<!--
            	症状
            -->
			<div class="bc-fff mt10 c-panel" auto-item>
				<div class="c-border-b pl10 ptb5 c-panel-bar">
					<img class="f-w20 c-vam" src="../images/jiankangxiangqing_icon.png"/>
					<span class="c-333 c-vam c-fwb c-f18">症状</span>
					<img class="f-w20 c-vam fr mt5 mr10 down-icon" src="../images/shou02_icon.png"/>
					<img class="f-w20 c-vam fr mt5 mr10 up-icon" src="../images/shou_icon.png"/>
				</div>
				<div class="c-panel-content c-hide pb10 c-border-b">
					<div class="mt5 pl10" auto-item>
						<div class="c-f16 c-909090" item-value>
							<span ms-if="data.asymptomatic =='1'"></span><!-- 无症状 -->
							<span ms-if="data.symptomHeadach =='1'">头痛;</span>
							<span ms-if="data.symptomDizziness =='1'">头晕;</span>
							<span ms-if="data.symptomPalpitation =='1'">心悸;</span>
							<span ms-if="data.symptomChestStuffiness =='1'">胸闷;</span>
							<span ms-if="data.symptomChestPain =='1'">胸痛;</span>
							<span ms-if="data.symptomChronicCough =='1'">慢性咳嗽;</span>
							<span ms-if="data.symptomExpectoration =='1'">咳痰;</span>
							<span ms-if="data.symptomDyspnea =='1'">呼吸困难;</span>
							<span ms-if="data.symptomPolydipsia =='1'">多饮;</span>
							<span ms-if="data.symptomPolyuria =='1'">多尿;</span>
							<span ms-if="data.symptomWeightLoss =='1'">体重下降;</span>
							<span ms-if="data.symptomLackOfPower =='1'">乏力;</span>
							<span ms-if="data.symptomJointGall =='1'">关节肿痛;</span>
							<span ms-if="data.symptomBlurredVision =='1'">视力模糊;</span>
							<span ms-if="data.symptomHandFootNumbness =='1'">手脚麻木;</span>
							<span ms-if="data.symptomUrinaryUrgency =='1'">尿急;</span>
							<span ms-if="data.symptomDysuria =='1'">尿痛;</span>
							<span ms-if="data.symptomConstipation =='1'">便秘;</span>
							<span ms-if="data.symptomDiarrhea =='1'">腹泻;</span>
							<span ms-if="data.symptomNauseaVomiting =='1'">恶心呕吐;</span>
							<span ms-if="data.symptomDazzle =='1'">眼花;</span>
							<span ms-if="data.symptomTinnitus =='1'">耳鸣;</span>
							<span ms-if="data.symptomBreastBursting =='1'">乳房胀痛;</span>
							<span ms-if="data.symptomOther =='1'" ms-text="data.symptomOtherStr"></span>
						</div>
					</div>
				</div>
			</div>
			
			<!--
            	一般情况
            -->
			<div class="bc-fff mt10 c-panel" auto-item>
				<div class="c-border-b pl10 ptb5 c-panel-bar">
					<img class="f-w20 c-vam" src="../images/jiankangxiangqing_icon.png"/>
					<span class="c-333 c-vam c-fwb c-f18">一般情况</span>
					<img class="f-w20 c-vam fr mt5 mr10 down-icon" src="../images/shou02_icon.png"/>
					<img class="f-w20 c-vam fr mt5 mr10 up-icon" src="../images/shou_icon.png"/>
				</div>
				<div class="c-panel-content c-hide c-border-b pb5" style="margin-top: -6px;">
					<div class="mt10 pl10 pr10 ptb5 clearfix" auto-item>
						<span class="c-f16 c-909090" >
							体温
						</span>
						<span class="fr c-max-w120" >
							<span item-value ms-text="data.bodyTemperature"></span> ℃
						</span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							脉率
						</span>
						<span class="fr c-max-w120" >
							<span item-value ms-text="data.pulseFrequency"></span> 次/分
						</span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							呼吸频率
						</span>
						<span class="fr c-max-w120" >
							<span item-value ms-text="data.respiratoryRate"></span> 次/分
						</span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							血压(左)
						</span>
						<span class="fr c-max-w120" >
							<span item-value ms-if="data.bloodPressureLeftD && data.bloodPressureLeftU">
								<span ms-text="data.bloodPressureLeftD"></span>/<span ms-text="data.bloodPressureLeftU"></span>
							</span> mmHg
						</span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							血压(右)
						</span>
						<span class="fr c-max-w120" >
							<span item-value ms-if="data.bloodPressureRigthD && data.bloodPressureRigthU">
								<span ms-text="data.bloodPressureRigthD"></span>/<span ms-text="data.bloodPressureRigthU"></span>
							</span> mmHg
						</span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							身高
						</span>
						<span class="fr c-max-w120" >
							<span item-value ms-text="data.height"></span> cm
						</span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							体重
						</span>
						<span class="fr c-max-w120" >
							<span item-value ms-text="data.weight"></span> kg
						</span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							腰围
						</span>
						<span class="fr c-max-w120" >
							<span item-value ms-text="data.waist"></span> cm
						</span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							体质指数(BMI)
						</span>
						<span class="fr c-max-w120" >
							<span item-value ms-text="data.bmi"></span> kg/m<sup>2</sup>
						</span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							老年人健康状态自我评估
						</span>
						<span class="fr c-max-w120" item-value ms-text="data.elderlyHealthStatus"></span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							老年人生活自理能力评估
						</span>
						<span class="fr c-max-w120" item-value ms-text="data.elderlySelfCare"></span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<div auto-item>
							<span class="c-f16 c-909090">
							老年人认知功能
							</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','粗筛阴性','粗筛阳性')[data.elderlyCognitiveFun]"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--简易智力状态检查</span>
							<span class="fr c-max-w120" >
								<span item-value ms-text="data.miniMentalStateExamination"></span> 分
							</span>
						</div>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<div auto-item>
							<span class="c-f16 c-909090">
							老年人情感状态
							</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','粗筛阴性','粗筛阳性')[data.elderlyAffectiveState]"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--老年人抑郁评分</span>
							<span class="fr c-max-w120" >
								<span item-value ms-text="data.elderlyDepressionCheck"></span> 分
							</span>
						</div>
					</div>
				</div>
			</div>
			
			<!--
            	生活方式
            -->
			<div class="bc-fff mt10 c-panel" auto-item>
				<div class="c-border-b pl10 ptb5 c-panel-bar">
					<img class="f-w20 c-vam" src="../images/jiankangxiangqing_icon.png"/>
					<span class="c-333 c-vam c-fwb c-f18">生活方式</span>
					<img class="f-w20 c-vam fr mt5 mr10 down-icon" src="../images/shou02_icon.png"/>
					<img class="f-w20 c-vam fr mt5 mr10 up-icon" src="../images/shou_icon.png"/>
				</div>
				<div class="c-panel-content c-hide c-border-b card-layout" style="position: relative">
					<div class="card-item elastic-columns-ignore" auto-item>
						<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">体育锻炼</div>
							<div class="c-f14 c-909090" auto-item>
								<span>锻炼方式:</span>
								<span item-value ms-text="data.hardeningMode"></span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>锻炼频率:</span>
								<span item-value ms-text="data.hardeningFrequency"></span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>每次锻炼时间:</span>
								<span item-value ms-text="data.everyHardeningTime"></span>分钟
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>坚持锻炼时间:</span>
								<span item-value ms-text="data.insistHardeningTime"></span>年
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
						<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">饮食习惯</div>
							<div class="c-f14 c-909090" item-value>
								<span ms-if="data.eatClitocybineEqualization =='1'">荤素均衡;</span>
								<span ms-if="data.eatMeatdietFlash =='1'">荤食为主;</span>
								<span ms-if="data.eatVegetarianFlash =='1'">素食为主;</span>
								<span ms-if="data.eatHobbySalt =='1'">嗜盐;</span>
								<span ms-if="data.eatHobbyOil =='1'">嗜油;</span>
								<span ms-if="data.eatHobbySugar =='1'">嗜糖;</span>
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
						<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">吸烟情况</div>
							<div class="c-f14 c-909090" auto-item>
								<span>吸烟状况:</span>
								<span item-value ms-if="data.smokingCircumstance" ms-text="new Array('','从不吸烟','已戒烟','吸烟')[data.smokingCircumstance]"></span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>日吸烟量:</span>
								平均<span item-value ms-text="data.dailySmokingQuantity"></span>支
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>开始吸烟年龄:</span>
								<span item-value ms-text="data.beginSmokingAge"></span>岁
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>戒烟年龄:</span>
								<span item-value ms-text="data.quitSmokingAge"></span>岁
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
						<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">饮酒情况</div>
							<div class="c-f14 c-909090" auto-item>
								<span>饮酒频率:</span>
								<span item-value ms-text="data.drinkFrequency"></span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>日饮酒量:</span>
								<span item-value ms-text="data.everyAlcohol_tolerance"></span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>是否戒酒:</span> 
								<span item-value ms-text="(data.isDryOut==1)?'未戒酒':(data.isDryOut==2)?'已戒酒':''"></span> 
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span class="pl10">--戒酒年龄:</span>
								<span item-value ms-text="data.dryOutAge"></span>岁
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>开始饮酒年龄:</span>
								<span item-value ms-text="data.beginDrinkAge"></span>岁
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>近一年内是否曾醉酒:</span>
								<span item-value ms-text="(data.beginDrinkAge==1)?'是':(data.isDryOut==2)?'否':''"></span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>饮酒种类:</span>
								<span item-value>
									<span ms-if="data.drinkWhiteSpirits =='1'">白酒;</span>
									<span ms-if="data.drinkBeer =='1'">啤酒;</span>
									<span ms-if="data.drinkRedWine =='1'">红酒;</span>
									<span ms-if="data.drinkYellowWine =='1'">黄酒;</span>
									<span ms-if="data.drinkOthers =='1'" ms-text="data.drinkOthersStr"></span>
								</span>
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">职业暴露情况</div>
							<div auto-item>
								<div class="c-f14 c-909090" item-value ms-if="data.occupationalDisease == '2'">
									有接触史
								</div>
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>--工种:</span>
								<span item-value ms-text="data.occDiseaseTrades"></span>
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>--从业时间:</span>
								<span item-value ms-text="data.occupationalDiseaseWorkTime"></span>年
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>粉尘:</span>
								<span item-value ms-text="data.poisonDust"></span>
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>--防护措施:</span>
								<span item-value ms-if="data.poisonDust" ms-text="(data.poisonDustIspre==0)?'无':(data.poisonDustIspre==1)?data.poisonDustPreStr:''"></span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>放射物质:</span>
								<span item-value ms-text="data.poisonRadiogen"></span>
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>--防护措施:</span>
								<span item-value ms-if="data.poisonRadiogen" ms-text="(data.poisonRadiogenIspre ==0)?'无':(data.poisonRadiogenIspre ==1)?data.poisonRadiogenPreStr:''"></span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>物理因素:</span>
								<span item-value ms-text="data.poisonPhysicalfactor"></span>
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>--防护措施:</span>
								<span item-value ms-if="data.poisonPhysicalfactor" ms-text="(data.poisonPhysicalIspre  ==0)?'无':(data.poisonPhysicalIspre  ==1)?data.poisonPhysicalPreStr:''"></span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>化学物质:</span>
								<span item-value ms-text="data.poisonChemical"></span>
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>--防护措施:</span>
								<span item-value ms-if="data.poisonChemical" ms-text="(data.poisonChemicalIspre ==0)?'无':(data.poisonChemicalIspre ==1)?data.poisonChemicalPreStr:''"></span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>其他:</span>
								<span item-value ms-text="data.poisonOthers"></span>
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>--防护措施:</span>
								<span item-value ms-if="data.poisonOthers" ms-text="(data.poisonOthersIspre ==0)?'无':(data.poisonOthersIspre ==1)?data.poisonOthersPreStr:''"></span>
							</div>
						</div>
					</div>
				</div>
			</div>
			
			<!--
            	脏器功能
            -->
			<div class="bc-fff mt10 c-panel" auto-item>
				<div class="c-border-b pl10 ptb5 c-panel-bar">
					<img class="f-w20 c-vam" src="../images/jiankangxiangqing_icon.png"/>
					<span class="c-333 c-vam c-fwb c-f18">脏器功能</span>
					<img class="f-w20 c-vam fr mt5 mr10 down-icon" src="../images/shou02_icon.png"/>
					<img class="f-w20 c-vam fr mt5 mr10 up-icon" src="../images/shou_icon.png"/>
				</div>
				<div class="c-panel-content c-hide c-border-b pb5" style="margin-top: -6px;">
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<div>
							<span class="c-f16 c-909090">
							口腔
							</span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--口唇</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','红润','苍白','发绀','皲裂','疱疹')[data.lips]"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--齿列</span>
							<span class="fr c-max-w120" item-value>
								<span ms-if="data.dentitiondentureMissTeeth =='1'">缺齿;</span>
								<span ms-if="data.dentitiondentureDentalCaries =='1'">龋齿;</span>
								<span ms-if="data.dentitiondentureDenture =='1'">义齿(假牙);</span>
							</span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--咽部</span>
							<span class="fr c-max-w120" item-value>
								<span ms-if="data.pharyngealportionNo =='1'">无充血;</span>
								<span ms-if="data.pharyngealportionYes =='1'">充血;</span>
								<span ms-if="data.pharyngealportionAdd =='1'">淋巴滤泡增生;</span>
							</span>
						</div>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<div>
							<span class="c-f16 c-909090">
							视力
							</span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--左眼</span>
							<span class="fr c-max-w120" item-value ms-text="data.visionLeftEye"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--右眼</span>
							<span class="fr c-max-w120" item-value ms-text="data.visionRightEye"></span>
						</div>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<div>
							<span class="c-f16 c-909090">
							矫正视力
							</span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--左眼</span>
							<span class="fr c-max-w120" item-value ms-text="data.straightenVisionLeftEye"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--右眼</span>
							<span class="fr c-max-w120" item-value ms-text="data.straightenVisionRightEye"></span>
						</div>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090" >
							听力
						</span>
						<span class="fr c-max-w120" item-value ms-text="data.audition"></span>
					</div>
					<div class="mt10 pl10 pr10 pt10 c-border-t clearfix" auto-item>
						<span class="c-f16 c-909090" >
							运动功能
						</span>
						<span class="fr c-max-w120" item-value ms-text="data.motorFunction"></span>
					</div>
				</div>
			</div>
			
			<!--
            	查体
            -->
			<div class="bc-fff mt10 c-panel" auto-item>
				<div class="c-border-b pl10 ptb5 c-panel-bar">
					<img class="f-w20 c-vam" src="../images/jiankangxiangqing_icon.png"/>
					<span class="c-333 c-vam c-fwb c-f18">查体</span>
					<img class="f-w20 c-vam fr mt5 mr10 down-icon" src="../images/shou02_icon.png"/>
					<img class="f-w20 c-vam fr mt5 mr10 up-icon" src="../images/shou_icon.png"/>
				</div>
				<div class="c-panel-content c-hide pb10 c-border-b" style="margin-top: -6px;">
					<div class="mt5 pl10 pr10 pt5 clearfix" auto-item style="margin-top:10px">
						<span class="c-f16 c-909090" >
							眼底
						</span>
						<span class="fr c-max-w120" item-value>
							<span ms-if="data.eyeground=='1'">正常</span>
							<span ms-text="data.eyegroundException"></span>
						</span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							皮肤
						</span>
						<span class="fr c-max-w120" item-value>
							<span ms-text="data.skin"></span>
							<span ms-text="data.skinOthers"></span>
						</span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							巩膜
						</span>
						<span class="fr c-max-w120" item-value>
							<span ms-text="data.sclera"></span>
							<span ms-text="data.scleraOthers"></span>
						</span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							淋巴结
						</span>
						<span class="fr c-max-w120" item-value>
							<span ms-if="data.lymphNodeNotTouch =='1'">未触及</span>
							<span ms-if="data.lymphNodeClavicle =='1'">锁骨上</span>
							<span ms-if="data.lymphNodeRrmprt =='1'">腋窝</span>
							<span ms-if="data.lymphNode =='1'" ms-text="data.lymphNodeOthers"></span>
						</span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
						</span>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--桶状胸</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','否','是')[data.lungBarrelChest||0]"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--呼吸音</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','正常',data.lungBreathSound)[data.lungBreathSound||0]"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--罗音</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','无','干罗音','湿罗音',data.lungRhonchusException)[data.lungRhonchus||0]"></span>
						</div>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							心脏
						</span>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--心率</span>
							<span class="fr c-max-w120" >
								<span item-value ms-text="data.heartRate"></span> 次/分
							</span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--心律</span>
							<span class="fr c-max-w120" item-value ms-text="data.cardiacRhythm"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--杂音</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','无',data.cardiacSouffleOthers)[data.cardiacSouffle||0]"></span>
						</div>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							腹部
						</span>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--压痛</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','无',data.abdoPressPainOth)[data.abdoPressPain||0]"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--包块</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','无',data.abdoMassesOthers)[data.abdoMasses||0]"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--肝大</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','无',data.abdoHepatomegalyOth)[data.abdoHepatomegaly||0]"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--脾大</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','无',data.abdoSplenomegalyOth)[data.abdoSplenomegaly||0]"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--移动性浊音</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','无',data.abdoShiftingDullOth)[data.abdoShiftingDull||0]"></span>
						</div>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							下肢水肿
						</span>
						<span class="fr c-max-w120" item-value ms-text="data.immersionFoot"></span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							足背动脉搏动
						</span>
						<span class="fr c-max-w120" item-value ms-text="data.dorsumOfFootArteriopalmus"></span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							肛门指诊
						</span>
						<span class="fr c-max-w120" item-value>
							<span ms-text="data.fundamentFingerp"></span>
							<span ms-text="data.fundamentFingerpOth"></span>
						</span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							乳腺
						</span>
						<span class="fr c-max-w120" item-value>
							<span ms-if="data.breastNotTroubleFind =='1'">未见异常</span>
							<span ms-if="data.breastMastectomy =='1'">乳房切除</span>
							<span ms-if="data.breastAbnormalLactation =='1'">异常泌乳</span>
							<span ms-if="data.breastMasses =='1'">乳腺包块</span>
							<span ms-if="data.breastOthers =='1'" ms-text="data.breastOthersStr"></span>
						</span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							妇科
						</span>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--外阴</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','未见异常',data.vulvaException)[data.vulva || 0]"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--阴道</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','未见异常',data.vaginaException)[data.vagina || 0]"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--宫颈</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','未见异常',data.cervixException)[data.cervix || 0]"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--宫体</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','未见异常',data.corpusException)[data.corpus || 0]"></span>
						</div>
						<div auto-item>
							<span class="c-f14 c-909090" style="font-style: italic;">--附件</span>
							<span class="fr c-max-w120" item-value ms-text="new Array('','未见异常',data.attachmentException)[data.attachment || 0]"></span>
						</div>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							其他
						</span>
						<span class="fr c-max-w120" item-value ms-text="data.physicalExaminationOth"></span>
					</div>
				</div>
			</div>
			
			<!--
            	辅助检查
            -->
			<div class="bc-fff mt10 c-panel" auto-item>
				<div class="c-border-b pl10 ptb5 c-panel-bar">
					<img class="f-w20 c-vam" src="../images/jiankangxiangqing_icon.png"/>
					<span class="c-333 c-vam c-fwb c-f18">辅助检查</span>
					<img class="f-w20 c-vam fr mt5 mr10 down-icon" src="../images/shou02_icon.png"/>
					<img class="f-w20 c-vam fr mt5 mr10 up-icon" src="../images/shou_icon.png"/>
				</div>
				<div class="c-panel-content c-hide c-border-b card-layout" style="position: relative">
					<div class="card-item elastic-columns-ignore" auto-item>
						<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">血常规</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>血红蛋白:</span>
								<span item-value ms-text="data.hemoglobin"></span> g/L
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>白细胞:</span>
								<span item-value ms-text="data.leukocyte"></span> ×10<sup>9</sup>/L
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>血小板:</span>
								<span item-value ms-text="data.platelet"></span> ×10<sup>9</sup>/L
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>其他:</span>
								<span item-value ms-text="data.bloodRoutineOthers"></span>
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
						<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">尿常规</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>尿蛋白:</span>
								<span item-value ms-text="data.proteinuria"></span>
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>尿糖:</span>
								<span item-value ms-text="data.urineSugar"></span>
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>尿酮体:</span>
								<span item-value ms-text="data.ket"></span>
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>尿潜血:</span>
								<span item-value ms-text="data.urinaryOccultBlood"></span>
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>其他:</span>
								<span item-value ms-text="data.urineRoutineOthers"></span>
							</div>
						</div>
					</div> 
					<div class="card-item elastic-columns-ignore" auto-item>
						<div class="plr5 ptb5" auto-item>
							<div class="c-f16 c-fwb c-t-center">空腹血糖</div>
							<div class="c-f14 c-909090 pl10">
								<span auto-item>
									<span item-value ms-text="data.fastingPlasmaGlucoseL"></span>mmol/L 
								</span>
								<span ms-if="data.fastingPlasmaGlucoseL && data.fastingPlasmaGlucoseDL">或</span>
								<span auto-item>
									<span item-value ms-text="data.fastingPlasmaGlucoseDL"></span>mg/dL
								</span>
							</div> 
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
						<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">心电图</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span item-value ms-text="new Array('','正常','异常')[data.electrocardiogram||0]"></span>
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span item-value ms-text="data.electrocardiogramExcep"></span>
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">
								尿微量白蛋白
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span item-value ms-text="data.microalbuminuria"></span> mg/dL
							</div>
							<div class="c-f14 c-909090 pl10" auto-item> 
                                    <!-- TODO 不存在 -->
								<span>尿白蛋白/肌酥比值:</span>
								<span item-value ms-text="data.upcr"></span>
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">大便潜血</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span item-value ms-text="new Array('','阴性','阳性')[data.stoolOccultBlood||0]"></span>
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">糖化血红蛋白</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span item-value ms-text="data.glycolatedHemoglobin"></span> %
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">乙型肝炎表面抗原</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span item-value ms-text="new Array('','阴性','阳性')[data.hbsag||0]"></span>
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">肝功能</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>血清谷丙转氨酶:</span>
								<span item-value ms-text="data.liverFunctionSalt"></span> U/L
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>血清谷草转氨酶:</span>
								<span item-value ms-text="data.liverFunctionSgot"></span> U/L
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>白蛋白:</span>
								<span item-value ms-text="data.liverFunctionAlbumin"></span> g/L
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>总胆红素:</span>
								<span item-value ms-text="data.liverFunctionTotalBilirubin"></span> umol/L
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>结合胆红素:</span>
								<span item-value ms-text="data.liverFunctionCb"></span> umol/L
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">肾功能</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>血清肌酐:</span>
								<span item-value ms-text="data.renalFunctionCreatinine"></span> umol/L
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>血尿素氮:</span>
								<span item-value ms-text="data.renalFunctionBun"></span> mmol/L
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>血钾浓度:</span>
								<span item-value ms-text="data.renalFunctionBloodPotassium"></span> mmol/L
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>血钠浓度:</span>
								<span item-value ms-text="data.renalFunctionNatremia"></span> mmol/L
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>尿酸:</span>
								<span item-value ms-text="data.uricAcid"></span> umol/L
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">血脂</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>总胆固醇:</span>
								<span item-value ms-text="data.bloodFatTc"></span> mmol/L
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>甘油三酯:</span>
								<span item-value ms-text="data.bloodFatTriglyceride"></span> mmol/L
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>血清低密度脂蛋白胆固醇:</span>
								<span item-value ms-text="data.bloodFatLdlc"></span> mmol/L
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span>血清告密的脂蛋白胆固醇:</span>
								<span item-value ms-text="data.bloodFatHdlc"></span> mmol/L
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">胸部X线片</div>
							<div class="c-f14 c-909090 pl10"  auto-item>
								<span item-value ms-text="new Array('','正常','异常')[data.cxr]"></span>
							</div>
							<div class="c-f14 c-909090 pl10"  auto-item>
								<span item-value ms-text="data.cxrException"></span>
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">B超</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span item-value ms-text="new Array('','正常','异常')[data.typeBUltrasonic]"></span>
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span item-value ms-text="data.typeBUltrasonicExcep"></span>
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">宫颈涂片</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span item-value ms-text="new Array('','正常','异常')[data.cervicalPapSmears]"></span>
							</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span item-value ms-text="data.cervicalPapSmearsExcep"></span>
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">其他</div>
							<div class="c-f14 c-909090 pl10" auto-item>
								<span item-value ms-text="data.assistantInvesOth"></span>
							</div>
						</div>
					</div>
				</div>
			</div>
			
			<!--
            	中医体质辨识
            -->
			<div class="bc-fff mt10 c-panel" auto-item>
				<div class="c-border-b pl10 ptb5 c-panel-bar">
					<img class="f-w20 c-vam" src="../images/jiankangxiangqing_icon.png"/>
					<span class="c-333 c-vam c-fwb c-f18">中医体质辨识</span>
					<img class="f-w20 c-vam fr mt5 mr10 down-icon" src="../images/shou02_icon.png"/>
					<img class="f-w20 c-vam fr mt5 mr10 up-icon" src="../images/shou_icon.png"/>
				</div>
				<div class="c-panel-content c-hide pb10 c-border-b">
					<div class="mt5 pl10 pr10 ptb5 clearfix" auto-item>
						<span class="c-f16 c-909090">
							平和质
						</span>
						<span class="fr c-max-w120" item-value ms-text="new Array('','是','基本是')[data.corporeityGentle]"></span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							气虚质
						</span>
						<span class="fr c-max-w120" item-value ms-text="new Array('','是','基本是')[data.corporeityQiAsthenia]"></span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							阳虚质
						</span>
						<span class="fr c-max-w120" item-value ms-text="new Array('','是','基本是')[data.corporeityYangDeficiency]"></span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							阴虚质
						</span>
						<span class="fr c-max-w120" item-value ms-text="new Array('','是','基本是')[data.corporeityYinDeficiency]"></span>
					</div>
					
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							痰湿质
						</span>
						<span class="fr c-max-w120" item-value ms-text="new Array('','是','基本是')[data.corporeityPhlegmDamp]"></span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							湿热质
						</span>
						<span class="fr c-max-w120" item-value ms-text="new Array('','是','基本是')[data.corporeityDampHeat]"></span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							血瘀质
						</span>
						<span class="fr c-max-w120" item-value ms-text="new Array('','是','基本是')[data.corporeityHaemostasis]"></span>
					</div>
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							气郁质
						</span>
						<span class="fr c-max-w120" item-value ms-text="new Array('','是','基本是')[data.corporeityQiDepression]"></span>
					</div>
					
					<div class="mt5 pl10 pr10 c-border-t pt10 clearfix" auto-item>
						<span class="c-f16 c-909090">
							特秉质
						</span>
						<span class="fr c-max-w120" item-value ms-text="new Array('','是','基本是')[data.corporeityTeBing]"></span>
					</div>
				</div>
			</div>
			
			<!--
            	现存主要健康问题
            -->
			<div class="bc-fff mt10 c-panel" auto-item>
				<div class="c-border-b pl10 ptb5 c-panel-bar">
					<img class="f-w20 c-vam" src="../images/jiankangxiangqing_icon.png"/>
					<span class="c-333 c-vam c-fwb c-f18">现存主要健康问题</span>
					<img class="f-w20 c-vam fr mt5 mr10 down-icon" src="../images/shou02_icon.png"/>
					<img class="f-w20 c-vam fr mt5 mr10 up-icon" src="../images/shou_icon.png"/>
				</div>
				<div class="c-panel-content c-hide c-border-b card-layout" style="position: relative">
					<div class="card-item elastic-columns-ignore" auto-item>
						<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">脑血管疾病</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.cvdUndiscovered=='0'"></span><!-- 未发现 -->
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.cvdIschemicStroke=='1'">缺血性卒中</span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.cvdCerebralHemorrhage=='1'">脑出血</span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.cvdSah=='1'">蛛网膜下腔出血</span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.cvdTia=='1'">短暂性脑缺血发作</span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.cvdOthers=='1'" ms-text="data.cvdOthersStr" ></span>
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
						<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">肾脏疾病</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.renalUndiscovered=='0'"></span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.renalDn=='1'">糖尿病肾病</span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.renalFailure=='1'">肾功能衰竭</span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.renalAgn=='1'">急性肾炎</span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.renalCgn=='1'">慢性肾炎</span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.renalOthers=='1'" ms-text="data.renalOthersStr" ></span>
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
						<div class="plr5 ptb5">
							<div class="c-f16 c-fwb c-t-center">心脏疾病</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.heartUndiscovered=='0'"></span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.heartMyocardialInfarction=='1'">心肌梗死</span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.heartAnginaPectoris=='1'">心绞痛</span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.heartCoronaryArtery=='1'">冠状动脉血运重建</span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.heartChf=='1'">充血性心力衰竭</span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.heartPrecordialpain=='1'">心前区疼痛</span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span item-value ms-if="data.heartOthers=='1'" ms-text="data.heartOthersStr" ></span>
							</div>
						</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
								<div class="c-f16 c-fwb c-t-center">血管疾病</div>
								<div class="c-f14 c-909090" auto-item>
									<span item-value ms-if="data.angiosisUndiscovered=='0'"></span>
								</div>
								<div class="c-f14 c-909090" auto-item>
									<span item-value ms-if="data.angiosisDa=='1'">夹层动脉瘤</span>
								</div>
								<div class="c-f14 c-909090" auto-item>
									<span item-value ms-if="data.angiosisOcclusionArteries=='1'">动脉闭塞性疾病</span>
								</div>
								<div class="c-f14 c-909090" auto-item>
									<span item-value ms-if="data.angiosisOthers=='1'" ms-text="data.angiosisOthersStr" ></span>
								</div>
							</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
								<div class="c-f16 c-fwb c-t-center">眼部疾病</div>
								<div class="c-f14 c-909090" auto-item>
									<span item-value ms-if="data.eyeDiseaseUndiscovered=='0'"></span>
								</div>
								<div class="c-f14 c-909090" auto-item>
									<span item-value ms-if="data.retinalHemorrhage=='1'">视网膜出血</span>
								</div>
								<div class="c-f14 c-909090" auto-item>
									<span item-value ms-if="data.papilledema=='1'">视乳头水肿</span>
								</div>
								<div class="c-f14 c-909090" auto-item>
									<span item-value ms-if="data.eyeDiseaseCataract=='1'">白内障</span>
								</div>
								<div class="c-f14 c-909090" auto-item>
									<span item-value ms-if="data.eyeDiseaseOthers=='1'" ms-text="data.eyeDiseaseOthersStr" ></span>
								</div>
							</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
								<div class="c-f16 c-fwb c-t-center">神经系统疾病</div>
								<div class="c-f14 c-909090" auto-item>
									<span item-value ms-text="new Array('','',data.nervousSystemDiseaseStr)[data.nervousSystemDisease]"></span>
								</div>
							</div>
					</div>
					<div class="card-item elastic-columns-ignore" auto-item>
							<div class="plr5 ptb5">
								<div class="c-f16 c-fwb c-t-center">其他系统疾病</div>
								<div class="c-f14 c-909090" auto-item>
									<span item-value ms-text="new Array('','',data.othersSystemDiseaseStr)[data.nervousSystemDisease]"></span>
								</div>
							</div>
					</div>
				</div>
			</div>
			
			<!--
            	住院治疗情况
            -->
			<div class="bc-fff mt10 c-panel" auto-item>
				<div class="c-border-b pl10 ptb5 c-panel-bar">
					<img class="f-w20 c-vam" src="../images/jiankangxiangqing_icon.png"/>
					<span class="c-333 c-vam c-fwb c-f18">住院治疗情况</span>
					<img class="f-w20 c-vam fr mt5 mr10 down-icon" src="../images/shou02_icon.png"/>
					<img class="f-w20 c-vam fr mt5 mr10 up-icon" src="../images/shou_icon.png"/>
				</div>
				<div class="c-panel-content c-hide  pb10 c-border-b">
					<div class="mt5 pl10">
						<div auto-item>
							<div class="c-f16 c-fwb pb5 pt5">住院史</div>
							<div class="c-border-t">
								<div class="c-border mt5 pl10 pr10 pt10 pb10 c-border-r5 mr10" auto-item ms-repeat="data.inhospitalList">
									<div class="c-f14 c-909090" auto-item>
										<span>时间:</span>
										<span item-value>
											<span ms-text="el.inhospitalAdmissiondate"></span>
											<span ms-if="el.inhospitalAdmissiondate&&el.inhospitalLeavedate"> ~ </span>
											<span ms-text="el.inhospitalLeavedate"></span>
										</span>
									</div>
									<div class="c-f14 c-909090" auto-item>
										<span>原因:</span>
										<span item-value ms-text="el.inhospitalCause"></span>
									</div>
									<div class="c-f14 c-909090" auto-item>
										<span>病案号:</span>
										<span item-value ms-text="el.inhospitalPatientId"></span>
									</div>
									<div class="c-f14 c-909090" auto-item>
										<span>医疗机构:</span>
										<span item-value ms-text="el.inhospitalOrgName"></span>
									</div>
								</div>
								
							</div>
						</div>
						
						<div class="c-border-t mt5" auto-item>
							<div class="c-f16 c-fwb pb5 pt5">家庭病床史</div>
							<div class="c-border-t">
								<div class="c-border mt5 pl10 pr10 pt10 pb10 c-border-r5 mr10" auto-item ms-repeat="data.fpList">
									<div class="c-f14 c-909090" auto-item>
										<span>时间:</span>
										<span item-value>
											<span ms-text="el.fpEstablishDate"></span>
											<span ms-if="el.fpEstablishDate&&el.fpCancelDate"> ~ </span>
											<span ms-text="el.fpCancelDate"></span>
										</span>
									</div>
									<div class="c-f14 c-909090" auto-item>
										<span>原因:</span>
										<span item-value ms-text="el.fpCause"></span>
									</div>
									<div class="c-f14 c-909090" auto-item>
										<span>病案号:</span>
										<span item-value ms-text="el.fpPatientId"></span>
									</div>
									<div class="c-f14 c-909090" auto-item>
										<span>医疗机构:</span>
										<span item-value ms-text="el.fpOrgName"></span>
									</div>
								</div>
							</div>
						</div>
					</div>
				</div>
			</div>
			
			<!--
            	主要用药情况
            -->
			<div class="bc-fff mt10 c-panel" auto-item>
				<div class="c-border-b pl10 ptb5 c-panel-bar">
					<img class="f-w20 c-vam" src="../images/jiankangxiangqing_icon.png"/>
					<span class="c-333 c-vam c-fwb c-f18">主要用药情况</span>
					<img class="f-w20 c-vam fr mt5 mr10 down-icon" src="../images/shou02_icon.png"/>
					<img class="f-w20 c-vam fr mt5 mr10 up-icon" src="../images/shou_icon.png"/>
				</div>
				<div class="c-panel-content c-hide pb10 c-border-b">
					<div class="mt5 pl10">
						<div auto-item ms-repeat="data.drugList">
							<div class="c-border mt5 pl10 pr10 pt10 pb10 c-border-r5 mr10">
								<div class="c-f16 c-fwb pb5 pt5" ms-text="el.drugName"></div>
								<div class="c-f14 c-909090" auto-item>
									<span>用法:</span>
									<span item-value ms-text="el.drugUsage"></span>
								</div>
								<div class="c-f14 c-909090" auto-item>
									<span>用量:</span>
									<span item-value ms-text="el.drug_dosage"></span>
								</div>
								<div class="c-f14 c-909090" auto-item>
									<span>用药时间:</span>
									<span item-value ms-text="el.drugDate"></span>
								</div>
								<div class="c-f14 c-909090" auto-item>
									<span>服药依从性:</span>
									<span item-value ms-text="new Array('','规律','间断','不服药')[el.drugCompliance]"></span>
								</div>
							</div>
						</div>
					</div>
				</div>
			</div>
			
			<!--
            	非免疫规划预防接种史
            -->
			<div class="bc-fff mt10 c-panel" auto-item>
				<div class="c-border-b pl10 ptb5 c-panel-bar">
					<img class="f-w20 c-vam" src="../images/jiankangxiangqing_icon.png"/>
					<span class="c-333 c-vam c-fwb c-f18">非免疫规划预防接种史</span>
					<img class="f-w20 c-vam fr mt5 mr10 down-icon" src="../images/shou02_icon.png"/>
					<img class="f-w20 c-vam fr mt5 mr10 up-icon" src="../images/shou_icon.png"/>
				</div>
				<div class="c-panel-content c-hide pb10 c-border-b">
					<div class="mt5 pl10">
						<div class="c-border mt5 pl10 pr10 pt10 pb10 c-border-r5 mr10" auto-item ms-repeat="data.fpList">
							<div class="c-f16 c-fwb " ms-text="el.niVaccinationName"></div>
							<div class="c-f14 c-909090" auto-item>
								<span>接种日期:</span>
								<span item-value ms-text="el.niVaccinationDate"></span>
							</div>
							<div class="c-f14 c-909090" auto-item>
								<span>接种机构:</span>
								<span item-value ms-text="el.niVaccinationOrg"></span>
							</div>
						</div>
					</div>
				</div>
			</div>
			
    	</div>
		<script src="../../../js/jquery/2.1.3/jquery.js"></script>
		<script type="text/javascript" src="../../../js/mui.min.js"></script>
		<script src="../../../widget/artDialog/6.0.5/js/dialog-plus.min.js"></script>
		<script src="../../../js/es6-promise.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/underscore.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/template.js"></script>
		<script src="../../../js/weixin_common.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/common_http.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/app.js"></script>
		<script src="../js/avalon.modern.js"></script>
		<script src="../js/elastic-columns.js"></script>
		<script src="../js/jiankangtijianxiangqing.js"></script>
	</body>
</html>

+ 76 - 0
html/jkda/html/jiuzhenjilu.html

@ -0,0 +1,76 @@
<!DOCTYPE html>
<html>
	<head>
		<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
		<meta charset="utf-8">
		<title>就诊记录</title>
		<link rel="stylesheet" type="text/css" href="../../../css/cross.css" />
		<link rel="stylesheet" type="text/css" href="../../../iconfont/iconfont.css" />
		<link rel="stylesheet" type="text/css" href="../../../css/iscroll.css" />	
		<link rel="stylesheet" type="text/css" href="../../../widget/artDialog/6.0.5/css/ui-dialog.min.css">
		<link rel="stylesheet" type="text/css" href="../../../widget/mobiscroll/2.15.1/css/mobiscroll.css">
		<link rel="stylesheet" type="text/css" href="../css/jiuzhenjilu.css?v=1.3.4">
	</head>
	<body>
		<div id="memberContainer"></div>
		<div class="div-content c-hide">
			<div class="f-pa f-hh vertical-line"></div>
            <div id="wrapper">
        		<div class="iScroller">
		          	 <ul class="ul-consultation" id="records">
		          	 	
		            </ul>
				</div>
			</div>	
		</div>
		<div id="no_result_wrap" class="c-hide">
			<img class="no-result-img" src="../images/shujuweikong_img.png" />
			<div class="f-fs14 c-323232 c-t-center">抱歉,暂未找到符合条件的结果。</div>
		</div>
		<a href="shangchuanjiuzhenjilu.html?eventType=1">
			<img id="new_btn" src="../images/xuanfutianjia_btn.png" />
		</a>
		<script type="text/html" id="li_tmpl">
			{{each list as it}}
			<!--屏蔽非门诊和住院记录-->
			{{if it.dataFrom==2 || (it.dataFrom==1 && it.eventType == '1') || (it.dataFrom==1 && it.eventType == '2') || (it.dataFrom==1 && it.eventType == '3')}}
			<li data-id="{{it.id}}" data-from="{{it.dataFrom}}" data-event-date="{{it.eventDate}}" data-json="{{it | toJson}}" class="{{it.eventType | getEventTypeClass}}">
        		<div class="record-date">{{it.eventDate | getMD}}</div>
        		<div class="outer-circle">
					<div class="inner-circle"></div>
				</div>
				<div class="record-card">
		        	<div class="card-title">
		        		<span class="span-date"></span>
		        	    <span >{{it.eventType | getEventTypeName}}</span>
		        	    {{if it.dataFrom==2 }}
		        	    <span class="fr">上传</span>
		        	    {{/if}}
		        	</div>
		    		<div class="c-content-warp s-bc-ffffff pl10 pb10 c-nowrap">
						<span class="c-323232 c-f16 ">{{it.dianosis||"无诊断结果"}}</span>
						<div class="c-909090 c-f12"><img src="../images/yiyuanjianzhu_icon.png" class="yiyuan-icon mr5"/>{{it.orgName}}</div>
		    		</div>
		       </div>
        	</li>
        	{{/if}}
        	{{/each}}
		</script>
		<script src="../../../js/jquery/2.1.3/jquery.js"></script>
		<script src="../../../js/app.js" type="text/javascript" charset="utf-8"></script>
		<script type="text/javascript" src="../../../js/mui.min.js"></script>
		<script src="../../../widget/artDialog/6.0.5/js/dialog-plus.min.js"></script>
		<script src="../../../widget/marques/marquee.js"></script>
		<script type="text/javascript" src="../../../js/common_http.js" ></script>
		<script type="text/javascript" src="../../../js/weixin_common.js" ></script>
		<script src="../../../js/es6-promise.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/underscore.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/template.js"></script>
		<script src="../../../widget/mobiscroll/2.15.1/js/mobiscroll.js"></script>
		<script src="../../../js/iscroll-probe.js"></script>
		<script src="http://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script>
		<script src="../../../js/iscroll-pull-up-down.js"></script>
		<script src="../../../js/family-members.js"></script>
		<script src="../js/jiuzhenjilu.js?v=1.3.4"></script>
	</body>
</html>

+ 241 - 0
html/jkda/html/jiuzhenxiangqing.html

@ -0,0 +1,241 @@
<!DOCTYPE html>
<html>
	<head>
		<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
		<meta charset="utf-8">
		<title>门/急诊详情</title>
		<link rel="stylesheet" type="text/css" href="../../../css/cross.css" />
		<link rel="stylesheet" type="text/css" href="../../../iconfont/iconfont.css" />
		<link rel="stylesheet" type="text/css" href="../css/ss-style.css" />
		<link rel="stylesheet" type="text/css" href="../../../css/cross.ui.css">
		<link rel="stylesheet" type="text/css" href="../css/zx-style.css">	
		<link rel="stylesheet" type="text/css" href="../../../css/iscroll.css" />	
		<link rel="stylesheet" type="text/css" href="../../../css/pull-up-down.css" />	
		<link rel="stylesheet" type="text/css" href="../../../widget/artDialog/6.0.5/css/ui-dialog.min.css">
		<link rel="stylesheet" type="text/css" href="../../../widget/mobiscroll/2.15.1/css/mobiscroll.css">
		<link rel="stylesheet" type="text/css" href="../../../widget/photoswipe/photoswipe.css">
		<link rel="stylesheet" type="text/css" href="../../../widget/photoswipe/default-skin/default-skin.css">
		<link rel="stylesheet" type="text/css" href="../css/jiuzhenxiangqing.css?v=1.3.4">
	</head>
	<body>
		<div id="edit_btn">
			<img src="../images/xuanfuxiugai_btn.png"/>
		</div>
		<div class="mt10 info-panel bc-fff">
			<p class="title pl15">
				<img src="../images/jiuzhenxinxi_icon.png" class="title-icon"/>
				<span class="c-fwb pl10" >就诊信息</span>
			</p>
			<div class="pl15 pt10 pb10 c-f14">
				<label>就诊时间:</label><span id="time"></span>
				<label class="ml20">就诊类型:</label><span id="type"></span>
			</div>
			<div id="dept_doctor" class="pl15 pb10 c-f14 c-hide">
				<label>科室/医生:</label><span id="dept"></span><span id="doctor"></span>
			</div>
			<div class="pl15 pb10 c-f14 c-hide">
				<label>医院:</label><span id="org"></span>
			</div>
		</div>
		<div class="mt10 info-panel bc-fff">
			<p class="title pl15">
				<img src="../images/zhenduanjieguo_icon.png" class="title-icon"/>
				<span class="c-fwb pl10" >诊断结果</span>
			</p>
			<div id="diagnosis" class="pl15 pt10 pb10 c-f14">
				
			</div>
		</div>
		<div data-type="病历" class="mt10 info-panel bc-fff clearfix pb10 c-hide">
			<p class="title pl15">
				<img src="../images/bingli_icon.png" class="title-icon"/>
				<span class="c-fwb pl10" >病历</span>
			</p>
			<ul id="bingli_images" class="pl15 pb10 c-f14 img-list">
				
			</ul>
		</div>
		<div data-type="处方" class="mt10 info-panel bc-fff clearfix pb10 c-hide">
			<p class="title pl15">
				<img src="../images/chufang_icon.png" class="title-icon"/>
				<span class="c-fwb pl10" >处方</span>
			</p>
			<ul id="chufang_images" class="pl15 pb10 c-f14 img-list">
				
			</ul>
		</div>
		<div data-type="检查报告"  class="mt10 info-panel bc-fff clearfix pb10 c-hide">
			<p class="title pl15">
				<img src="../images/jianchabaogao_icon.png" class="title-icon"/>
				<span class="c-fwb pl10" >检查报告</span>
			</p>
			<ul id="jiancha_images" class="pl15 pb10 c-f14 img-list">
				
			</ul>
		</div>
		<div data-type="检验报告" class="mt10 info-panel bc-fff clearfix pb10 c-hide">
			<p class="title pl15">
				<img src="../images/jianchabaogao_icon.png" class="title-icon"/>
				<span class="c-fwb pl10" >检验报告</span>
			</p>
			<ul id="jianyan_images"class="pl15 pb10 c-f14 img-list">
				
			</ul>
		</div>
		<div data-type="病理报告" class="mt10 info-panel bc-fff clearfix pb10 c-hide">
			<p class="title pl15">
				<img src="../images/binglibaogao_icon.png" class="title-icon"/>
				<span class="c-fwb pl10" >病理报告</span>
			</p>
			<ul id="bingli_images" class="pl15 pb10 c-f14 img-list">
				
			</ul>
		</div>
		<div data-type="其他" class="mt10 info-panel bc-fff clearfix pb10 c-hide">
			<p class="title pl15">
				<img src="../images/qita_icon.png" class="title-icon"/>
				<span class="c-fwb pl10" >其他</span>
			</p>
			<ul id="qita_images" class="pl15 pb10 c-f14 img-list">
				
			</ul>
		</div>
		<div data-type="未分类" class="mt10 info-panel bc-fff clearfix pb10 c-hide">
			<p class="title pl15">
				<img src="../images/weifenlei_icon.png" class="title-icon"/>
				<span class="c-fwb pl10" >未分类</span>
			</p>
			<ul id="weifenlei_images" class="pl15 pb10 c-f14 img-list">
				
			</ul>
		</div>
		
		<!-- Root element of PhotoSwipe. Must have class pswp. -->
		<div class="pswp" tabindex="-1" role="dialog" aria-hidden="true">
		    <!-- Background of PhotoSwipe. 
		         It's a separate element as animating opacity is faster than rgba(). -->
		    <div class="pswp__bg"></div>
		
		    <!-- Slides wrapper with overflow:hidden. -->
		    <div class="pswp__scroll-wrap">
		
		        <!-- Container that holds slides. 
		            PhotoSwipe keeps only 3 of them in the DOM to save memory.
		            Don't modify these 3 pswp__item elements, data is added later on. -->
		        <div class="pswp__container">
		            <div class="pswp__item"></div>
		            <div class="pswp__item"></div>
		            <div class="pswp__item"></div>
		        </div>
		
		        <!-- Default (PhotoSwipeUI_Default) interface on top of sliding area. Can be changed. -->
		        <div class="pswp__ui pswp__ui--hidden">
		
		            <div class="pswp__top-bar" style="display: none;">
		                <!--  Controls are self-explanatory. Order can be changed. -->
		                <div class="pswp__counter"></div>
		                <button class="pswp__button pswp__button--close" title="Close (Esc)"></button>
		                <!-- Preloader demo http://codepen.io/dimsemenov/pen/yyBWoR -->
		                <!-- element will get class pswp__preloader--active when preloader is running -->
		                <div class="pswp__preloader">
		                    <div class="pswp__preloader__icn">
		                      <div class="pswp__preloader__cut">
		                        <div class="pswp__preloader__donut"></div>
		                      </div>
		                    </div>
		                </div>
		            </div>
		            <div class="pswp__caption">
		                <div class="pswp__caption__center"></div>
		            </div>
		
		        </div>
		
		    </div>
		    <div id="catalog_bar" style="position: absolute; bottom: 0; width: 100%; height: 40px; background: #000; opacity: 0.8; "class="c-f14 pt10 pl10 pr10">
		    	<div class="ui-grid">
			        <div class="ui-col-1 pr10"><a id="delete_img_btn" href="javascript:void(0);" class="c-fff"><img src="../images/shanchu02_btn.png" style="width: 18px; height: 18px;margin-top: 3px; margin-right: 5px;" />删除</a></div>
			        <div class="ui-col-1 pr10 pop-catalog-sel c-t-center"><a href="javascript:void(0);" class="c-fff" ><span id="catalog_name"></span><span id="page_counter"></span></a></div>
			        <div class="ui-col-1 c-t-right pop-catalog-sel"><a href="javascript:void(0);" class="c-fff" ><img src="../images/fenlei_btn.png" style="width: 18px; height: 18px;margin-top: 3px; margin-right: 5px;" />分类</a></div>
			    </div>
		    </div> 	
		    <div id="catalog_box" style="position: absolute; bottom: 0; width: 100%; background: #000; opacity: 0.8;" class="c-hide">
				<ul class="n-list select-image-bar">
					<li class="ptb12">
						<div class="n-list-key pr15 c-f16 c-fff">变更图片分类</div>
						<div class="n-list-info c-t-right">
							<p class="c-ccc c-f12 c-t-right img-count" id="image_counter">
								<span id="cur_page"></span><span class="c-74bf00">/</span><span id="amount_page" class="c-74bf00"></span>
							</p>
						</div>
					</li>
				</ul>
				<div class="pl10 pr10 mt10 pb10 img-catalog" style="border-bottom: 1px solid #909090;">
					<div class="ui-grid">
				        <div class="ui-col-1 pr10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="病历">病历</a></div>
				        <div class="ui-col-1 pr10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="处方">处方</a></div>
				        <div class="ui-col-1"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="病理报告">病理报告</a></div>
				    </div>
				    <div class="ui-grid mt10">
				        <div class="ui-col-1 pr10"><a href="javascript: void(0);" data-ref="jian_cha_types" class="c-btn-74bf00 c-btn-icon c-323232" data-type="检查报告"><i class="c-arrow-d"></i>检查报告</a></div>
				        <div class="ui-col-1 pr10"><a href="javascript: void(0);" data-ref="jian_yan_types" class="c-btn-74bf00 c-btn-icon c-323232" data-type="检验报告"><i class="c-arrow-d"></i>检验报告</a></a></div>
				        <div class="ui-col-1"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232"  data-type="其他">其他</a></div>
				    </div>
				</div>
				<div id="jian_cha_types" class="pl10 pr10 mt10 mb10 c-hide sub-catalog" >
					<div class="ui-grid">
				        <div class="ui-col-1 pr10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="超声">超声</a></div>
				        <div class="ui-col-1 pr10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="CR">CR</a></div>
				        <div class="ui-col-1 pr10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="DR">DR</a></div>
				        <div class="ui-col-1"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="CT">CT</a></div>
				    </div>
				    <div class="ui-grid mt10">
				    	<div class="ui-col-1 pr10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="MR">MR</a></div>
				        <div class="ui-col-1 pr10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="消化内镜">消化内镜</a></div>
				        <div class="ui-col-1"><a href="javascript:;" class="c-btn-74bf00 c-btn-icon c-323232" data-type="其他">其他</a></div>
				    </div>
				</div> 
				<div id="jian_yan_types" class="pl10 pr10 mt10 mb10 c-hide sub-catalog" >
					<div class="ui-grid">
				        <div class="ui-col-1 pr10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="血液">血液</a></div>
				        <div class="ui-col-1 pr10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="细菌培养">细菌培养</a></div>
				        <div class="ui-col-1 pr10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="尿液">尿液</a></div>
				        <div class="ui-col-1"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="粪便">粪便</a></div>
				    </div>
				    <div class="ui-grid mt10">
				        <div class="ui-col-1 pr10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="分泌物">分泌物</a></div>
				        <div class="ui-col-1"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="其他">其他</a></div>
				    </div>
				</div> 
			</div>
		</div>
		<script type="text/html" id="li_tmpl">
			{{each list as it}}
			<li class="fl mr10 mt10">
				<img src="{{it.imgUrl | setPhoto}}" data-id="{{it.id}}"  class="preview-img" data-catalog="{{it.imgType}}" data-sub-catalog="{{it.imgLabel}}"/>
				{{if it.imgLabel }}
				<div class="c-t-center c-909090 c-f12 mt5" >{{it.imgLabel}}</div>
				{{/if}}
			</li>
        	{{/each}}
		</script>
		<script src="../../../js/jquery/2.1.3/jquery.js"></script>
		<script src="../../../js/app.js" type="text/javascript" charset="utf-8"></script>
		<script type="text/javascript" src="../../../js/mui.min.js"></script>
		<script src="../../../widget/artDialog/6.0.5/js/dialog-plus.min.js"></script>
		<script src="../../../widget/marques/marquee.js"></script>
		<script type="text/javascript" src="../../../js/common_http.js" ></script>
		<script type="text/javascript" src="../../../js/weixin_common.js" ></script>
		<script src="../../../js/es6-promise.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/underscore.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/template.js"></script>
		<script src="../../../widget/mobiscroll/2.15.1/js/mobiscroll.js"></script>
		<script src="../../../js/iscroll-probe.js"></script>
		<script src="http://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script>
		<script src="../../../js/iscroll-pull-up-down.js"></script>
		<script src="../../../js/pull-up-down.js"></script>
		<script src="../../../widget/photoswipe/photoswipe.min.js"></script>
		<script src="../../../widget/photoswipe/photoswipe-ui-default.min.js"></script>
		<script src="../js/jiuzhenxiangqing.js?v=1.3.4"></script>
	</body>
</html>

+ 245 - 0
html/jkda/html/shangchuanjiuzhenjilu-edit.html

@ -0,0 +1,245 @@
<!DOCTYPE html>
<html>
	<head>
		<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
		<meta charset="utf-8">
		<title>编辑就诊记录</title>
		<link rel="stylesheet" type="text/css" href="../../../css/cross.css" />
		<link rel="stylesheet" type="text/css" href="../../../iconfont/iconfont.css" />
		<link rel="stylesheet" type="text/css" href="../css/ss-style.css" />
		<link rel="stylesheet" type="text/css" href="../../../css/cross.ui.css">
		<link rel="stylesheet" type="text/css" href="../css/zx-style.css">	
		<link rel="stylesheet" type="text/css" href="../css/consultation.css" />	
		<link rel="stylesheet" type="text/css" href="../../../css/iscroll.css" />	
		<link rel="stylesheet" href="../css/search-bar.css" type="text/css"/>
		<link rel="stylesheet" type="text/css" href="../../../widget/artDialog/6.0.5/css/ui-dialog.min.css">
		<link rel="stylesheet" type="text/css" href="../../../widget/mobiscroll/2.15.1/css/mobiscroll.css">
		<link rel="stylesheet" type="text/css" href="../../../widget/photoswipe/photoswipe.css">
		<link rel="stylesheet" type="text/css" href="../../../widget/photoswipe/default-skin/default-skin.css">
		<link rel="stylesheet" type="text/css" href="../css/shangchuanjiuzhenjilu-edit.css">
	</head>
	<body>
		<div class="c-main">
			<div class="wis-fix c-border-b mt15">
				<ul class="c-list patient-list c-border-t mt" data-list="patientInfo">
					<li>
						<div class="c-list-value pr30 ptb5" >
							<h4><img src="../images/jiuzhenxinxi_icon.png" style="width: 20px; height: 20px; margin-top:2px; margin-right: 5px;"/>就诊信息</h4>
						</div>
					</li>
					<li>
						<div class="c-list-value pr30" style="width: 80px;">
							<h4><em class="required"></em>就诊时间</h4>
						</div>
						<div class="c-list-info">
							<div class="input-group width-100">
								<input type="text" class="form-control width-100 no-border c-t-right" placeholder="请选择就诊时间" style="background: #FFFFFF;" data-time="date" value="" id="date">
								<span class="c-arrow-r"></span>
							</div>
						</div>
					</li>
					<li>
						<div class="c-list-value pr30" style="width: 80px;">
							<h4><em class="required"></em>就诊类型</h4>
						</div>
						<div class="c-list-info">
							<div class="input-group width-100">
								<input type="text" class="form-control width-100 no-border c-t-right" placeholder="请选择就诊类型" style="background: #FFFFFF;" data-val="" value="" id="type">
								<span class="c-arrow-r"></span>
							</div>
						</div>
					</li>
					<li>
						<div class="c-list-value pr30" style="width: 80px;">
							<h4><em class=""></em>就诊医院</h4>
						</div>
						<div class="c-list-info">
							<div class="input-group width-100">
								<input type="text" class="form-control width-100 no-border c-t-right" placeholder="请输入就诊医院" style="background: #FFFFFF;" data-val="" value="" id="hospital">
								<span class="c-arrow-r"></span>
							</div>
						</div>
					</li>
					<li>
						<div class="c-list-value pr30" style="width: 80px;">
							<h4><em class=""></em>就诊科室</h4>
						</div>
						<div class="c-list-info">
							<div class="input-group width-100">
								<input type="text" class="form-control width-100 no-border c-t-right" placeholder="请输入就诊科室" style="background: #FFFFFF;" data-val="" value="" id="dept">
								<span class="c-arrow-r"></span>
							</div>
						</div>
					</li>
					<li>
						<div class="c-list-value pr30" style="width: 80px;">
							<h4><em class=""></em>就诊医生</h4>
						</div>
						<div class="c-list-info">
							<div class="input-group width-100">
								<input type="text" class="form-control width-100 no-border c-t-right" placeholder="请输入诊治医生名称" style="background: #FFFFFF;" data-val="" value="" id="doc_name">
								<span class="c-arrow-r"></span>
							</div>
						</div>
					</li>
				</ul>
			</div>
			<div class="wis-fix c-border-b mt15">
				<ul class="c-list patient-list c-border-t " >
					<li>
						<div class="c-list-value pr30 ptb5" >
							<h4><img src="../images/zhenduanjieguo_icon.png" style="width: 20px; height: 20px; margin-top:2px; margin-right: 5px;"/>诊断结果</h4>
						</div>
					</li>
					<li class="ptb12">
						<div class="c-list-value" style="min-width: initial;">
							<!--<h4><em class="required"></em></h4>-->
						</div>
                        <div class="c-list-info">
                            <input type="text" class="form-control width-100 no-border" placeholder="请输入诊断结果" style="background: #FFFFFF;" data-val="" value="" id="diag_input">
                        </div>
                        <div class="c-list-key">
                            <div id="add_diag" class="c-btn c-btn-tiny c-btn-radius c-btn-fff c-75bf00 c-border-75bf00">添加</div>
                        </div>
                    </li>
				</ul>
				<ul id="diagnosis" class="c-list">
                    
                </ul>
			</div>	
			<div class="mod mod-record mt15">
		    	<!--新增图片上传-->
				<ul class="n-list  c-border-tb">
					<li class="ptb12">
						<div class="n-list-key pr15 c-f16">上传病历图片</div>
						<div class="n-list-info c-t-right">
							<p class="c-ccc c-f12 c-t-right img-count" id="image_tips"></p>
						</div>
					</li>
					<li class="n-list-cover ptb12">
						<div class="upload-img mt10">
							<ul id="img_ul">
								<li id="add_img_li">
									<a href="javascript:;" class="add-btn" onclick="chooseImage()"></a>
								</li>
							</ul>
						</div>
					</li>
				</ul>
		   </div>
			<div class="bottom-box clearfix mt20 plr15 mb10">
				<div class="ui-grid">
			        <div class="ui-col-1 pr10"><a href="javascript:void(0);" id="delete_btn" class="c-btn-full c-btn-ff6a56 c-btn-radius fl c-f18">删除病历</a></div>
			        <div class="ui-col-1"><a href="javascript:void(0);"  id="save_btn" class="c-btn-full c-btn-75BF00 c-btn-radius fl c-f18">保存变更</a></div>
			    </div>
				
			</div>
		</div>
		<!-- Root element of PhotoSwipe. Must have class pswp. -->
		<div class="pswp" tabindex="-1" role="dialog" aria-hidden="true">
			<img id="set_type_ack" src="../images/xuanfuquedi_btn.png" style="position:absolute; top: 20px; right: 20px; width:50px;height:50px;z-index: 99;">
			</img>
		    <!-- Background of PhotoSwipe. 
		         It's a separate element as animating opacity is faster than rgba(). -->
		    <div class="pswp__bg"></div>
		
		    <!-- Slides wrapper with overflow:hidden. -->
		    <div class="pswp__scroll-wrap">
		
		        <!-- Container that holds slides. 
		            PhotoSwipe keeps only 3 of them in the DOM to save memory.
		            Don't modify these 3 pswp__item elements, data is added later on. -->
		        <div class="pswp__container">
		            <div class="pswp__item"></div>
		            <div class="pswp__item"></div>
		            <div class="pswp__item"></div>
		        </div>
		
		        <!-- Default (PhotoSwipeUI_Default) interface on top of sliding area. Can be changed. -->
		        <div class="pswp__ui pswp__ui--hidden">
		
		            <div class="pswp__top-bar" style="display: none;">
		                <!--  Controls are self-explanatory. Order can be changed. -->
		                <div class="pswp__counter"></div>
		                <button class="pswp__button pswp__button--close" title="Close (Esc)"></button>
		                <!-- Preloader demo http://codepen.io/dimsemenov/pen/yyBWoR -->
		                <!-- element will get class pswp__preloader--active when preloader is running -->
		                <div class="pswp__preloader">
		                    <div class="pswp__preloader__icn">
		                      <div class="pswp__preloader__cut">
		                        <div class="pswp__preloader__donut"></div>
		                      </div>
		                    </div>
		                </div>
		            </div>
		            <div class="pswp__caption">
		                <div class="pswp__caption__center"></div>
		            </div>
		
		        </div>
		
		    </div>
		    <div style="position: absolute; bottom: 0; width: 100%; background: #000; opacity: 0.8;">
				<ul class="n-list select-image-bar">
					<li class="ptb12">
						<div class="n-list-key pr15 c-f16 c-fff">请选择图片分类</div>
						<div class="n-list-info c-t-right">
							<p class="c-ccc c-f12 c-t-right img-count" id="image_counter">
								<span id="cur_page"></span><span class="c-74bf00">/</span><span id="amount_page" class="c-74bf00"></span>
							</p>
						</div>
					</li>
				</ul>
				<div class="pl10 pr10 mt10 pb10 img-catalog" style="border-bottom: 1px solid #909090;">
					<div class="ui-grid">
				        <div class="ui-col-1 pr10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="病历">病历</a></div>
				        <div class="ui-col-1 pr10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="处方">处方</a></div>
				        <div class="ui-col-1"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="病理报告">病理报告</a></div>
				    </div>
				    <div class="ui-grid mt10">
				        <div class="ui-col-1 pr10"><a href="javascript: void(0);" data-ref="jian_cha_types" class="c-btn-74bf00 c-btn-icon c-323232" data-type="检查报告"><i class="c-arrow-d"></i>检查报告</a></div>
				        <div class="ui-col-1 pr10"><a href="javascript: void(0);" data-ref="jian_yan_types" class="c-btn-74bf00 c-btn-icon c-323232" data-type="检验报告"><i class="c-arrow-d"></i>检验报告</a></a></div>
				        <div class="ui-col-1"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232"  data-type="其他">其他</a></div>
				    </div>
				</div>
				<div id="jian_cha_types" class="pl10 pr10 mb10 c-hide sub-catalog clearfix" >
					<div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="超声">超声</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="CR">CR</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="DR">DR</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="CT">CT</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="MR">MR</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="消化内镜">消化内镜</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:;" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="其他">其他</a></div>
				</div> 
				<div id="jian_yan_types" class="pl10 pr10 mb10 c-hide sub-catalog clearfix" >
					<div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="血液">血液</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="细菌培养">细菌培养</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="尿液">尿液</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="粪便">粪便</a></div>
					<div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="分泌物">分泌物</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="其他">其他</a></div>
				</div> 
			</div>
		</div>
		
		<script src="../../../js/jquery/2.1.3/jquery.js"></script>
		<script src="../../../js/app.js" type="text/javascript" charset="utf-8"></script>
		<script type="text/javascript" src="../../../js/mui.min.js"></script>
		<script src="../../../widget/artDialog/6.0.5/js/dialog-plus.min.js"></script>
		<script src="../../../widget/marques/marquee.js"></script>
		<script src="../../../js/es6-promise.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/underscore.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/template.js"></script>
		<script type="text/javascript" src="../../../js/common_http.js" ></script>
		<script type="text/javascript" src="../../../js/weixin_common.js" ></script>
		<script src="../../../widget/mobiscroll/2.15.1/js/mobiscroll.js"></script>
		<script src="../../../js/iscroll-probe.js"></script>
		<script src="http://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script>
		<script src="../../../js/iscroll-pull-up-down.js"></script>
		<script src="../js/upload-file.js"></script>
		<script src="../../../widget/photoswipe/photoswipe.min.js"></script>
		<script src="../../../widget/photoswipe/photoswipe-ui-default.min.js"></script>
		<script src="../js/shangchuanjiuzhenjilu-edit.js"></script>
	</body>
</html>

+ 261 - 0
html/jkda/html/shangchuanjiuzhenjilu.html

@ -0,0 +1,261 @@
<!DOCTYPE html>
<html>
	<head>
		<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
		<meta charset="utf-8">
		<title>上传就诊记录</title>
		<link rel="stylesheet" type="text/css" href="../../../css/cross.css" />
		<link rel="stylesheet" type="text/css" href="../../../iconfont/iconfont.css" />
		<link rel="stylesheet" type="text/css" href="../css/ss-style.css" />
		<link rel="stylesheet" type="text/css" href="../../../css/cross.ui.css">
		<link rel="stylesheet" type="text/css" href="../css/zx-style.css">		
		<link rel="stylesheet" type="text/css" href="../../../css/iscroll.css" />	
		<link rel="stylesheet" type="text/css" href="../../../widget/artDialog/6.0.5/css/ui-dialog.min.css">
		<link rel="stylesheet" type="text/css" href="../../../widget/mobiscroll/2.15.1/css/mobiscroll.css">
		<link rel="stylesheet" type="text/css" href="../../../widget/photoswipe/photoswipe.css">
		<link rel="stylesheet" type="text/css" href="../../../widget/photoswipe/default-skin/default-skin.css">
		<link rel="stylesheet" type="text/css" href="../css/shangchuanjiuzhenjilu.css?v=1.3.4">
	</head>
	<body>
		<div class="c-main">
			<div class="wis-fix c-border-b mt15">
				<ul class="c-list patient-list c-border-t" data-list="patientInfo">
					<li>
						<div class="c-list-value pr30 ptb5" >
							<h4><img src="../images/jiuzhenxinxi_icon.png" style="width: 20px; height: 20px; margin-top:2px; margin-right: 5px;"/>就诊信息</h4>
						</div>
					</li>
					<li>
						<div class="c-list-value pr30" style="width: 80px;">
							<h4><em class="required"></em>就诊时间</h4>
						</div>
						<div class="c-list-info">
							<div class="input-group width-100">
								<input type="text" class="form-control width-100 no-border c-t-right" placeholder="请选择就诊时间" style="background: #FFFFFF;" data-time="date" value="" id="date">
								<span class="c-arrow-r"></span>
							</div>
						</div>
					</li>
					<li>
						<div class="c-list-value pr30" style="width: 80px;">
							<h4><em class="required"></em>就诊人员</h4>
						</div>
						<div class="c-list-info">
							<div class="input-group width-100">
								<input type="text" readonly="readonly" class="form-control width-100 no-border c-t-right" style="background: #FFFFFF;" data-val="" value="" id="member">
							</div>
						</div>
					</li>
					<li>
						<div class="c-list-value pr30" style="width: 80px;">
							<h4><em class="required"></em>就诊类型</h4>
						</div>
						<div class="c-list-info">
							<div class="input-group width-100">
								<input type="text" class="form-control width-100 no-border c-t-right" placeholder="请选择就诊类型" style="background: #FFFFFF;" data-val="" value="" id="type">
								<span class="c-arrow-r"></span>
							</div>
						</div>
					</li>
					<li>
						<div class="c-list-value pr30" style="width: 80px;">
							<h4><em class=""></em>就诊医院</h4>
						</div>
						<div class="c-list-info">
							<div class="input-group width-100">
								<input type="text" class="form-control width-100 no-border c-t-right" placeholder="请输入就诊医院" style="background: #FFFFFF;" data-val="" value="" id="hospital">
								<span class="c-arrow-r"></span>
							</div>
						</div>
					</li>
					<li>
						<div class="c-list-value pr30" style="width: 80px;">
							<h4><em class=""></em>就诊科室</h4>
						</div>
						<div class="c-list-info">
							<div class="input-group width-100">
								<input type="text" class="form-control width-100 no-border c-t-right" placeholder="请输入就诊科室" style="background: #FFFFFF;" data-val="" value="" id="dept">
								<span class="c-arrow-r"></span>
							</div>
						</div>
					</li>
					<li>
						<div class="c-list-value pr30" style="width: 80px;">
							<h4><em class=""></em>就诊医生</h4>
						</div>
						<div class="c-list-info">
							<div class="input-group width-100">
								<input type="text" class="form-control width-100 no-border c-t-right" placeholder="请输入诊治医生名称" style="background: #FFFFFF;" data-val="" value="" id="doc_name">
								<span class="c-arrow-r"></span>
							</div>
						</div>
					</li>
				</ul>
			</div>
			<div class="wis-fix c-border-b mt15">
				<ul class="c-list patient-list c-border-t" >
					<li>
						<div class="c-list-value pr30 ptb5" >
							<h4><img src="../images/zhenduanjieguo_icon.png" style="width: 20px; height: 20px; margin-top:2px; margin-right: 5px;"/>诊断结果</h4>
						</div>
					</li>
					<li class="ptb12">
						<div class="c-list-value" style="min-width: initial;">
							<!--<h4><em class="required"></em></h4>-->
						</div>
                        <div class="c-list-info">
                            <input type="text" class="form-control width-100 no-border" placeholder="请输入诊断结果" style="background: #FFFFFF;" data-val="" value="" id="diag_input">
                        </div>
                        <div class="c-list-key">
                            <div id="add_diag" class="c-btn c-btn-tiny c-btn-radius c-btn-fff c-75bf00 c-border-75bf00">添加</div>
                        </div>
                    </li>
				</ul>
				<ul id="diagnosis" class="c-list c-border-tb">
                    
                </ul>
			</div>	
			<div class="mod mod-record mt15">
		    	<!--新增图片上传-->
				<ul class="n-list">
					<li class="ptb12">
						<div class="n-list-key pr15 c-f16">上传病历图片</div>
						<div class="n-list-info c-t-right">
							<p class="c-ccc c-f12 c-t-right img-count" id="image_tips"></p>
						</div>
					</li>
					<li class="n-list-cover ptb12">
						<div class="upload-img mt10">
							<ul id="img_ul">
								<!--<li>
									<img src="https://farm4.staticflickr.com/3894/15008518202_b016d7d289_m.jpg">
									<div class="del-wrap">
										<img src="../images/shanchu01_btn.png" class="del-icon"/>
									</div>
									<p class="catalog-name">sdafsdfdasfa</p>
								</li>
								<li>
									<img src="https://farm6.staticflickr.com/5591/15008867125_68a8ed88cc_m.jpg">
									
								</li>-->
								<li id="add_img_li">
									<a href="javascript:;" class="add-btn" onclick="chooseImage()"></a>
								</li>
							</ul>
						</div>
					</li>
				</ul>
		   </div>
			<div class="bottom-box clearfix mt20 plr15 mb10">
				<a id="save_btn" href="javascript:void(0);"  class="c-btn-full c-btn-75BF00 c-btn-radius fl c-f18">保存</a>
			</div>
		</div>
		<!-- Root element of PhotoSwipe. Must have class pswp. -->
		<div class="pswp" tabindex="-1" role="dialog" aria-hidden="true">
			<img id="set_type_ack" src="../images/xuanfuquedi_btn.png" style="position:absolute; top: 20px; right: 20px; width:50px;height:50px;z-index: 99;">
			</img>
		    <!-- Background of PhotoSwipe. 
		         It's a separate element as animating opacity is faster than rgba(). -->
		    <div class="pswp__bg"></div>
		
		    <!-- Slides wrapper with overflow:hidden. -->
		    <div class="pswp__scroll-wrap">
		
		        <!-- Container that holds slides. 
		            PhotoSwipe keeps only 3 of them in the DOM to save memory.
		            Don't modify these 3 pswp__item elements, data is added later on. -->
		        <div class="pswp__container">
		            <div class="pswp__item"></div>
		            <div class="pswp__item"></div>
		            <div class="pswp__item"></div>
		        </div>
		
		        <!-- Default (PhotoSwipeUI_Default) interface on top of sliding area. Can be changed. -->
		        <div class="pswp__ui pswp__ui--hidden">
		
		            <div class="pswp__top-bar" style="display: none;">
		                <!--  Controls are self-explanatory. Order can be changed. -->
		                <div class="pswp__counter"></div>
		                <button class="pswp__button pswp__button--close" title="Close (Esc)"></button>
		                <!-- Preloader demo http://codepen.io/dimsemenov/pen/yyBWoR -->
		                <!-- element will get class pswp__preloader--active when preloader is running -->
		                <div class="pswp__preloader">
		                    <div class="pswp__preloader__icn">
		                      <div class="pswp__preloader__cut">
		                        <div class="pswp__preloader__donut"></div>
		                      </div>
		                    </div>
		                </div>
		            </div>
		            <div class="pswp__caption">
		                <div class="pswp__caption__center"></div>
		            </div>
		
		        </div>
		
		    </div>
		    <div style="position: absolute; bottom: 0; width: 100%; background: #000; opacity: 0.8;">
				<ul class="n-list select-image-bar">
					<li class="ptb12">
						<div class="n-list-key pr15 c-f16 c-fff">请选择图片分类</div>
						<div class="n-list-info c-t-right">
							<p class="c-ccc c-f12 c-t-right img-count" id="image_counter">
								<span id="cur_page"></span><span class="c-74bf00">/</span><span id="amount_page" class="c-74bf00"></span>
							</p>
						</div>
					</li>
				</ul>
				<div class="pl10 pr10 mt10 pb10 img-catalog" style="border-bottom: 1px solid #909090;">
					<div class="ui-grid">
				        <div class="ui-col-1 pr10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="病历">病历</a></div>
				        <div class="ui-col-1 pr10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="处方">处方</a></div>
				        <div class="ui-col-1"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232" data-type="病理报告">病理报告</a></div>
				    </div>
				    <div class="ui-grid mt10">
				        <div class="ui-col-1 pr10"><a href="javascript: void(0);" data-ref="jian_cha_types" class="c-btn-74bf00 c-btn-icon c-323232" data-type="检查报告"><i class="c-arrow-d"></i>检查报告</a></div>
				        <div class="ui-col-1 pr10"><a href="javascript: void(0);" data-ref="jian_yan_types" class="c-btn-74bf00 c-btn-icon c-323232" data-type="检验报告"><i class="c-arrow-d"></i>检验报告</a></a></div>
				        <div class="ui-col-1"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232"  data-type="其他">其他</a></div>
				    </div>
				</div>
				<div id="jian_cha_types" class="pl10 pr10 mb10 c-hide sub-catalog clearfix" >
					<div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="超声">超声</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="CR">CR</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="DR">DR</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="CT">CT</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="MR">MR</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="消化内镜">消化内镜</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:;" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="其他">其他</a></div>
				</div> 
				<div id="jian_yan_types" class="pl10 pr10 mb10 c-hide sub-catalog clearfix" >
					<div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="血液">血液</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="细菌培养">细菌培养</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="尿液">尿液</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="粪便">粪便</a></div>
					<div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="分泌物">分泌物</a></div>
			        <div class="pr10 fl mt10"><a href="javascript:void(0);" class="c-btn-74bf00 c-btn-icon c-323232 c-f12" data-type="其他">其他</a></div>
				</div> 
			</div>
		</div>
		
		<script src="../../../js/jquery/2.1.3/jquery.js"></script>
		<script src="../../../js/app.js" type="text/javascript" charset="utf-8"></script>
		<script type="text/javascript" src="../../../js/mui.min.js"></script>
		<script src="../../../widget/artDialog/6.0.5/js/dialog-plus.min.js"></script>
		<script src="../../../widget/marques/marquee.js"></script>
		<script src="../../../js/es6-promise.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/underscore.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/template.js"></script>
		<script type="text/javascript" src="../../../js/common_http.js" ></script>
		<script type="text/javascript" src="../../../js/weixin_common.js" ></script>
		<script src="../../../widget/mobiscroll/2.15.1/js/mobiscroll.js"></script>
		<script src="../../../js/iscroll-probe.js"></script>
		<script src="http://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script>
		<script src="../../../js/iscroll-pull-up-down.js"></script>
		<script src="../js/upload-file.js"></script>
		<script src="../../../widget/photoswipe/photoswipe.min.js"></script>
		<script src="../../../widget/photoswipe/photoswipe-ui-default.min.js"></script>
		<script src="../../../js/family-members.js"></script>
		<script src="../js/shangchuanjiuzhenjilu.js?v=1.3.4"></script>
	</body>
</html>

+ 52 - 0
html/jkda/html/single-profile.html

@ -0,0 +1,52 @@
<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<meta name="author" content="yihu.com" />
		<meta name="format-detection" content="telephone=no" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0" />
		<meta name="apple-mobile-web-app-capable" content="yes" />
		<meta name="apple-mobile-web-app-status-bar-style" content="black" />
		<link rel="stylesheet" type="text/css" href="../../../iconfont/iconfont.css">
		<link rel="stylesheet" href="../../../css/cross.ui.css" type="text/css" />
		<link rel="stylesheet" type="text/css" href="../../../widget/artDialog/6.0.5/css/ui-dialog.min.css">
		<link rel="stylesheet" type="text/css" href="../../../css/iscroll.css" />	
		<link rel="stylesheet" type="text/css" href="../../../widget/mobiscroll/2.15.1/css/mobiscroll.css">
		<link rel="stylesheet" type="text/css" href="../css/base.css" />
		<link rel="stylesheet" type="text/css" href="../css/info.css" />
		<style type="text/css">
			#xiangqing_btn img { position:fixed; bottom:50px; right: 20px; width: 50px; height: 50px; z-index: 9999; }
		</style>
	</head>
	<body>
		<div class="h45">
			<div class="demo-comtop">
				<h1><span id="selected_profile_name"></span></h1>
			</div>
		</div>
		<div id="xiangqing_btn">
			<img src="../images/xuanfujiuzhenxiangqing_btn.png"/>
		</div>
		<div class="page-content"  ms-controller="viewController">
			
    	</div>
		
		<script src="../../../js/jquery/2.1.3/jquery.js"></script>
		<script src="../../../js/app.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../widget/artDialog/6.0.5/js/dialog-plus.min.js"></script>
		<script type="text/javascript" src="../../../js/common_http.js" ></script>
		<script type="text/javascript" src="../../../js/weixin_common.js" ></script>
		<script src="../../../js/es6-promise.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/underscore.js" type="text/javascript" charset="utf-8"></script>
		<script src="../../../js/template.js"></script>
		<script src="../../../widget/mobiscroll/2.15.1/js/mobiscroll.js"></script>
		<script src="../../../js/iscroll-probe.js"></script>
		<script src="http://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script>
		<script src="../../../js/iscroll-pull-up-down.js"></script>
		<script src="../../../js/pull-up-down.js"></script>
		<script src="../js/avalon.modern.js"></script>
		<script src="../js/single-profile.js"></script>
	</body>
</html>

BIN
html/jkda/images/baogaoxiangqing_icon.png


BIN
html/jkda/images/bingli_icon.png


BIN
html/jkda/images/binglibaogao_icon.png


BIN
html/jkda/images/bingqingmiaoshu_icon.png


BIN
html/jkda/images/checked_blue.png


BIN
html/jkda/images/chufang_icon.png


BIN
html/jkda/images/fenlei_btn.png


BIN
html/jkda/images/guanbi_btn.png


BIN
html/jkda/images/hongjiantou_icon.png


BIN
html/jkda/images/img/Rp.png


BIN
html/jkda/images/img/i-adm-sta.png


BIN
html/jkda/images/img/i-cli-dia.png


BIN
html/jkda/images/img/i-con-con.png


BIN
html/jkda/images/img/i-con-info.png


BIN
html/jkda/images/img/i-dia-basis.png


BIN
html/jkda/images/img/i-dia-rec.png


BIN
html/jkda/images/img/i-doc-info.png


BIN
html/jkda/images/img/i-down.png


BIN
html/jkda/images/img/i-drop-down.png


BIN
html/jkda/images/img/i-ess-info.png


BIN
html/jkda/images/img/i-hos-sum.png


BIN
html/jkda/images/img/i-ins-res.png


BIN
html/jkda/images/img/i-inspection-personnel.png


BIN
html/jkda/images/img/i-inspectors.png


BIN
html/jkda/images/img/i-ope-rec.png


BIN
html/jkda/images/img/i-pat-his.png


BIN
html/jkda/images/img/i-pat-info.png


BIN
html/jkda/images/img/i-pha-info.png


BIN
html/jkda/images/img/i-ref-info.png


BIN
html/jkda/images/img/i-switch.png


BIN
html/jkda/images/img/i-sym-rec.png


BIN
html/jkda/images/img/i-test-results.png


BIN
html/jkda/images/img/i-up.png


BIN
html/jkda/images/img/i-visiting-result.png


BIN
html/jkda/images/jianchabaogao_icon.png


BIN
html/jkda/images/jiankangxiangqing_icon.png


BIN
html/jkda/images/jianyanbaogao_icon.png


BIN
html/jkda/images/jianyanjieguo_icon.png


BIN
html/jkda/images/jiuzhenxinxi_icon.png


BIN
html/jkda/images/lvjiantou_icon.png


BIN
html/jkda/images/qita_icon.png


BIN
html/jkda/images/shanchu01_btn.png


BIN
html/jkda/images/shanchu02_btn.png


BIN
html/jkda/images/shou02_icon.png


BIN
html/jkda/images/shou_icon.png


BIN
html/jkda/images/shousuo_icon.png


BIN
html/jkda/images/shujuweikong_img.png


BIN
html/jkda/images/tianjiatupian_icon.png


BIN
html/jkda/images/weifenlei_icon.png


BIN
html/jkda/images/xuanfujiuzhenxiangqing_btn.png


BIN
html/jkda/images/xuanfuquedi_btn.png


BIN
html/jkda/images/xuanfutianjia_btn.png


BIN
html/jkda/images/xuanfuxiugai_btn.png


BIN
html/jkda/images/yingxiangjielun_icon.png


BIN
html/jkda/images/yingxiangshujian_icon.png


BIN
html/jkda/images/yiwen_btn.png


BIN
html/jkda/images/yiyuanjianzhu_icon.png


BIN
html/jkda/images/zhankai_icon.png


BIN
html/jkda/images/zhenduanjieguo_icon.png


+ 5788 - 0
html/jkda/js/avalon.modern.js

@ -0,0 +1,5788 @@
/*==================================================
 Copyright (c) 2013-2015 司徒正美 and other contributors
 http://www.cnblogs.com/rubylouvre/
 https://github.com/RubyLouvre
 http://weibo.com/jslouvre/
 
 Released under the MIT license
 avalon.modern.js 1.5.5 built in 2015.11.20
 support IE10+ and other browsers
 ==================================================*/
(function(global, factory) {
    if (typeof module === "object" && typeof module.exports === "object") {
        // For CommonJS and CommonJS-like environments where a proper `window`
        // is present, execute the factory and get avalon.
        // For environments that do not have a `window` with a `document`
        // (such as Node.js), expose a factory as module.exports.
        // This accentuates the need for the creation of a real `window`.
        // e.g. var avalon = require("avalon")(window);
        module.exports = global.document ? factory(global, true) : function(w) {
            if (!w.document) {
                throw new Error("Avalon requires a window with a document")
            }
            return factory(w)
        }
    } else {
        factory(global)
    }
// Pass this if window is not defined yet
}(typeof window !== "undefined" ? window : this, function(window, noGlobal){
/*********************************************************************
 *                    全局变量及方法                                  *
 **********************************************************************/
var expose = Date.now()
//http://stackoverflow.com/questions/7290086/javascript-use-strict-and-nicks-find-global-function
var DOC = window.document
var head = DOC.head //HEAD元素
head.insertAdjacentHTML("afterBegin", '<avalon ms-skip class="avalonHide"><style id="avalonStyle">.avalonHide{ display: none!important }</style></avalon>')
var ifGroup = head.firstChild
function log() {
    if (avalon.config.debug) {
// http://stackoverflow.com/questions/8785624/how-to-safely-wrap-console-log
        console.log.apply(console, arguments)
    }
}
/**
 * Creates a new object without a prototype. This object is useful for lookup without having to
 * guard against prototypically inherited properties via hasOwnProperty.
 *
 * Related micro-benchmarks:
 * - http://jsperf.com/object-create2
 * - http://jsperf.com/proto-map-lookup/2
 * - http://jsperf.com/for-in-vs-object-keys2
 */
function createMap() {
  return Object.create(null)
}
var subscribers = "$" + expose
var nullObject = {} //作用类似于noop,只用于代码防御,千万不要在它上面添加属性
var rword = /[^, ]+/g //切割字符串为一个个小块,以空格或豆号分开它们,结合replace实现字符串的forEach
var rw20g = /\w+/g
var rsvg = /^\[object SVG\w*Element\]$/
var rwindow = /^\[object (?:Window|DOMWindow|global)\]$/
var oproto = Object.prototype
var ohasOwn = oproto.hasOwnProperty
var serialize = oproto.toString
var ap = Array.prototype
var aslice = ap.slice
var W3C = window.dispatchEvent
var root = DOC.documentElement
var avalonFragment = DOC.createDocumentFragment()
var cinerator = DOC.createElement("div")
var class2type = {}
"Boolean Number String Function Array Date RegExp Object Error".replace(rword, function (name) {
    class2type["[object " + name + "]"] = name.toLowerCase()
})
function scpCompile(array){
    return Function.apply(noop,array)
}
function noop(){}
function oneObject(array, val) {
    if (typeof array === "string") {
        array = array.match(rword) || []
    }
    var result = {},
            value = val !== void 0 ? val : 1
    for (var i = 0, n = array.length; i < n; i++) {
        result[array[i]] = value
    }
    return result
}
//生成UUID http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript
var generateID = function (prefix) {
    prefix = prefix || "avalon"
    return String(Math.random() + Math.random()).replace(/\d\.\d{4}/, prefix)
}
function IE() {
    if (window.VBArray) {
        var mode = document.documentMode
        return mode ? mode : window.XMLHttpRequest ? 7 : 6
    } else {
        return NaN
    }
}
var IEVersion = IE()
avalon = function (el) { //创建jQuery式的无new 实例化结构
    return new avalon.init(el)
}
/*视浏览器情况采用最快的异步回调*/
avalon.nextTick = new function () {// jshint ignore:line
    var tickImmediate = window.setImmediate
    var tickObserver = window.MutationObserver
    if (tickImmediate) {
        return tickImmediate.bind(window)
    }
    var queue = []
    function callback() {
        var n = queue.length
        for (var i = 0; i < n; i++) {
            queue[i]()
        }
        queue = queue.slice(n)
    }
    if (tickObserver) {
        var node = document.createTextNode("avalon")
        new tickObserver(callback).observe(node, {characterData: true})// jshint ignore:line
        var bool = false
        return function (fn) {
            queue.push(fn)
            bool = !bool
            node.data = bool
        }
    }
    return function (fn) {
        setTimeout(fn, 4)
    }
}// jshint ignore:line
/*********************************************************************
 *                 avalon的静态方法定义区                              *
 **********************************************************************/
avalon.init = function (el) {
    this[0] = this.element = el
}
avalon.fn = avalon.prototype = avalon.init.prototype
avalon.type = function (obj) { //取得目标的类型
    if (obj == null) {
        return String(obj)
    }
    // 早期的webkit内核浏览器实现了已废弃的ecma262v4标准,可以将正则字面量当作函数使用,因此typeof在判定正则时会返回function
    return typeof obj === "object" || typeof obj === "function" ?
            class2type[serialize.call(obj)] || "object" :
            typeof obj
}
var isFunction = function (fn) {
    return serialize.call(fn) === "[object Function]"
}
avalon.isFunction = isFunction
avalon.isWindow = function (obj) {
    return rwindow.test(serialize.call(obj))
}
/*判定是否是一个朴素的javascript对象(Object),不是DOM对象,不是BOM对象,不是自定义类的实例*/
avalon.isPlainObject = function (obj) {
    // 简单的 typeof obj === "object"检测,会致使用isPlainObject(window)在opera下通不过
    return serialize.call(obj) === "[object Object]" && Object.getPrototypeOf(obj) === oproto
}
//与jQuery.extend方法,可用于浅拷贝,深拷贝
avalon.mix = avalon.fn.mix = function () {
    var options, name, src, copy, copyIsArray, clone,
            target = arguments[0] || {},
            i = 1,
            length = arguments.length,
            deep = false
    // 如果第一个参数为布尔,判定是否深拷贝
    if (typeof target === "boolean") {
        deep = target
        target = arguments[1] || {}
        i++
    }
    //确保接受方为一个复杂的数据类型
    if (typeof target !== "object" && !isFunction(target)) {
        target = {}
    }
    //如果只有一个参数,那么新成员添加于mix所在的对象上
    if (i === length) {
        target = this
        i--
    }
    for (; i < length; i++) {
        //只处理非空参数
        if ((options = arguments[i]) != null) {
            for (name in options) {
                src = target[name]
                copy = options[name]
                // 防止环引用
                if (target === copy) {
                    continue
                }
                if (deep && copy && (avalon.isPlainObject(copy) || (copyIsArray = Array.isArray(copy)))) {
                    if (copyIsArray) {
                        copyIsArray = false
                        clone = src && Array.isArray(src) ? src : []
                    } else {
                        clone = src && avalon.isPlainObject(src) ? src : {}
                    }
                    target[name] = avalon.mix(deep, clone, copy)
                } else if (copy !== void 0) {
                    target[name] = copy
                }
            }
        }
    }
    return target
}
function _number(a, len) { //用于模拟slice, splice的效果
    a = Math.floor(a) || 0
    return a < 0 ? Math.max(len + a, 0) : Math.min(a, len);
}
avalon.mix({
    rword: rword,
    subscribers: subscribers,
    version: 1.55,
    ui: {},
    log: log,
    slice: function (nodes, start, end) {
        return aslice.call(nodes, start, end)
    },
    noop: noop,
    /*如果不用Error对象封装一下,str在控制台下可能会乱码*/
    error: function (str, e) {
        throw new (e || Error)(str)// jshint ignore:line
    },
    /*将一个以空格或逗号隔开的字符串或数组,转换成一个键值都为1的对象*/
    oneObject: oneObject,
    /* avalon.range(10)
     => [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
     avalon.range(1, 11)
     => [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
     avalon.range(0, 30, 5)
     => [0, 5, 10, 15, 20, 25]
     avalon.range(0, -10, -1)
     => [0, -1, -2, -3, -4, -5, -6, -7, -8, -9]
     avalon.range(0)
     => []*/
    range: function (start, end, step) { // 用于生成整数数组
        step || (step = 1)
        if (end == null) {
            end = start || 0
            start = 0
        }
        var index = -1,
                length = Math.max(0, Math.ceil((end - start) / step)),
                result = new Array(length)
        while (++index < length) {
            result[index] = start
            start += step
        }
        return result
    },
    eventHooks: {},
    /*绑定事件*/
    bind: function (el, type, fn, phase) {
        var hooks = avalon.eventHooks
        var hook = hooks[type]
        if (typeof hook === "object") {
            type = hook.type || type
            phase = hook.phase || !!phase
            fn = hook.fn ? hook.fn(el, fn) : fn
        }
        el.addEventListener(type, fn, phase)
        return fn
    },
    /*卸载事件*/
    unbind: function (el, type, fn, phase) {
        var hooks = avalon.eventHooks
        var hook = hooks[type]
        var callback = fn || noop
        if (typeof hook === "object") {
            type = hook.type || type
            phase = hook.phase || !!phase
        }
        el.removeEventListener(type, callback, phase)
    },
    /*读写删除元素节点的样式*/
    css: function (node, name, value) {
        if (node instanceof avalon) {
            node = node[0]
        }
        var prop = /[_-]/.test(name) ? camelize(name) : name, fn
        name = avalon.cssName(prop) || prop
        if (value === void 0 || typeof value === "boolean") { //获取样式
            fn = cssHooks[prop + ":get"] || cssHooks["@:get"]
            if (name === "background") {
                name = "backgroundColor"
            }
            var val = fn(node, name)
            return value === true ? parseFloat(val) || 0 : val
        } else if (value === "") { //请除样式
            node.style[name] = ""
        } else { //设置样式
            if (value == null || value !== value) {
                return
            }
            if (isFinite(value) && !avalon.cssNumber[prop]) {
                value += "px"
            }
            fn = cssHooks[prop + ":set"] || cssHooks["@:set"]
            fn(node, name, value)
        }
    },
    /*遍历数组与对象,回调的第一个参数为索引或键名,第二个或元素或键值*/
    each: function (obj, fn) {
        if (obj) { //排除null, undefined
            var i = 0
            if (isArrayLike(obj)) {
                for (var n = obj.length; i < n; i++) {
                    if (fn(i, obj[i]) === false)
                        break
                }
            } else {
                for (i in obj) {
                    if (obj.hasOwnProperty(i) && fn(i, obj[i]) === false) {
                        break
                    }
                }
            }
        }
    },
    //收集元素的data-{{prefix}}-*属性,并转换为对象
    getWidgetData: function (elem, prefix) {
        var raw = avalon(elem).data()
        var result = {}
        for (var i in raw) {
            if (i.indexOf(prefix) === 0) {
                result[i.replace(prefix, "").replace(/\w/, function (a) {
                    return a.toLowerCase()
                })] = raw[i]
            }
        }
        return result
    },
    Array: {
        /*只有当前数组不存在此元素时只添加它*/
        ensure: function (target, item) {
            if (target.indexOf(item) === -1) {
                return target.push(item)
            }
        },
        /*移除数组中指定位置的元素,返回布尔表示成功与否*/
        removeAt: function (target, index) {
            return !!target.splice(index, 1).length
        },
        /*移除数组中第一个匹配传参的那个元素,返回布尔表示成功与否*/
        remove: function (target, item) {
            var index = target.indexOf(item)
            if (~index)
                return avalon.Array.removeAt(target, index)
            return false
        }
    }
})
var bindingHandlers = avalon.bindingHandlers = {}
var bindingExecutors = avalon.bindingExecutors = {}
var directives = avalon.directives = {}
avalon.directive = function (name, obj) {
    bindingHandlers[name] = obj.init = (obj.init || noop)
    bindingExecutors[name] = obj.update = (obj.update || noop)
    return directives[name] = obj
}
/*判定是否类数组,如节点集合,纯数组,arguments与拥有非负整数的length属性的纯JS对象*/
function isArrayLike(obj) {
    if (obj && typeof obj === "object") {
        var n = obj.length,
                str = serialize.call(obj)
        if (/(Array|List|Collection|Map|Arguments)\]$/.test(str)) {
            return true
        } else if (str === "[object Object]" && n === (n >>> 0)) {
            return true //由于ecma262v5能修改对象属性的enumerable,因此不能用propertyIsEnumerable来判定了
        }
    }
    return false
}
// https://github.com/rsms/js-lru
var Cache = new function() {// jshint ignore:line
    function LRU(maxLength) {
        this.size = 0
        this.limit = maxLength
        this.head = this.tail = void 0
        this._keymap = {}
    }
    var p = LRU.prototype
    p.put = function(key, value) {
        var entry = {
            key: key,
            value: value
        }
        this._keymap[key] = entry
        if (this.tail) {
            this.tail.newer = entry
            entry.older = this.tail
        } else {
            this.head = entry
        }
        this.tail = entry
        if (this.size === this.limit) {
            this.shift()
        } else {
            this.size++
        }
        return value
    }
    p.shift = function() {
        var entry = this.head
        if (entry) {
            this.head = this.head.newer
            this.head.older =
                    entry.newer =
                    entry.older =
                    this._keymap[entry.key] = void 0
             delete this._keymap[entry.key] //#1029
        }
    }
    p.get = function(key) {
        var entry = this._keymap[key]
        if (entry === void 0)
            return
        if (entry === this.tail) {
            return  entry.value
        }
        // HEAD--------------TAIL
        //   <.older   .newer>
        //  <--- add direction --
        //   A  B  C  <D>  E
        if (entry.newer) {
            if (entry === this.head) {
                this.head = entry.newer
            }
            entry.newer.older = entry.older // C <-- E.
        }
        if (entry.older) {
            entry.older.newer = entry.newer // C. --> E
        }
        entry.newer = void 0 // D --x
        entry.older = this.tail // D. --> E
        if (this.tail) {
            this.tail.newer = entry // E. <-- D
        }
        this.tail = entry
        return entry.value
    }
    return LRU
}// jshint ignore:line
/*********************************************************************
 *                           DOM 底层补丁                             *
 **********************************************************************/
//safari5+是把contains方法放在Element.prototype上而不是Node.prototype
if (!DOC.contains) {
    Node.prototype.contains = function (arg) {
        return !!(this.compareDocumentPosition(arg) & 16)
    }
}
avalon.contains = function (root, el) {
    try {
        while ((el = el.parentNode))
            if (el === root)
                return true
        return false
    } catch (e) {
        return false
    }
}
if (window.SVGElement) {
    var svgns = "http://www.w3.org/2000/svg"
    var svg = DOC.createElementNS(svgns, "svg")
    svg.innerHTML = '<circle cx="50" cy="50" r="40" fill="red" />'
    if (!rsvg.test(svg.firstChild)) {// #409
        /* jshint ignore:start */
        function enumerateNode(node, targetNode) {
            if (node && node.childNodes) {
                var nodes = node.childNodes
                for (var i = 0, el; el = nodes[i++]; ) {
                    if (el.tagName) {
                        var svg = DOC.createElementNS(svgns,
                                el.tagName.toLowerCase())
                        // copy attrs
                        ap.forEach.call(el.attributes, function (attr) {
                            svg.setAttribute(attr.name, attr.value)
                        })
                        // 递归处理子节点
                        enumerateNode(el, svg)
                        targetNode.appendChild(svg)
                    }
                }
            }
        }
        /* jshint ignore:end */
        Object.defineProperties(SVGElement.prototype, {
            "outerHTML": {//IE9-11,firefox不支持SVG元素的innerHTML,outerHTML属性
                enumerable: true,
                configurable: true,
                get: function () {
                    return new XMLSerializer().serializeToString(this)
                },
                set: function (html) {
                    var tagName = this.tagName.toLowerCase(),
                            par = this.parentNode,
                            frag = avalon.parseHTML(html)
                    // 操作的svg,直接插入
                    if (tagName === "svg") {
                        par.insertBefore(frag, this)
                        // svg节点的子节点类似
                    } else {
                        var newFrag = DOC.createDocumentFragment()
                        enumerateNode(frag, newFrag)
                        par.insertBefore(newFrag, this)
                    }
                    par.removeChild(this)
                }
            },
            "innerHTML": {
                enumerable: true,
                configurable: true,
                get: function () {
                    var s = this.outerHTML
                    var ropen = new RegExp("<" + this.nodeName + '\\b(?:(["\'])[^"]*?(\\1)|[^>])*>', "i")
                    var rclose = new RegExp("<\/" + this.nodeName + ">$", "i")
                    return  s.replace(ropen, "").replace(rclose, "")
                },
                set: function (html) {
                    if (avalon.clearHTML) {
                        avalon.clearHTML(this)
                        var frag = avalon.parseHTML(html)
                        enumerateNode(frag, this)
                    }
                }
            }
        })
    }
}
//========================= event binding ====================
var eventHooks = avalon.eventHooks
//针对firefox, chrome修正mouseenter, mouseleave(chrome30+)
if (!("onmouseenter" in root)) {
    avalon.each({
        mouseenter: "mouseover",
        mouseleave: "mouseout"
    }, function (origType, fixType) {
        eventHooks[origType] = {
            type: fixType,
            fn: function (elem, fn) {
                return function (e) {
                    var t = e.relatedTarget
                    if (!t || (t !== elem && !(elem.compareDocumentPosition(t) & 16))) {
                        delete e.type
                        e.type = origType
                        return fn.call(elem, e)
                    }
                }
            }
        }
    })
}
//针对IE9+, w3c修正animationend
avalon.each({
    AnimationEvent: "animationend",
    WebKitAnimationEvent: "webkitAnimationEnd"
}, function (construct, fixType) {
    if (window[construct] && !eventHooks.animationend) {
        eventHooks.animationend = {
            type: fixType
        }
    }
})
if (DOC.onmousewheel === void 0) {
    /* IE6-11 chrome mousewheel wheelDetla 下 -120 上 120
     firefox DOMMouseScroll detail 下3 上-3
     firefox wheel detlaY 下3 上-3
     IE9-11 wheel deltaY 下40 上-40
     chrome wheel deltaY 下100 上-100 */
    eventHooks.mousewheel = {
        type: "wheel",
        fn: function (elem, fn) {
            return function (e) {
                e.wheelDeltaY = e.wheelDelta = e.deltaY > 0 ? -120 : 120
                e.wheelDeltaX = 0
                Object.defineProperty(e, "type", {
                    value: "mousewheel"
                })
                fn.call(elem, e)
            }
        }
    }
}
/*********************************************************************
 *                           配置系统                                 *
 **********************************************************************/
function kernel(settings) {
    for (var p in settings) {
        if (!ohasOwn.call(settings, p))
            continue
        var val = settings[p]
        if (typeof kernel.plugins[p] === "function") {
            kernel.plugins[p](val)
        } else if (typeof kernel[p] === "object") {
            avalon.mix(kernel[p], val)
        } else {
            kernel[p] = val
        }
    }
    return this
}
var openTag, closeTag, rexpr, rexprg, rbind, rregexp = /[-.*+?^${}()|[\]\/\\]/g
function escapeRegExp(target) {
    //http://stevenlevithan.com/regex/xregexp/
    //将字符串安全格式化为正则表达式的源码
    return (target + "").replace(rregexp, "\\$&")
}
var plugins = {
    interpolate: function (array) {
        openTag = array[0]
        closeTag = array[1]
        if (openTag === closeTag) {
            throw new SyntaxError("openTag!==closeTag")
            var test = openTag + "test" + closeTag
            cinerator.innerHTML = test
            if (cinerator.innerHTML !== test && cinerator.innerHTML.indexOf("&lt;") > -1) {
                throw new SyntaxError("此定界符不合法")
            }
            cinerator.innerHTML = ""
        }
         kernel.openTag = openTag
            kernel.closeTag = closeTag
        var o = escapeRegExp(openTag),
                c = escapeRegExp(closeTag)
        rexpr = new RegExp(o + "(.*?)" + c)
        rexprg = new RegExp(o + "(.*?)" + c, "g")
        rbind = new RegExp(o + ".*?" + c + "|\\sms-")
    }
}
kernel.async =true
kernel.debug = true
kernel.plugins = plugins
kernel.plugins['interpolate'](["{{", "}}"])
kernel.paths = {}
kernel.shim = {}
kernel.maxRepeatSize = 100
avalon.config = kernel
function $watch(expr, binding) {
    var $events = this.$events || (this.$events = {})
    var queue = $events[expr] || ($events[expr] = [])
    if (typeof binding === "function") {
        var backup = binding
        backup.uniqueNumber = Math.random()
        binding = {
            element: root,
            type: "user-watcher",
            handler: noop,
            vmodels: [this],
            expr: expr,
            uniqueNumber: backup.uniqueNumber
        }
        binding.wildcard = /\*/.test(expr)
    }
    if (!binding.update) {
        if (/\w\.*\B/.test(expr)) {
            binding.getter = noop
            var host = this
            binding.update = function () {
                var args = this.fireArgs || []
                if (args[2])
                    binding.handler.apply(host, args)
                delete this.fireArgs
            }
            queue.sync = true
            avalon.Array.ensure(queue, binding)
        } else {
            avalon.injectBinding(binding)
        }
        if (backup) {
            binding.handler = backup
        }
    } else if (!binding.oneTime) {
        avalon.Array.ensure(queue, binding)
    }
    return function () {
        binding.update = binding.getter = binding.handler = noop
        binding.element = DOC.createElement("a")
    }
}
function $emit(key, args) {
    var event = this.$events
    if (event && event[key]) {
        if (args) {
            args[2] = key
        }
        var arr = event[key]
        notifySubscribers(arr, args)
        var parent = this.$up
        if (parent) {
            if (this.$pathname) {
                $emit.call(parent, this.$pathname + "." + key, args)//以确切的值往上冒泡
            }
            $emit.call(parent, "*." + key, args)//以模糊的值往上冒泡
        }
    } else {
        parent = this.$up
       
        if(this.$ups ){
            for(var i in this.$ups){
                $emit.call(this.$ups[i], i+"."+key, args)//以确切的值往上冒泡
            }
            return
        }
        if (parent) {
            var p = this.$pathname
            if (p === "")
                p = "*"
            var path = p + "." + key
            arr = path.split(".")
            if (arr.indexOf("*") === -1) {
                $emit.call(parent, path, args)//以确切的值往上冒泡
                arr[1] = "*"
                $emit.call(parent, arr.join("."), args)//以模糊的值往上冒泡
            } else {
                $emit.call(parent, path, args)//以确切的值往上冒泡
            }
        }
    }
}
function collectDependency(el, key) {
    do {
        if (el.$watch) {
            var e = el.$events || (el.$events = {})
            var array = e[key] || (e[key] = [])
            dependencyDetection.collectDependency(array)
            return
        }
        el = el.$up
        if (el) {
            key = el.$pathname + "." + key
        } else {
            break
        }
    } while (true)
}
function notifySubscribers(subs, args) {
    if (!subs)
        return
    if (new Date() - beginTime > 444 && typeof subs[0] === "object") {
        rejectDisposeQueue()
    }
    var users = [], renders = []
    for (var i = 0, sub; sub = subs[i++]; ) {
        if (sub.type === "user-watcher") {
            users.push(sub)
        } else {
            renders.push(sub)
        }
    }
    if (kernel.async) {
        buffer.render()//1
        for (i = 0; sub = renders[i++]; ) {
            if (sub.update) {
                var uuid = getUid(sub)
                if (!buffer.queue[uuid]) {
                    buffer.queue[uuid] = 1
                    buffer.queue.push(sub)
                }
            }
        }
    } else {
        for (i = 0; sub = renders[i++]; ) {
            if (sub.update) {
                sub.update()//最小化刷新DOM树
            }
        }
    }
    for (i = 0; sub = users[i++]; ) {
        if (args && args[2] === sub.expr || sub.wildcard) {
            sub.fireArgs = args
        }
        sub.update()
    }
}
//avalon最核心的方法的两个方法之一(另一个是avalon.scan),返回一个ViewModel(VM)
var VMODELS = avalon.vmodels = {} //所有vmodel都储存在这里
avalon.define = function (source) {
    var $id = source.$id
    if (!$id) {
        log("warning: vm必须指定$id")
    }
    var vmodel = modelFactory(source)
    vmodel.$id = $id
    return VMODELS[$id] = vmodel
}
//一些不需要被监听的属性
var $$skipArray = oneObject("$id,$watch,$fire,$events,$model,$skipArray,$active,$pathname,$up,$ups,$track,$accessors")
//如果浏览器不支持ecma262v5的Object.defineProperties或者存在BUG,比如IE8
//标准浏览器使用__defineGetter__, __defineSetter__实现
function modelFactory(source, options) {
    options = options || {}
    options.watch = true
    return observeObject(source, options)
}
//监听对象属性值的变化(注意,数组元素不是数组的属性),通过对劫持当前对象的访问器实现
//监听对象或数组的结构变化, 对对象的键值对进行增删重排, 或对数组的进行增删重排,都属于这范畴
//   通过比较前后代理VM顺序实现
function Component() {
}
function observeObject(source, options) {
    if (!source || (source.$id && source.$accessors) || (source.nodeName && source.nodeType > 0)) {
        return source
    }
    //source为原对象,不能是元素节点或null
    //options,可选,配置对象,里面有old, force, watch这三个属性
    options = options || nullObject
    var force = options.force || nullObject
    var old = options.old
    var oldAccessors = old && old.$accessors || nullObject
    var $vmodel = new Component() //要返回的对象, 它在IE6-8下可能被偷龙转凤
    var accessors = {} //监控属性
    var hasOwn = {}
    var skip = []
    var simple = []
    var $skipArray = {}
    if (source.$skipArray) {
        $skipArray = oneObject(source.$skipArray)
        delete source.$skipArray
    }
    //处理计算属性
    var computed = source.$computed
    if (computed) {
        delete source.$computed
        for (var name in computed) {
            hasOwn[name] = true;
            (function (key, value) {
                var old
                accessors[key] = {
                    get: function () {
                        return old = value.get.call(this)
                    },
                    set: function (x) {
                        if (typeof value.set === "function") {
                            var older = old
                            value.set.call(this, x)
                            var newer = this[key]
                            if (this.$fire && (newer !== older)) {
                                this.$fire(key, newer, older)
                            }
                        }
                    },
                    enumerable: true,
                    configurable: true
                }
            })(name, computed[name])// jshint ignore:line
        }
    }
    for (name in source) {
        var value = source[name]
        if (!$$skipArray[name])
            hasOwn[name] = true
        if (typeof value === "function" || (value && value.nodeName && value.nodeType > 0) ||
                (!force[name] && (name.charAt(0) === "$" || $$skipArray[name] || $skipArray[name]))) {
            skip.push(name)
        } else if (isComputed(value)) {
            log("warning:计算属性建议放在$computed对象中统一定义");
            (function (key, value) {
                var old
                accessors[key] = {
                    get: function () {
                        return old = value.get.call(this)
                    },
                    set: function (x) {
                        if (typeof value.set === "function") {
                            var older = old
                            value.set.call(this, x)
                            var newer = this[key]
                            if (this.$fire && (newer !== older)) {
                                this.$fire(key, newer, older)
                            }
                        }
                    },
                    enumerable: true,
                    configurable: true
                }
            })(name, value)// jshint ignore:line
        } else {
            simple.push(name)
            if (oldAccessors[name]) {
                accessors[name] = oldAccessors[name]
            } else {
                accessors[name] = makeGetSet(name, value)
            }
        }
    }
    accessors["$model"] = $modelDescriptor
    $vmodel = Object.defineProperties($vmodel, accessors, source)
    function trackBy(name) {
        return hasOwn[name] === true
    }
    skip.forEach(function (name) {
        $vmodel[name] = source[name]
    })
    /* jshint ignore:start */
    hideProperty($vmodel, "$ups", null)
    hideProperty($vmodel, "$id", "anonymous")
    hideProperty($vmodel, "$up", old ? old.$up : null)
    hideProperty($vmodel, "$track", Object.keys(hasOwn))
    hideProperty($vmodel, "$active", false)
    hideProperty($vmodel, "$pathname", old ? old.$pathname : "")
    hideProperty($vmodel, "$accessors", accessors)
    hideProperty($vmodel, "hasOwnProperty", trackBy)
    if (options.watch) {
        hideProperty($vmodel, "$watch", function () {
            return $watch.apply($vmodel, arguments)
        })
        hideProperty($vmodel, "$fire", function (path, a) {
            if (path.indexOf("all!") === 0) {
                var ee = path.slice(4)
                for (var i in avalon.vmodels) {
                    var v = avalon.vmodels[i]
                    v.$fire && v.$fire.apply(v, [ee, a])
                }
            } else {
                $emit.call($vmodel, path, [a])
            }
        })
    }
    /* jshint ignore:end */
    //必须设置了$active,$events
    simple.forEach(function (name) {
        var oldVal = old && old[name]
        var val = $vmodel[name] = source[name]
        if (val && typeof val === "object") {
            val.$up = $vmodel
            val.$pathname = name
        }
        $emit.call($vmodel, name,[val,oldVal])
    })
    for (name in computed) {
        value = $vmodel[name]
    }
    $vmodel.$active = true
    return $vmodel
}
/*
 新的VM拥有如下私有属性
 $id: vm.id
 $events: 放置$watch回调与绑定对象
 $watch: 增强版$watch
 $fire: 触发$watch回调
 $track:一个数组,里面包含用户定义的所有键名
 $active:boolean,false时防止依赖收集
 $model:返回一个纯净的JS对象
 $accessors:放置所有读写器的数据描述对象
 $up:返回其上级对象
 $pathname:返回此对象在上级对象的名字,注意,数组元素的$pathname为空字符串
 =============================
 $skipArray:用于指定不可监听的属性,但VM生成是没有此属性的
 */
function isComputed(val) {//speed up!
    if (val && typeof val === "object") {
        for (var i in val) {
            if (i !== "get" && i !== "set") {
                return false
            }
        }
        return  typeof val.get === "function"
    }
}
function makeGetSet(key, value) {
    var childVm, value = NaN
    return {
        get: function () {
            if (this.$active) {
                collectDependency(this, key)
            }
            return value
        },
        set: function (newVal) {
            if (value === newVal)
                return
            var oldValue = value
            childVm = observe(newVal, value)
            if (childVm) {
                value = childVm
            } else {
                childVm = void 0
                value = newVal
            }
            if (Object(childVm) === childVm) {
                childVm.$pathname = key
                childVm.$up = this
            }
            if (this.$active) {
                $emit.call(this, key, [value, oldValue])
            }
        },
        enumerable: true,
        configurable: true
    }
}
function observe(obj, old, hasReturn, watch) {
    if (Array.isArray(obj)) {
        return observeArray(obj, old, watch)
    } else if (avalon.isPlainObject(obj)) {
        if (old && typeof old === 'object') {
            var keys = Object.keys(obj)
            var keys2 = Object.keys(old)
            if (keys.join(";") === keys2.join(";")) {
                for (var i in obj) {
                    if (obj.hasOwnProperty(i)) {
                        old[i] = obj[i]
                    }
                }
                return old
            }
            old.$active = false
        }
        return observeObject(obj, {
            old: old,
            watch: watch
        })
    }
    if (hasReturn) {
        return obj
    }
}
function observeArray(array, old, watch) {
    if (old) {
        var args = [0, old.length].concat(array)
        old.splice.apply(old, args)
        return old
    } else {
        for (var i in newProto) {
            array[i] = newProto[i]
        }
        hideProperty(array, "$up", null)
        hideProperty(array, "$pathname", "")
        hideProperty(array, "$track", createTrack(array.length))
        array._ = observeObject({
            length: NaN
        }, {
            watch: true
        })
        array._.length = array.length
        array._.$watch("length", function (a, b) {
            $emit.call(array.$up, array.$pathname + ".length", [a, b])
        })
        if (watch) {
            hideProperty(array, "$watch", function () {
                return $watch.apply(array, arguments)
            })
        }
        Object.defineProperty(array, "$model", $modelDescriptor)
        for (var j = 0, n = array.length; j < n; j++) {
            var el = array[j] = observe(array[j], 0, 1, 1)
            if (Object(el) === el) {//#1077
                el.$up = array
            }
        }
        return array
    }
}
function hideProperty(host, name, value) {
    Object.defineProperty(host, name, {
        value: value,
        writable: true,
        enumerable: false,
        configurable: true
    })
}
function toJson(val) {
    var xtype = avalon.type(val)
    if (xtype === "array") {
        var array = []
        for (var i = 0; i < val.length; i++) {
            array[i] = toJson(val[i])
        }
        return array
    } else if (xtype === "object") {
        var obj = {}
        for (i in val) {
            if (val.hasOwnProperty(i)) {
                var value = val[i]
                obj[i] = value && value.nodeType ? value : toJson(value)
            }
        }
        return obj
    }
    return val
}
var $modelDescriptor = {
    get: function () {
        return toJson(this)
    },
    set: noop,
    enumerable: false,
    configurable: true
}
/*********************************************************************
 *          监控数组(与ms-each, ms-repeat配合使用)                     *
 **********************************************************************/
var arrayMethods = ['push', 'pop', 'shift', 'unshift', 'splice']
var arrayProto = Array.prototype
var newProto = {
    notify: function () {
        $emit.call(this.$up, this.$pathname)
    },
    set: function (index, val) {
        if (((index >>> 0) === index) && this[index] !== val) {
            if (index > this.length) {
                throw Error(index + "set方法的第一个参数不能大于原数组长度")
            }
            $emit.call(this.$up, this.$pathname + ".*", [val, this[index]])
            this.splice(index, 1, val)
        }
    },
    contains: function (el) { //判定是否包含
        return this.indexOf(el) !== -1
    },
    ensure: function (el) {
        if (!this.contains(el)) { //只有不存在才push
            this.push(el)
        }
        return this
    },
    pushArray: function (arr) {
        return this.push.apply(this, arr)
    },
    remove: function (el) { //移除第一个等于给定值的元素
        return this.removeAt(this.indexOf(el))
    },
    removeAt: function (index) { //移除指定索引上的元素
        if ((index >>> 0) === index) {
            return this.splice(index, 1)
        }
        return []
    },
    size: function () { //取得数组长度,这个函数可以同步视图,length不能
        return this._.length
    },
    removeAll: function (all) { //移除N个元素
        if (Array.isArray(all)) {
            for (var i = this.length - 1; i >= 0; i--) {
                if (all.indexOf(this[i]) !== -1) {
                    _splice.call(this.$track, i, 1)
                    _splice.call(this, i, 1)
                    
                }
            }
        } else if (typeof all === "function") {
            for (i = this.length - 1; i >= 0; i--) {
                var el = this[i]
                if (all(el, i)) {
                     _splice.call(this.$track, i, 1)
                    _splice.call(this, i, 1)
                   
                }
            }
        } else {
            _splice.call(this.$track, 0, this.length)
            _splice.call(this, 0, this.length)
        }
        if (!W3C) {
            this.$model = toJson(this)
        }
        this.notify()
        this._.length = this.length
    },
    clear: function () {
        return this.removeAll()
    }
}
var _splice = arrayProto.splice
arrayMethods.forEach(function (method) {
    var original = arrayProto[method]
    newProto[method] = function () {
        // 继续尝试劫持数组元素的属性
        var args = []
        for (var i = 0, n = arguments.length; i < n; i++) {
            args[i] = observe(arguments[i], 0, 1, 1)
        }
        var result = original.apply(this, args)
        addTrack(this.$track, method, args)
        if (!W3C) {
            this.$model = toJson(this)
        }
        this.notify()
        this._.length = this.length
        return result
    }
})
"sort,reverse".replace(rword, function (method) {
    newProto[method] = function () {
        var oldArray = this.concat() //保持原来状态的旧数组
        var newArray = this
        var mask = Math.random()
        var indexes = []
        var hasSort = false
        arrayProto[method].apply(newArray, arguments) //排序
        for (var i = 0, n = oldArray.length; i < n; i++) {
            var neo = newArray[i]
            var old = oldArray[i]
            if (neo === old) {
                indexes.push(i)
            } else {
                var index = oldArray.indexOf(neo)
                indexes.push(index)//得到新数组的每个元素在旧数组对应的位置
                oldArray[index] = mask    //屏蔽已经找过的元素
                hasSort = true
            }
        }
        if (hasSort) {
            sortByIndex(this.$track, indexes)
            if (!W3C) {
                this.$model = toJson(this)
            }
            this.notify()
        }
        return this
    }
})
function sortByIndex(array, indexes) {
    var map = {};
    for (var i = 0, n = indexes.length; i < n; i++) {
        map[i] = array[i]
        var j = indexes[i]
        if (j in map) {
            array[i] = map[j]
            delete map[j]
        } else {
            array[i] = array[j]
        }
    }
}
function createTrack(n) {
    var ret = []
    for (var i = 0; i < n; i++) {
        ret[i] = generateID("$proxy$each")
    }
    return ret
}
function addTrack(track, method, args) {
    switch (method) {
        case 'push':
        case 'unshift':
            args = createTrack(args.length)
            break
        case 'splice':
            if (args.length > 2) {
                // 0, 5, a, b, c --> 0, 2, 0
                // 0, 5, a, b, c, d, e, f, g--> 0, 0, 3
                var del = args[1]
                var add = args.length - 2
                // args = [args[0], Math.max(del - add, 0)].concat(createTrack(Math.max(add - del, 0)))
                args = [args[0], args[1]].concat(createTrack(args.length - 2))
            }
            break
    }
    Array.prototype[method].apply(track, args)
}
/*********************************************************************
 *                           依赖调度系统                             *
 **********************************************************************/
//检测两个对象间的依赖关系
var dependencyDetection = (function () {
    var outerFrames = []
    var currentFrame
    return {
        begin: function (binding) {
            //accessorObject为一个拥有callback的对象
            outerFrames.push(currentFrame)
            currentFrame = binding
        },
        end: function () {
            currentFrame = outerFrames.pop()
        },
        collectDependency: function (array) {
            if (currentFrame) {
                //被dependencyDetection.begin调用
                currentFrame.callback(array)
            }
        }
    };
})()
//将绑定对象注入到其依赖项的订阅数组中
var roneval = /^on$/
function returnRandom() {
    return new Date() - 0
}
avalon.injectBinding = function (binding) {
    binding.handler = binding.handler || directives[binding.type].update || noop
    binding.update = function () {
        var begin = false
        if (!binding.getter) {
            begin = true
            dependencyDetection.begin({
                callback: function (array) {
                    injectDependency(array, binding)
                }
            })
            binding.getter = parseExpr(binding.expr, binding.vmodels, binding)
            binding.observers.forEach(function (a) {
                a.v.$watch(a.p, binding)
            })
            delete binding.observers
        }
        try {
            var args = binding.fireArgs, a, b
            delete binding.fireArgs
            if (!args) {
                if (binding.type === "on") {
                    a = binding.getter + ""
                } else {
                    a = binding.getter.apply(0, binding.args)
                }
            } else {
                a = args[0]
                b = args[1]
            }
            b = typeof b === "undefined" ? binding.oldValue : b
            if (binding._filters) {
                a = filters.$filter.apply(0, [a].concat(binding._filters))
            }
            if (binding.signature) {
                var xtype = avalon.type(a)
                if (xtype !== "array" && xtype !== "object") {
                    throw Error("warning:" + binding.expr + "只能是对象或数组")
                }
                binding.xtype = xtype
                var vtrack = getProxyIds(binding.proxies || [], xtype)
                var mtrack = a.$track || (xtype === "array" ? createTrack(a.length) :
                        Object.keys(a))
                binding.track = mtrack
                if (vtrack !== mtrack.join(";")) {
                    binding.handler(a, b)
                    binding.oldValue = 1
                }
            } else if (Array.isArray(a) ? a.length !== (b && b.length) : false) {
                binding.handler(a, b)
                binding.oldValue = a.concat()
            } else if (!("oldValue" in binding) || a !== b) {
                binding.handler(a, b)
                binding.oldValue = a
            }
        } catch (e) {
            delete binding.getter
            log("warning:exception throwed in [avalon.injectBinding] ", e)
            var node = binding.element
            if (node && node.nodeType === 3) {
                node.nodeValue = openTag + (binding.oneTime ? "::" : "") + binding.expr + closeTag
            }
        } finally {
            begin && dependencyDetection.end()
        }
    }
    binding.update()
}
//将依赖项(比它高层的访问器或构建视图刷新函数的绑定对象)注入到订阅者数组
function injectDependency(list, binding) {
    if (binding.oneTime)
        return
    if (list && avalon.Array.ensure(list, binding) && binding.element) {
        injectDisposeQueue(binding, list)
        if (new Date() - beginTime > 444) {
            rejectDisposeQueue()
        }
    }
}
function getProxyIds(a, isArray) {
    var ret = []
    for (var i = 0, el; el = a[i++]; ) {
        ret.push(isArray ? el.$id : el.$key)
    }
    return ret.join(";")
}
/*********************************************************************
 *                          定时GC回收机制                             *
 **********************************************************************/
var disposeCount = 0
var disposeQueue = avalon.$$subscribers = []
var beginTime = new Date()
var oldInfo = {}
function getUid(data) { //IE9+,标准浏览器
    if (!data.uniqueNumber) {
        var elem = data.element
        if (elem) {
            if (elem.nodeType !== 1) {
                //如果是注释节点,则data.pos不存在,当一个元素下有两个注释节点就会出问题
                data.uniqueNumber = data.type + "-" + getUid(elem.parentNode) + "-" + (++disposeCount)
            } else {
                data.uniqueNumber = data.name + "-" + getUid(elem)
            }
        } else {
            data.uniqueNumber = ++disposeCount
        }
    }
    return data.uniqueNumber
}
//添加到回收列队中
function injectDisposeQueue(data, list) {
    var lists = data.lists || (data.lists = [])
    var uuid = getUid(data)
    avalon.Array.ensure(lists, list)
    list.$uuid = list.$uuid || generateID()
    if (!disposeQueue[uuid]) {
        disposeQueue[uuid] = 1
        disposeQueue.push(data)
    }
}
function rejectDisposeQueue(data) {
    var i = disposeQueue.length
    var n = i
    var allTypes = []
    var iffishTypes = {}
    var newInfo = {}
    //对页面上所有绑定对象进行分门别类, 只检测个数发生变化的类型
    while (data = disposeQueue[--i]) {
        var type = data.type
        if (newInfo[type]) {
            newInfo[type]++
        } else {
            newInfo[type] = 1
            allTypes.push(type)
        }
    }
    var diff = false
    allTypes.forEach(function (type) {
        if (oldInfo[type] !== newInfo[type]) {
            iffishTypes[type] = 1
            diff = true
        }
    })
    i = n
    if (diff) {
        while (data = disposeQueue[--i]) {
            if (data.element === null) {
                disposeQueue.splice(i, 1)
                continue
            }
            if (iffishTypes[data.type] && shouldDispose(data.element)) { //如果它没有在DOM树
                disposeQueue.splice(i, 1)
                delete disposeQueue[data.uniqueNumber]
                var lists = data.lists
                for (var k = 0, list; list = lists[k++]; ) {
                    avalon.Array.remove(lists, list)
                    avalon.Array.remove(list, data)
                }
                disposeData(data)
            }
        }
    }
    oldInfo = newInfo
    beginTime = new Date()
}
function disposeData(data) {
    delete disposeQueue[data.uniqueNumber] // 先清除,不然无法回收了
    data.element = null
    data.rollback && data.rollback()
    for (var key in data) {
        data[key] = null
    }
}
function shouldDispose(el) {
    try {//IE下,如果文本节点脱离DOM树,访问parentNode会报错
        var fireError = el.parentNode.nodeType
    } catch (e) {
        return true
    }
    if (el.ifRemove) {
        // 如果节点被放到ifGroup,才移除
        if (!root.contains(el.ifRemove) && (ifGroup === el.parentNode)) {
            el.parentNode && el.parentNode.removeChild(el)
            return true
        }
    }
    return el.msRetain ? 0 : (el.nodeType === 1 ? !root.contains(el) : !avalon.contains(root, el))
}
/************************************************************************
 *              HTML处理(parseHTML, innerHTML, clearHTML)                 *
 **************************************************************************/
//parseHTML的辅助变量
var tagHooks = new function() {// jshint ignore:line
    avalon.mix(this, {
        option: DOC.createElement("select"),
        thead: DOC.createElement("table"),
        td: DOC.createElement("tr"),
        area: DOC.createElement("map"),
        tr: DOC.createElement("tbody"),
        col: DOC.createElement("colgroup"),
        legend: DOC.createElement("fieldset"),
        _default: DOC.createElement("div"),
        "g": DOC.createElementNS("http://www.w3.org/2000/svg", "svg")
    })
    this.optgroup = this.option
    this.tbody = this.tfoot = this.colgroup = this.caption = this.thead
    this.th = this.td
}// jshint ignore:line
String("circle,defs,ellipse,image,line,path,polygon,polyline,rect,symbol,text,use").replace(rword, function(tag) {
    tagHooks[tag] = tagHooks.g //处理SVG
})
var rtagName = /<([\w:]+)/
var rxhtml = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/ig
var scriptTypes = oneObject(["", "text/javascript", "text/ecmascript", "application/ecmascript", "application/javascript"])
var script = DOC.createElement("script")
var rhtml = /<|&#?\w+;/
avalon.parseHTML = function(html) {
    var fragment = avalonFragment.cloneNode(false)
    if (typeof html !== "string" ) {
        return fragment
    }
    if (!rhtml.test(html)) {
        fragment.appendChild(DOC.createTextNode(html))
        return fragment
    }
    html = html.replace(rxhtml, "<$1></$2>").trim()
    var tag = (rtagName.exec(html) || ["", ""])[1].toLowerCase(),
            //取得其标签名
            wrapper = tagHooks[tag] || tagHooks._default,
            firstChild
    wrapper.innerHTML = html
    var els = wrapper.getElementsByTagName("script")
    if (els.length) { //使用innerHTML生成的script节点不会发出请求与执行text属性
        for (var i = 0, el; el = els[i++]; ) {
            if (scriptTypes[el.type]) {
                var neo = script.cloneNode(false) //FF不能省略参数
                ap.forEach.call(el.attributes, function(attr) {
                    neo.setAttribute(attr.name, attr.value)
                })// jshint ignore:line
                neo.text = el.text
                el.parentNode.replaceChild(neo, el)
            }
        }
    }
    while (firstChild = wrapper.firstChild) { // 将wrapper上的节点转移到文档碎片上!
        fragment.appendChild(firstChild)
    }
    return fragment
}
avalon.innerHTML = function(node, html) {
    var a = this.parseHTML(html)
    this.clearHTML(node).appendChild(a)
}
avalon.clearHTML = function(node) {
    node.textContent = ""
    while (node.firstChild) {
        node.removeChild(node.firstChild)
    }
    return node
}
/*********************************************************************
 *                        avalon的原型方法定义区                        *
 **********************************************************************/
function hyphen(target) {
    //转换为连字符线风格
    return target.replace(/([a-z\d])([A-Z]+)/g, "$1-$2").toLowerCase()
}
function camelize(target) {
    //转换为驼峰风格
    if (target.indexOf("-") < 0 && target.indexOf("_") < 0) {
        return target //提前判断,提高getStyle等的效率
    }
    return target.replace(/[-_][^-_]/g, function (match) {
        return match.charAt(1).toUpperCase()
    })
}
"add,remove".replace(rword, function (method) {
    avalon.fn[method + "Class"] = function (cls) {
        var el = this[0]
        //https://developer.mozilla.org/zh-CN/docs/Mozilla/Firefox/Releases/26
        if (cls && typeof cls === "string" && el && el.nodeType === 1) {
            cls.replace(/\S+/g, function (c) {
                el.classList[method](c)
            })
        }
        return this
    }
})
avalon.fn.mix({
    hasClass: function (cls) {
        var el = this[0] || {} //IE10+, chrome8+, firefox3.6+, safari5.1+,opera11.5+支持classList,chrome24+,firefox26+支持classList2.0
        return el.nodeType === 1 && el.classList.contains(cls)
    },
    toggleClass: function (value, stateVal) {
        var className, i = 0
        var classNames = String(value).split(/\s+/)
        var isBool = typeof stateVal === "boolean"
        while ((className = classNames[i++])) {
            var state = isBool ? stateVal : !this.hasClass(className)
            this[state ? "addClass" : "removeClass"](className)
        }
        return this
    },
    attr: function (name, value) {
        if (arguments.length === 2) {
            this[0].setAttribute(name, value)
            return this
        } else {
            return this[0].getAttribute(name)
        }
    },
    data: function (name, value) {
        name = "data-" + hyphen(name || "")
        switch (arguments.length) {
            case 2:
                this.attr(name, value)
                return this
            case 1:
                var val = this.attr(name)
                return parseData(val)
            case 0:
                var ret = {}
                ap.forEach.call(this[0].attributes, function (attr) {
                    if (attr) {
                        name = attr.name
                        if (!name.indexOf("data-")) {
                            name = camelize(name.slice(5))
                            ret[name] = parseData(attr.value)
                        }
                    }
                })
                return ret
        }
    },
    removeData: function (name) {
        name = "data-" + hyphen(name)
        this[0].removeAttribute(name)
        return this
    },
    css: function (name, value) {
        if (avalon.isPlainObject(name)) {
            for (var i in name) {
                avalon.css(this, i, name[i])
            }
        } else {
            var ret = avalon.css(this, name, value)
        }
        return ret !== void 0 ? ret : this
    },
    position: function () {
        var offsetParent, offset,
                elem = this[0],
                parentOffset = {
                    top: 0,
                    left: 0
                };
        if (!elem) {
            return
        }
        if (this.css("position") === "fixed") {
            offset = elem.getBoundingClientRect()
        } else {
            offsetParent = this.offsetParent() //得到真正的offsetParent
            offset = this.offset() // 得到正确的offsetParent
            if (offsetParent[0].tagName !== "HTML") {
                parentOffset = offsetParent.offset()
            }
            parentOffset.top += avalon.css(offsetParent[0], "borderTopWidth", true)
            parentOffset.left += avalon.css(offsetParent[0], "borderLeftWidth", true)
            // Subtract offsetParent scroll positions
            parentOffset.top -= offsetParent.scrollTop()
            parentOffset.left -= offsetParent.scrollLeft()
        }
        return {
            top: offset.top - parentOffset.top - avalon.css(elem, "marginTop", true),
            left: offset.left - parentOffset.left - avalon.css(elem, "marginLeft", true)
        }
    },
    offsetParent: function () {
        var offsetParent = this[0].offsetParent
        while (offsetParent && avalon.css(offsetParent, "position") === "static") {
            offsetParent = offsetParent.offsetParent;
        }
        return avalon(offsetParent || root)
    },
    bind: function (type, fn, phase) {
        if (this[0]) { //此方法不会链
            return avalon.bind(this[0], type, fn, phase)
        }
    },
    unbind: function (type, fn, phase) {
        if (this[0]) {
            avalon.unbind(this[0], type, fn, phase)
        }
        return this
    },
    val: function (value) {
        var node = this[0]
        if (node && node.nodeType === 1) {
            var get = arguments.length === 0
            var access = get ? ":get" : ":set"
            var fn = valHooks[getValType(node) + access]
            if (fn) {
                var val = fn(node, value)
            } else if (get) {
                return (node.value || "").replace(/\r/g, "")
            } else {
                node.value = value
            }
        }
        return get ? val : this
    }
})
if (root.dataset) {
    avalon.fn.data = function (name, val) {
        name = name && camelize(name)
        var dataset = this[0].dataset
        switch (arguments.length) {
            case 2:
                dataset[name] = val
                return this
            case 1:
                val = dataset[name]
                return parseData(val)
            case 0:
                var ret = createMap()
                for (name in dataset) {
                    ret[name] = parseData(dataset[name])
                }
                return ret
        }
    }
}
var rbrace = /(?:\{[\s\S]*\}|\[[\s\S]*\])$/
avalon.parseJSON = JSON.parse
function parseData(data) {
    try {
        if (typeof data === "object")
            return data
        data = data === "true" ? true :
                data === "false" ? false :
                data === "null" ? null : +data + "" === data ? +data : rbrace.test(data) ? JSON.parse(data) : data
    } catch (e) {
    }
    return data
}
avalon.fireDom = function (elem, type, opts) {
    var hackEvent = DOC.createEvent("Events");
    hackEvent.initEvent(type, true, true)
    avalon.mix(hackEvent, opts)
    elem.dispatchEvent(hackEvent)
}
avalon.each({
    scrollLeft: "pageXOffset",
    scrollTop: "pageYOffset"
}, function (method, prop) {
    avalon.fn[method] = function (val) {
        var node = this[0] || {},
                win = getWindow(node),
                top = method === "scrollTop"
        if (!arguments.length) {
            return win ? win[prop] : node[method]
        } else {
            if (win) {
                win.scrollTo(!top ? val : win[prop], top ? val : win[prop])
            } else {
                node[method] = val
            }
        }
    }
})
function getWindow(node) {
    return node.window && node.document ? node : node.nodeType === 9 ? node.defaultView : false
}
//=============================css相关==================================
var cssHooks = avalon.cssHooks = createMap()
var prefixes = ["", "-webkit-", "-moz-", "-ms-"] //去掉opera-15的支持
var cssMap = {
    "float": "cssFloat"
}
avalon.cssNumber = oneObject("animationIterationCount,animationIterationCount,columnCount,order,flex,flexGrow,flexShrink,fillOpacity,fontWeight,lineHeight,opacity,orphans,widows,zIndex,zoom")
avalon.cssName = function (name, host, camelCase) {
    if (cssMap[name]) {
        return cssMap[name]
    }
    host = host || root.style
    for (var i = 0, n = prefixes.length; i < n; i++) {
        camelCase = camelize(prefixes[i] + name)
        if (camelCase in host) {
            return (cssMap[name] = camelCase)
        }
    }
    return null
}
cssHooks["@:set"] = function (node, name, value) {
    node.style[name] = value
}
cssHooks["@:get"] = function (node, name) {
    if (!node || !node.style) {
        throw new Error("getComputedStyle要求传入一个节点 " + node)
    }
    var ret, computed = getComputedStyle(node)
    if (computed) {
        ret = name === "filter" ? computed.getPropertyValue(name) : computed[name]
        if (ret === "") {
            ret = node.style[name] //其他浏览器需要我们手动取内联样式
        }
    }
    return ret
}
cssHooks["opacity:get"] = function (node) {
    var ret = cssHooks["@:get"](node, "opacity")
    return ret === "" ? "1" : ret
}
"top,left".replace(rword, function (name) {
    cssHooks[name + ":get"] = function (node) {
        var computed = cssHooks["@:get"](node, name)
        return /px$/.test(computed) ? computed :
                avalon(node).position()[name] + "px"
    }
})
var cssShow = {
    position: "absolute",
    visibility: "hidden",
    display: "block"
}
var rdisplayswap = /^(none|table(?!-c[ea]).+)/
function showHidden(node, array) {
    //http://www.cnblogs.com/rubylouvre/archive/2012/10/27/2742529.html
    if (node.offsetWidth <= 0) { //opera.offsetWidth可能小于0
        var styles = getComputedStyle(node, null)
        if (rdisplayswap.test(styles["display"])) {
            var obj = {
                node: node
            }
            for (var name in cssShow) {
                obj[name] = styles[name]
                node.style[name] = cssShow[name]
            }
            array.push(obj)
        }
        var parent = node.parentNode
        if (parent && parent.nodeType === 1) {
            showHidden(parent, array)
        }
    }
}
"Width,Height".replace(rword, function (name) { //fix 481
    var method = name.toLowerCase(),
            clientProp = "client" + name,
            scrollProp = "scroll" + name,
            offsetProp = "offset" + name
    cssHooks[method + ":get"] = function (node, which, override) {
        var boxSizing = -4
        if (typeof override === "number") {
            boxSizing = override
        }
        which = name === "Width" ? ["Left", "Right"] : ["Top", "Bottom"]
        var ret = node[offsetProp] // border-box 0
        if (boxSizing === 2) { // margin-box 2
            return ret + avalon.css(node, "margin" + which[0], true) + avalon.css(node, "margin" + which[1], true)
        }
        if (boxSizing < 0) { // padding-box  -2
            ret = ret - avalon.css(node, "border" + which[0] + "Width", true) - avalon.css(node, "border" + which[1] + "Width", true)
        }
        if (boxSizing === -4) { // content-box -4
            ret = ret - avalon.css(node, "padding" + which[0], true) - avalon.css(node, "padding" + which[1], true)
        }
        return ret
    }
    cssHooks[method + "&get"] = function (node) {
        var hidden = [];
        showHidden(node, hidden);
        var val = cssHooks[method + ":get"](node)
        for (var i = 0, obj; obj = hidden[i++]; ) {
            node = obj.node
            for (var n in obj) {
                if (typeof obj[n] === "string") {
                    node.style[n] = obj[n]
                }
            }
        }
        return val;
    }
    avalon.fn[method] = function (value) { //会忽视其display
        var node = this[0]
        if (arguments.length === 0) {
            if (node.setTimeout) { //取得窗口尺寸,IE9后可以用node.innerWidth /innerHeight代替
                return node["inner" + name]
            }
            if (node.nodeType === 9) { //取得页面尺寸
                var doc = node.documentElement
                //FF chrome    html.scrollHeight< body.scrollHeight
                //IE 标准模式 : html.scrollHeight> body.scrollHeight
                //IE 怪异模式 : html.scrollHeight 最大等于可视窗口多一点?
                return Math.max(node.body[scrollProp], doc[scrollProp], node.body[offsetProp], doc[offsetProp], doc[clientProp])
            }
            return cssHooks[method + "&get"](node)
        } else {
            return this.css(method, value)
        }
    }
    avalon.fn["inner" + name] = function () {
        return cssHooks[method + ":get"](this[0], void 0, -2)
    }
    avalon.fn["outer" + name] = function (includeMargin) {
        return cssHooks[method + ":get"](this[0], void 0, includeMargin === true ? 2 : 0)
    }
})
avalon.fn.offset = function () { //取得距离页面左右角的坐标
    var node = this[0]
    try {
        var rect = node.getBoundingClientRect()
        // Make sure element is not hidden (display: none) or disconnected
        // https://github.com/jquery/jquery/pull/2043/files#r23981494
        if (rect.width || rect.height || node.getClientRects().length) {
            var doc = node.ownerDocument
            var root = doc.documentElement
            var win = doc.defaultView
            return {
                top: rect.top + win.pageYOffset - root.clientTop,
                left: rect.left + win.pageXOffset - root.clientLeft
            }
        }
    } catch (e) {
        return {
            left: 0,
            top: 0
        }
    }
}
//=============================val相关=======================
function getValType(elem) {
    var ret = elem.tagName.toLowerCase()
    return ret === "input" && /checkbox|radio/.test(elem.type) ? "checked" : ret
}
var valHooks = {
    "select:get": function (node, value) {
        var option, options = node.options,
                index = node.selectedIndex,
                one = node.type === "select-one" || index < 0,
                values = one ? null : [],
                max = one ? index + 1 : options.length,
                i = index < 0 ? max : one ? index : 0
        for (; i < max; i++) {
            option = options[i]
            //旧式IE在reset后不会改变selected,需要改用i === index判定
            //我们过滤所有disabled的option元素,但在safari5下,如果设置select为disable,那么其所有孩子都disable
            //因此当一个元素为disable,需要检测其是否显式设置了disable及其父节点的disable情况
            if ((option.selected || i === index) && !option.disabled) {
                value = option.value
                if (one) {
                    return value
                }
                //收集所有selected值组成数组返回
                values.push(value)
            }
        }
        return values
    },
    "select:set": function (node, values, optionSet) {
        values = [].concat(values) //强制转换为数组
        for (var i = 0, el; el = node.options[i++]; ) {
            if ((el.selected = values.indexOf(el.value) > -1)) {
                optionSet = true
            }
        }
        if (!optionSet) {
            node.selectedIndex = -1
        }
    }
}
var keyMap = {}
var keys = ["break,case,catch,continue,debugger,default,delete,do,else,false",
    "finally,for,function,if,in,instanceof,new,null,return,switch,this",
    "throw,true,try,typeof,var,void,while,with", /* 关键字*/
    "abstract,boolean,byte,char,class,const,double,enum,export,extends",
    "final,float,goto,implements,import,int,interface,long,native",
    "package,private,protected,public,short,static,super,synchronized",
    "throws,transient,volatile", /*保留字*/
    "arguments,let,yield,undefined"].join(",")
keys.replace(/\w+/g, function (a) {
    keyMap[a] = true
})
var ridentStart = /[a-z_$]/i
var rwhiteSpace = /[\s\uFEFF\xA0]/
function getIdent(input, lastIndex) {
    var result = []
    var subroutine = !!lastIndex
    lastIndex = lastIndex || 0
    //将表达式中的标识符抽取出来
    var state = "unknown"
    var variable = ""
    for (var i = 0; i < input.length; i++) {
        var c = input.charAt(i)
        if (c === "'" || c === '"') {//字符串开始
            if (state === "unknown") {
                state = c
            } else if (state === c) {//字符串结束
                state = "unknown"
            }
        } else if (c === "\\") {
            if (state === "'" || state === '"') {
                i++
            }
        } else if (ridentStart.test(c)) {//碰到标识符
            if (state === "unknown") {
                state = "variable"
                variable = c
            } else if (state === "maybePath") {
                variable = result.pop()
                variable += "." + c
                state = "variable"
            } else if (state === "variable") {
                variable += c
            }
        } else if (/\w/.test(c)) {
            if (state === "variable") {
                variable += c
            }
        } else if (c === ".") {
            if (state === "variable") {
                if (variable) {
                    result.push(variable)
                    variable = ""
                    state = "maybePath"
                }
            }
        } else if (c === "[") {
            if (state === "variable" || state === "maybePath") {
                if (variable) {//如果前面存在变量,收集它
                    result.push(variable)
                    variable = ""
                }
                var lastLength = result.length
                var last = result[lastLength - 1]
                var innerResult = getIdent(input.slice(i), i)
                if (innerResult.length) {//如果括号中存在变量,那么这里添加通配符
                    result[lastLength - 1] = last + ".*"
                    result = innerResult.concat(result)
                } else { //如果括号中的东西是确定的,直接转换为其子属性
                    var content = input.slice(i + 1, innerResult.i)
                    try {
                        var text = (scpCompile(["return " + content]))()
                        result[lastLength - 1] = last + "." + text
                    } catch (e) {
                    }
                }
                state = "maybePath"//]后面可能还接东西
                i = innerResult.i
            }
        } else if (c === "]") {
            if (subroutine) {
                result.i = i + lastIndex
                addVar(result, variable)
                return result
            }
        } else if (rwhiteSpace.test(c) && c !== "\r" && c !== "\n") {
            if (state === "variable") {
                if (addVar(result, variable)) {
                    state = "maybePath" // aaa . bbb 这样的情况
                }
                variable = ""
            }
        } else {
            addVar(result, variable)
            state = "unknown"
            variable = ""
        }
    }
    addVar(result, variable)
    return result
}
function addVar(array, element) {
    if (element && !keyMap[element]) {
        array.push(element)
        return true
    }
}
function addAssign(vars, vmodel, name, binding) {
    var ret = [],
            prefix = " = " + name + "."
    for (var i = vars.length, prop; prop = vars[--i]; ) {
        var arr = prop.split("."), a
        var first = arr[0]
        while (a = arr.shift()) {
            if (vmodel.hasOwnProperty(a)) {
                ret.push(first + prefix + first)
                binding.observers.push({
                    v: vmodel,
                    p: prop
                })
                vars.splice(i, 1)
            }
        }
    }
    return ret
}
var rproxy = /(\$proxy\$[a-z]+)\d+$/
var variablePool = new Cache(218)
//缓存求值函数,以便多次利用
var evaluatorPool = new Cache(128)
function getVars(expr) {
    expr = expr.trim()
    var ret = variablePool.get(expr)
    if (ret) {
        return ret.concat()
    }
    var array = getIdent(expr)
    var uniq = {}
    var result = []
    for (var i = 0, el; el = array[i++]; ) {
        if (!uniq[el]) {
            uniq[el] = 1
            result.push(el)
        }
    }
    return variablePool.put(expr, result).concat()
}
function parseExpr(expr, vmodels, binding) {
    var filters = binding.filters
    if (typeof filters === "string" && filters.trim() && !binding._filters) {
        binding._filters = parseFilter(filters.trim())
    }
    var vars = getVars(expr)
    var expose = new Date() - 0
    var assigns = []
    var names = []
    var args = []
    binding.observers = []
    for (var i = 0, sn = vmodels.length; i < sn; i++) {
        if (vars.length) {
            var name = "vm" + expose + "_" + i
            names.push(name)
            args.push(vmodels[i])
            assigns.push.apply(assigns, addAssign(vars, vmodels[i], name, binding))
        }
    }
    binding.args = args
    var dataType = binding.type
    var exprId = vmodels.map(function (el) {
        return String(el.$id).replace(rproxy, "$1")
    }) + expr + dataType
    var getter = evaluatorPool.get(exprId) //直接从缓存,免得重复生成
    if (getter) {
        if (dataType === "duplex") {
            var setter = evaluatorPool.get(exprId + "setter")
            binding.setter = setter.apply(setter, binding.args)
        }
        return binding.getter = getter
    }
    if (!assigns.length) {
        assigns.push("fix" + expose)
    }
    if (dataType === "duplex") {
        var nameOne = {}
        assigns.forEach(function (a) {
            var arr = a.split("=")
            nameOne[arr[0].trim()] = arr[1].trim()
        })
        expr = expr.replace(/[\$\w]+/, function (a) {
            return nameOne[a] ? nameOne[a] : a
        })
        /* jshint ignore:start */
        var fn2 = scpCompile(names.concat("'use strict';" +
                "return function(vvv){" + expr + " = vvv\n}\n"))
        /* jshint ignore:end */
        evaluatorPool.put(exprId + "setter", fn2)
        binding.setter = fn2.apply(fn2, binding.args)
    }
    if (dataType === "on") { //事件绑定
        if (expr.indexOf("(") === -1) {
            expr += ".call(this, $event)"
        } else {
            expr = expr.replace("(", ".call(this,")
        }
        names.push("$event")
        expr = "\nreturn " + expr + ";" //IE全家 Function("return ")出错,需要Function("return ;")
        var lastIndex = expr.lastIndexOf("\nreturn")
        var header = expr.slice(0, lastIndex)
        var footer = expr.slice(lastIndex)
        expr = header + "\n" + footer
    } else {
        expr = "\nreturn " + expr + ";" //IE全家 Function("return ")出错,需要Function("return ;")
    }
    /* jshint ignore:start */
    getter = scpCompile(names.concat("'use strict';\nvar " +
            assigns.join(",\n") + expr))
    /* jshint ignore:end */
    return  evaluatorPool.put(exprId, getter)
}
//========
function normalizeExpr(code) {
    var hasExpr = rexpr.test(code) //比如ms-class="width{{w}}"的情况
    if (hasExpr) {
        var array = scanExpr(code)
        if (array.length === 1) {
            return array[0].expr
        }
        return array.map(function (el) {
            return el.type ? "(" + el.expr + ")" : quote(el.expr)
        }).join(" + ")
    } else {
        return code
    }
}
avalon.normalizeExpr = normalizeExpr
avalon.parseExprProxy = parseExpr
var rthimRightParentheses = /\)\s*$/
var rthimOtherParentheses = /\)\s*\|/g
var rquoteFilterName = /\|\s*([$\w]+)/g
var rpatchBracket = /"\s*\["/g
var rthimLeftParentheses = /"\s*\(/g
function parseFilter(filters) {
    filters = filters
            .replace(rthimRightParentheses, "")//处理最后的小括号
            .replace(rthimOtherParentheses, function () {//处理其他小括号
                return "],|"
            })
            .replace(rquoteFilterName, function (a, b) { //处理|及它后面的过滤器的名字
                return "[" + quote(b)
            })
            .replace(rpatchBracket, function () {
                return '"],["'
            })
            .replace(rthimLeftParentheses, function () {
                return '",'
            }) + "]"
    /* jshint ignore:start */
    return  scpCompile(["return [" + filters + "]"])()
    /* jshint ignore:end */
}
/*********************************************************************
 *                          编译系统                                  *
 **********************************************************************/
var quote = JSON.stringify
/*********************************************************************
 *                           扫描系统                                 *
 **********************************************************************/
avalon.scan = function (elem, vmodel) {
    elem = elem || root
    var vmodels = vmodel ? [].concat(vmodel) : []
    scanTag(elem, vmodels)
}
//http://www.w3.org/TR/html5/syntax.html#void-elements
var stopScan = oneObject("area,base,basefont,br,col,command,embed,hr,img,input,link,meta,param,source,track,wbr,noscript,script,style,textarea".toUpperCase())
function checkScan(elem, callback, innerHTML) {
    var id = setTimeout(function () {
        var currHTML = elem.innerHTML
        clearTimeout(id)
        if (currHTML === innerHTML) {
            callback()
        } else {
            checkScan(elem, callback, currHTML)
        }
    })
}
function createSignalTower(elem, vmodel) {
    var id = elem.getAttribute("avalonctrl") || vmodel.$id
    elem.setAttribute("avalonctrl", id)
    if (vmodel.$events) {
        vmodel.$events.expr = elem.tagName + '[avalonctrl="' + id + '"]'
    }
}
var getBindingCallback = function (elem, name, vmodels) {
    var callback = elem.getAttribute(name)
    if (callback) {
        for (var i = 0, vm; vm = vmodels[i++]; ) {
            if (vm.hasOwnProperty(callback) && typeof vm[callback] === "function") {
                return vm[callback]
            }
        }
    }
}
function executeBindings(bindings, vmodels) {
    for (var i = 0, binding; binding = bindings[i++]; ) {
        binding.vmodels = vmodels
        directives[binding.type].init(binding)
      
        avalon.injectBinding(binding)
        if (binding.getter && binding.element.nodeType === 1) { //移除数据绑定,防止被二次解析
            //chrome使用removeAttributeNode移除不存在的特性节点时会报错 https://github.com/RubyLouvre/avalon/issues/99
            binding.element.removeAttribute(binding.name)
        }
    }
    bindings.length = 0
}
//https://github.com/RubyLouvre/avalon/issues/636
var mergeTextNodes = IEVersion && window.MutationObserver ? function (elem) {
    var node = elem.firstChild, text
    while (node) {
        var aaa = node.nextSibling
        if (node.nodeType === 3) {
            if (text) {
                text.nodeValue += node.nodeValue
                elem.removeChild(node)
            } else {
                text = node
            }
        } else {
            text = null
        }
        node = aaa
    }
} : 0
var roneTime = /^\s*::/
var rmsAttr = /ms-(\w+)-?(.*)/
var events = oneObject("animationend,blur,change,input,click,dblclick,focus,keydown,keypress,keyup,mousedown,mouseenter,mouseleave,mousemove,mouseout,mouseover,mouseup,scan,scroll,submit")
var obsoleteAttrs = oneObject("value,title,alt,checked,selected,disabled,readonly,enabled,href,src")
function bindingSorter(a, b) {
    return a.priority - b.priority
}
var rnoCollect = /^(ms-\S+|data-\S+|on[a-z]+|id|style|class)$/
var ronattr = /^on\-[\w-]+$/
function getOptionsFromTag(elem, vmodels) {
    var attributes = elem.attributes
    var ret = {}
    for (var i = 0, attr; attr = attributes[i++]; ) {
        var name = attr.name
        if (attr.specified && !rnoCollect.test(name)) {
            var camelizeName = camelize(attr.name)
            if (/^on\-[\w-]+$/.test(name)) {
                ret[camelizeName] = getBindingCallback(elem, name, vmodels) 
            } else {
                ret[camelizeName] = parseData(attr.value)
            }
        }
    }
    return ret
}
function scanAttr(elem, vmodels, match) {
    var scanNode = true
    if (vmodels.length) {
        var attributes = elem.attributes
        var bindings = []
        var uniq = {}
        for (var i = 0, attr; attr = attributes[i++]; ) {
            var name = attr.name
            if (uniq[name]) {//IE8下ms-repeat,ms-with BUG
                continue
            }
            uniq[name] = 1
            if (attr.specified) {
                if (match = name.match(rmsAttr)) {
                    //如果是以指定前缀命名的
                    var type = match[1]
                    var param = match[2] || ""
                    var value = attr.value
                    if (events[type]) {
                        param = type
                        type = "on"
                    } else if (obsoleteAttrs[type]) {
                        param = type
                        type = "attr"
                        name = "ms-" + type + "-" + param
                        log("warning!请改用" + name + "代替" + attr.name + "!")
                    }
                    if (directives[type]) {
                        var newValue = value.replace(roneTime, "")
                        var oneTime = value !== newValue
                        var binding = {
                            type: type,
                            param: param,
                            element: elem,
                            name: name,
                            expr: newValue,
                            oneTime: oneTime,
                            priority: (directives[type].priority || type.charCodeAt(0) * 10) + (Number(param.replace(/\D/g, "")) || 0)
                        }
                        if (type === "html" || type === "text") {
                            var filters = getToken(value).filters
                            binding.expr = binding.expr.replace(filters, "")
                            binding.filters = filters.replace(rhasHtml, function () {
                                binding.type = "html"
                                binding.group = 1
                                return ""
                            }).trim() // jshint ignore:line
                        } else if (type === "duplex") {
                            var hasDuplex = name
                        } else if (name === "ms-if-loop") {
                            binding.priority += 100
                        } else if (name === "ms-attr-value") {
                            var hasAttrValue = name
                        }
                        bindings.push(binding)
                    }
                }
            }
        }
        if (bindings.length) {
            bindings.sort(bindingSorter)
            if (hasDuplex && hasAttrValue && elem.type === "text") {
                log("warning!一个控件不能同时定义ms-attr-value与" + hasDuplex)
            }
            for (i = 0; binding = bindings[i]; i++) {
                type = binding.type
                if (rnoscanAttrBinding.test(type)) {
                    return executeBindings(bindings.slice(0, i + 1), vmodels)
                } else if (scanNode) {
                    scanNode = !rnoscanNodeBinding.test(type)
                }
            }
            executeBindings(bindings, vmodels)
        }
    }
    if (scanNode && !stopScan[elem.tagName]) {
        mergeTextNodes && mergeTextNodes(elem)
        scanNodeList(elem, vmodels) //扫描子孙元素
    }
}
var rnoscanAttrBinding = /^if|widget|repeat$/
var rnoscanNodeBinding = /^each|with|html|include$/
function scanNodeList(parent, vmodels) {
    var nodes = avalon.slice(parent.childNodes)
    scanNodeArray(nodes, vmodels)
}
function scanNodeArray(nodes, vmodels) {
    for (var i = 0, node; node = nodes[i++]; ) {
        switch (node.nodeType) {
            case 1:
                var elem = node
                if (!elem.msResolved && elem.parentNode && elem.parentNode.nodeType === 1) {
                    var library = isWidget(elem)
                    if (library) {
                        var widget = elem.localName ? elem.localName.replace(library + ":", "") : elem.nodeName
                        var fullName = library + ":" + camelize(widget)
                        componentQueue.push({
                            library: library,
                            element: elem,
                            fullName: fullName,
                            widget: widget,
                            vmodels: vmodels,
                            name: "widget"
                        })
                        if (avalon.components[fullName]) {
                            (function (name) {//确保所有ms-attr-name扫描完再处理
                                setTimeout(function () {
                                    avalon.component(name)
                                })
                            })(fullName)
                        }
                    }
                }
                scanTag(node, vmodels) //扫描元素节点
                if (node.msHasEvent) {
                    avalon.fireDom(node, "datasetchanged", {
                        bubble: node.msHasEvent
                    })
                }
                break
            case 3:
                if (rexpr.test(node.nodeValue)) {
                    scanText(node, vmodels, i) //扫描文本节点
                }
                break
        }
    }
}
function scanTag(elem, vmodels, node) {
    //扫描顺序  ms-skip(0) --> ms-important(1) --> ms-controller(2) --> ms-if(10) --> ms-repeat(100) 
    //--> ms-if-loop(110) --> ms-attr(970) ...--> ms-each(1400)-->ms-with(1500)--〉ms-duplex(2000)垫后        
    var a = elem.getAttribute("ms-skip")
    var b = elem.getAttributeNode("ms-important")
    var c = elem.getAttributeNode("ms-controller")
    if (typeof a === "string") {
        return
    } else if (node = b || c) {
        var newVmodel = avalon.vmodels[node.value]
        if (!newVmodel) {
            return
        }
        //ms-important不包含父VM,ms-controller相反
        vmodels = node === b ? [newVmodel] : [newVmodel].concat(vmodels)
        elem.removeAttribute(node.name) //removeAttributeNode不会刷新[ms-controller]样式规则
        elem.classList.remove(node.name)
        createSignalTower(elem, newVmodel)
    }
    scanAttr(elem, vmodels) //扫描特性节点
    if (newVmodel) {
        setTimeout(function () {
            newVmodel.$fire("ms-scan-end", elem)
        })
    }
}
var rhasHtml = /\|\s*html(?:\b|$)/,
    r11a = /\|\|/g,
    rlt = /&lt;/g,
    rgt = /&gt;/g,
    rstringLiteral = /(['"])(\\\1|.)+?\1/g
function getToken(value) {
    if (value.indexOf("|") > 0) {
        var scapegoat = value.replace(rstringLiteral, function (_) {
            return Array(_.length + 1).join("1") // jshint ignore:line
        })
        var index = scapegoat.replace(r11a, "\u1122\u3344").indexOf("|") //干掉所有短路或
        if (index > -1) {
            return {
                type: "text",
                filters: value.slice(index).trim(),
                expr: value.slice(0, index)
            }
        }
    }
    return {
        type: "text",
        expr: value,
        filters: ""
    }
}
function scanExpr(str) {
    var tokens = [],
        value, start = 0,
        stop
    do {
        stop = str.indexOf(openTag, start)
        if (stop === -1) {
            break
        }
        value = str.slice(start, stop)
        if (value) { // {{ 左边的文本
            tokens.push({
                expr: value
            })
        }
        start = stop + openTag.length
        stop = str.indexOf(closeTag, start)
        if (stop === -1) {
            break
        }
        value = str.slice(start, stop)
        if (value) { //处理{{ }}插值表达式
            tokens.push(getToken(value, start))
        }
        start = stop + closeTag.length
    } while (1)
    value = str.slice(start)
    if (value) { //}} 右边的文本
        tokens.push({
            expr: value
        })
    }
    return tokens
}
function scanText(textNode, vmodels, index) {
    var bindings = [],
    tokens = scanExpr(textNode.data)
    if (tokens.length) {
        for (var i = 0, token; token = tokens[i++];) {
            var node = DOC.createTextNode(token.expr) //将文本转换为文本节点,并替换原来的文本节点
            if (token.type) {
                token.expr = token.expr.replace(roneTime, function () {
                        token.oneTime = true
                        return ""
                    }) // jshint ignore:line
                token.element = node
                token.filters = token.filters.replace(rhasHtml, function () {
                        token.type = "html"
                        return ""
                    }) // jshint ignore:line
                token.pos = index * 1000 + i
                bindings.push(token) //收集带有插值表达式的文本
            }
            avalonFragment.appendChild(node)
        }
        textNode.parentNode.replaceChild(avalonFragment, textNode)
        if (bindings.length)
            executeBindings(bindings, vmodels)
    }
}
//使用来自游戏界的双缓冲技术,减少对视图的冗余刷新
var Buffer = function () {
    this.queue = []
}
Buffer.prototype = {
    render: function (isAnimate) {
        if (!this.locked) {
            this.locked = isAnimate ? root.offsetHeight + 10 : 1
            var me = this
            avalon.nextTick(function () {
                me.flush()
            })
        }
    },
    flush: function () {
        for (var i = 0, sub; sub = this.queue[i++]; ) {
            sub.update && sub.update()
        }
        this.locked = 0
        this.queue = []
    }
}
var buffer = new Buffer()
var componentQueue = []
var widgetList = []
var componentHooks = {
    $construct: function () {
        return avalon.mix.apply(null, arguments)
    },
    $ready: noop,
    $init: noop,
    $dispose: noop,
    $container: null,
    $childReady: noop,
    $replace: false,
    $extend: null,
    $$template: function (str) {
        return str
    }
}
avalon.components = {}
avalon.component = function (name, opts) {
    if (opts) {
        avalon.components[name] = avalon.mix({}, componentHooks, opts)
    }
    for (var i = 0, obj; obj = componentQueue[i]; i++) {
        if (name === obj.fullName) {
            componentQueue.splice(i, 1)
            i--;
            (function (host, hooks, elem, widget) {
                //如果elem已从Document里移除,直接返回
                //issuse : https://github.com/RubyLouvre/avalon2/issues/40
                if (!avalon.contains(DOC, elem)) {
                    avalon.Array.remove(componentQueue, host)
                    return
                }
                
                var dependencies = 1
                var library = host.library
                var global = avalon.libraries[library] || componentHooks
                //===========收集各种配置=======
                if (elem.getAttribute("ms-attr-identifier")) {
                    //如果还没有解析完,就延迟一下 #1155
                    return
                }
                var elemOpts = getOptionsFromTag(elem, host.vmodels)
                var vmOpts = getOptionsFromVM(host.vmodels, elemOpts.config || host.fullName)
                var $id = elemOpts.$id || elemOpts.identifier || generateID(widget)
                delete elemOpts.config
                delete elemOpts.$id
                delete elemOpts.identifier
                var componentDefinition = {}
                var parentHooks = avalon.components[hooks.$extend]
                if (parentHooks) {
                    avalon.mix(true, componentDefinition, parentHooks)
                    componentDefinition = parentHooks.$construct.call(elem, componentDefinition, {}, {})
                } else {
                    avalon.mix(true, componentDefinition, hooks)
                }
                componentDefinition = avalon.components[name].$construct.call(elem, componentDefinition, vmOpts, elemOpts)
                componentDefinition.$refs = {}
                componentDefinition.$id = $id
                //==========构建VM=========
                var keepSlot = componentDefinition.$slot
                var keepReplace = componentDefinition.$replace
                var keepContainer = componentDefinition.$container
                var keepTemplate = componentDefinition.$template
                delete componentDefinition.$slot
                delete componentDefinition.$replace
                delete componentDefinition.$container
                delete componentDefinition.$construct
                var vmodel = avalon.define(componentDefinition) || {}
                elem.msResolved = 1
                vmodel.$init(vmodel, elem)
                global.$init(vmodel, elem)
                var nodes = elem.childNodes
                //收集插入点
                var slots = {}, snode
                for (var s = 0, el; el = nodes[s++]; ) {
                    var type = el.nodeType === 1 && el.getAttribute("slot") || keepSlot
                    if (type) {
                        if (slots[type]) {
                            slots[type].push(el)
                        } else {
                            slots[type] = [el]
                        }
                    }
                }
                if (vmodel.$$template) {
                    avalon.clearHTML(elem)
                    elem.innerHTML = vmodel.$$template(keepTemplate)
                }
                for (s in slots) {
                    if (vmodel.hasOwnProperty(s)) {
                        var ss = slots[s]
                        if (ss.length) {
                            var fragment = avalonFragment.cloneNode(true)
                            for (var ns = 0; snode = ss[ns++]; ) {
                                fragment.appendChild(snode)
                            }
                            vmodel[s] = fragment
                        }
                        slots[s] = null
                    }
                }
                slots = null
                var child = elem.children[0] || elem.firstChild
                if (keepReplace) {
                    elem.parentNode.replaceChild(child, elem)
                    child.msResolved = 1
                    var cssText = elem.style.cssText
                    var className = elem.className
                    elem = host.element = child
                    elem.style.cssText = cssText
                    if (className) {
                        avalon(elem).addClass(className)
                    }
                }
                if (keepContainer) {
                    keepContainer.appendChild(elem)
                }
                avalon.fireDom(elem, "datasetchanged",
                        {library: library, vm: vmodel, childReady: 1})
                var children = 0
                var removeFn = avalon.bind(elem, "datasetchanged", function (e) {
                    if (e.childReady && e.library === library) {
                        dependencies += e.childReady
                        if (vmodel !== e.vm) {
                            vmodel.$refs[e.vm.$id] = e.vm
                            if (e.childReady === -1) {
                                children++
                                vmodel.$childReady(vmodel, elem, e)
                            }
                            e.stopPropagation()
                        }
                    }
                    if (dependencies === 0) {
                        var id1 = setTimeout(function () {
                            clearTimeout(id1)
                            vmodel.$ready(vmodel, elem, host.vmodels)
                            global.$ready(vmodel, elem, host.vmodels)
                        }, children ? Math.max(children * 17, 100) : 17)
                        avalon.unbind(elem, "datasetchanged", removeFn)
                        //==================
                        host.rollback = function () {
                            try {
                                vmodel.$dispose(vmodel, elem)
                                global.$dispose(vmodel, elem)
                            } catch (e) {
                            }
                            delete avalon.vmodels[vmodel.$id]
                        }
                        injectDisposeQueue(host, widgetList)
                        if (window.chrome) {
                            elem.addEventListener("DOMNodeRemovedFromDocument", function () {
                                setTimeout(rejectDisposeQueue)
                            })
                        }
                    }
                })
                scanTag(elem, [vmodel].concat(host.vmodels))
                avalon.vmodels[vmodel.$id] = vmodel
                if (!elem.childNodes.length) {
                    avalon.fireDom(elem, "datasetchanged", {library: library, vm: vmodel, childReady: -1})
                } else {
                    var id2 = setTimeout(function () {
                        clearTimeout(id2)
                        avalon.fireDom(elem, "datasetchanged", {library: library, vm: vmodel, childReady: -1})
                    }, 17)
                }
            })(obj, avalon.components[name], obj.element, obj.widget)// jshint ignore:line
        }
    }
}
function getOptionsFromVM(vmodels, pre) {
    if (pre) {
        for (var i = 0, v; v = vmodels[i++]; ) {
            if (v.hasOwnProperty(pre) && typeof v[pre] === "object") {
                var vmOptions = v[pre]
                return vmOptions.$model || vmOptions
                break
            }
        }
    }
    return {}
}
avalon.libraries = []
avalon.library = function (name, opts) {
    if (DOC.namespaces) {
        DOC.namespaces.add(name, 'http://www.w3.org/1999/xhtml');
    }
    avalon.libraries[name] = avalon.mix({
        $init: noop,
        $ready: noop,
        $dispose: noop
    }, opts || {})
}
avalon.library("ms")
/*
 broswer  nodeName  scopeName  localName
 IE9     ONI:BUTTON oni        button
 IE10    ONI:BUTTON undefined  oni:button
 IE8     button     oni        undefined
 chrome  ONI:BUTTON undefined  oni:button
 
 */
function isWidget(el) { //如果为自定义标签,返回UI库的名字
    if (el.scopeName && el.scopeName !== "HTML") {
        return el.scopeName
    }
    var fullName = el.nodeName.toLowerCase()
    var index = fullName.indexOf(":")
    if (index > 0) {
        return fullName.slice(0, index)
    }
}
//各种MVVM框架在大型表格下的性能测试
// https://github.com/RubyLouvre/avalon/issues/859
var bools = ["autofocus,autoplay,async,allowTransparency,checked,controls",
    "declare,disabled,defer,defaultChecked,defaultSelected",
    "contentEditable,isMap,loop,multiple,noHref,noResize,noShade",
    "open,readOnly,selected"
].join(",")
var boolMap = {}
bools.replace(rword, function (name) {
    boolMap[name.toLowerCase()] = name
})
var propMap = {//属性名映射
    "accept-charset": "acceptCharset",
    "char": "ch",
    "charoff": "chOff",
    "class": "className",
    "for": "htmlFor",
    "http-equiv": "httpEquiv"
}
var anomaly = ["accessKey,bgColor,cellPadding,cellSpacing,codeBase,codeType,colSpan",
    "dateTime,defaultValue,frameBorder,longDesc,maxLength,marginWidth,marginHeight",
    "rowSpan,tabIndex,useMap,vSpace,valueType,vAlign"
].join(",")
anomaly.replace(rword, function (name) {
    propMap[name.toLowerCase()] = name
})
var attrDir = avalon.directive("attr", {
    init: function (binding) {
        //{{aaa}} --> aaa
        //{{aaa}}/bbb.html --> (aaa) + "/bbb.html"
        binding.expr = normalizeExpr(binding.expr.trim())
        if (binding.type === "include") {
            var elem = binding.element
            effectBinding(elem, binding)
            binding.includeRendered = getBindingCallback(elem, "data-include-rendered", binding.vmodels)
            binding.includeLoaded = getBindingCallback(elem, "data-include-loaded", binding.vmodels)
            var outer = binding.includeReplace = !!avalon(elem).data("includeReplace")
            if (avalon(elem).data("includeCache")) {
                binding.templateCache = {}
            }
            binding.start = DOC.createComment("ms-include")
            binding.end = DOC.createComment("ms-include-end")
            if (outer) {
                binding.element = binding.end
                binding._element = elem
                elem.parentNode.insertBefore(binding.start, elem)
                elem.parentNode.insertBefore(binding.end, elem.nextSibling)
            } else {
                elem.insertBefore(binding.start, elem.firstChild)
                elem.appendChild(binding.end)
            }
        }
    },
    update: function (val) {
        var elem = this.element
        var attrName = this.param
        if (attrName === "href" || attrName === "src") {
            if (typeof val === "string" && !root.hasAttribute) {
                val = val.replace(/&amp;/g, "&") //处理IE67自动转义的问题
            }
            elem[attrName] = val
            if (window.chrome && elem.tagName === "EMBED") {
                var parent = elem.parentNode //#525  chrome1-37下embed标签动态设置src不能发生请求
                var comment = document.createComment("ms-src")
                parent.replaceChild(comment, elem)
                parent.replaceChild(elem, comment)
            }
        } else {
            // ms-attr-class="xxx" vm.xxx="aaa bbb ccc"将元素的className设置为aaa bbb ccc
            // ms-attr-class="xxx" vm.xxx=false  清空元素的所有类名
            // ms-attr-name="yyy"  vm.yyy="ooo" 为元素设置name属性
            var toRemove = (val === false) || (val === null) || (val === void 0)
            if (!W3C && propMap[attrName]) { //旧式IE下需要进行名字映射
                attrName = propMap[attrName]
            }
            var bool = boolMap[attrName]
            if (typeof elem[bool] === "boolean") {
                elem[bool] = !!val //布尔属性必须使用el.xxx = true|false方式设值
                if (!val) { //如果为false, IE全系列下相当于setAttribute(xxx,''),会影响到样式,需要进一步处理
                    toRemove = true
                }
            }
            if (toRemove) {
                return elem.removeAttribute(attrName)
            }
            //SVG只能使用setAttribute(xxx, yyy), VML只能使用elem.xxx = yyy ,HTML的固有属性必须elem.xxx = yyy
            var isInnate = rsvg.test(elem) ? false : (DOC.namespaces && isVML(elem)) ? true : attrName in elem.cloneNode(false)
            if (isInnate) {
                elem[attrName] = val + ""
            } else {
                elem.setAttribute(attrName, val)
            }
        }
    }
})
//这几个指令都可以使用插值表达式,如ms-src="aaa/{{b}}/{{c}}.html"
"title,alt,src,value,css,include,href".replace(rword, function (name) {
    directives[name] = attrDir
})
//根据VM的属性值或表达式的值切换类名,ms-class="xxx yyy zzz:flag"
//http://www.cnblogs.com/rubylouvre/archive/2012/12/17/2818540.html
avalon.directive("class", {
    init: function (binding) {
        var oldStyle = binding.param
        var method = binding.type
        if (!oldStyle || isFinite(oldStyle)) {
            binding.param = "" //去掉数字
            directives.effect.init(binding)
        } else {
            log('ms-' + method + '-xxx="yyy"这种用法已经过时,请使用ms-' + method + '="xxx:yyy"')
            binding.expr = '[' + quote(oldStyle) + "," + binding.expr + "]"
            binding.oldStyle = oldStyle
        }
        if (method === "hover" || method === "active") { //确保只绑定一次
            if (!binding.hasBindEvent) {
                var elem = binding.element
                var $elem = avalon(elem)
                var activate = "mouseenter" //在移出移入时切换类名
                var abandon = "mouseleave"
                if (method === "active") { //在聚焦失焦中切换类名
                    elem.tabIndex = elem.tabIndex || -1
                    activate = "mousedown"
                    abandon = "mouseup"
                    var fn0 = $elem.bind("mouseleave", function () {
                        binding.toggleClass && $elem.removeClass(binding.newClass)
                    })
                }
            }
            var fn1 = $elem.bind(activate, function () {
                binding.toggleClass && $elem.addClass(binding.newClass)
            })
            var fn2 = $elem.bind(abandon, function () {
                binding.toggleClass && $elem.removeClass(binding.newClass)
            })
            binding.rollback = function () {
                $elem.unbind("mouseleave", fn0)
                $elem.unbind(activate, fn1)
                $elem.unbind(abandon, fn2)
            }
            binding.hasBindEvent = true
        }
    },
    update: function (arr) {
        var binding = this
        var $elem = avalon(this.element)
        binding.newClass = arr[0]
        binding.toggleClass = !!arr[1]
        if (binding.oldClass && binding.newClass !== binding.oldClass) {
            $elem.removeClass(binding.oldClass)
        }
        binding.oldClass = binding.newClass
        if (binding.type === "class") {
            if (binding.oldStyle) {
                $elem.toggleClass(binding.oldStyle, !!arr[1])
            } else {
                $elem.toggleClass(binding.newClass, binding.toggleClass)
            }
        }
    }
})
"hover,active".replace(rword, function (name) {
    directives[name] = directives["class"]
})
//ms-controller绑定已经在scanTag 方法中实现
avalon.directive("css", {
    init: directives.attr.init,
    update: function (val) {
        avalon(this.element).css(this.param, val)
    }
})
avalon.directive("data", {
    priority: 100,
    update: function (val) {
        var elem = this.element
        var key = "data-" + this.param
        if (val && typeof val === "object") {
            elem[key] = val
        } else {
            elem.setAttribute(key, String(val))
        }
    }
})
//双工绑定
var rduplexType = /^(?:checkbox|radio)$/
var rduplexParam = /^(?:radio|checked)$/
var rnoduplexInput = /^(file|button|reset|submit|checkbox|radio|range)$/
var duplexBinding = avalon.directive("duplex", {
    priority: 2000,
    init: function (binding, hasCast) {
        var elem = binding.element
        var vmodels = binding.vmodels
        binding.changed = getBindingCallback(elem, "data-duplex-changed", vmodels) || noop
        var params = []
        var casting = oneObject("string,number,boolean,checked")
        if (elem.type === "radio" && binding.param === "") {
            binding.param = "checked"
        }
        binding.param.replace(rw20g, function (name) {
            if (rduplexType.test(elem.type) && rduplexParam.test(name)) {
                if (name === "radio")
                    log("ms-duplex-radio已经更名为ms-duplex-checked")
                name = "checked"
                binding.isChecked = true
                binding.xtype = "radio"
            }
            if (name === "bool") {
                name = "boolean"
                log("ms-duplex-bool已经更名为ms-duplex-boolean")
            } else if (name === "text") {
                name = "string"
                log("ms-duplex-text已经更名为ms-duplex-string")
            }
            if (casting[name]) {
                hasCast = true
            }
            avalon.Array.ensure(params, name)
        })
        if (!hasCast) {
            params.push("string")
        }
        binding.param = params.join("-")
        if (!binding.xtype) {
            binding.xtype = elem.tagName === "SELECT" ? "select" :
                    elem.type === "checkbox" ? "checkbox" :
                    elem.type === "radio" ? "radio" :
                    /^change/.test(elem.getAttribute("data-duplex-event")) ? "change" :
                    "input"
        }
        //===================绑定事件======================
        var bound = binding.bound = function (type, callback) {
            elem.addEventListener(type, callback, false)
            var old = binding.rollback
            binding.rollback = function () {
                elem.avalonSetter = null
                avalon.unbind(elem, type, callback)
                old && old()
            }
        }
        function callback(value) {
            binding.changed.call(this, value, binding)
        }
        var composing = false
        function compositionStart() {
            composing = true
        }
        function compositionEnd() {
            composing = false
        }
        var updateVModel = function (e) {
            var val = elem.value //防止递归调用形成死循环
            if (composing || val === binding.oldValue || binding.pipe === null) //处理中文输入法在minlengh下引发的BUG
                return
            var lastValue = binding.pipe(val, binding, "get")
            binding.oldValue = val
            binding.setter(lastValue)
            callback.call(elem, lastValue)
        }
        switch (binding.xtype) {
            case "radio":
                bound("click", function () {
                    var lastValue = binding.pipe(elem.value, binding, "get")
                    binding.setter(lastValue)
                    callback.call(elem, lastValue)
                })
                break
            case "checkbox":
                bound("change", function () {
                    var method = elem.checked ? "ensure" : "remove"
                    var array = binding.getter.apply(0, binding.vmodels)
                    if (!Array.isArray(array)) {
                        log("ms-duplex应用于checkbox上要对应一个数组")
                        array = [array]
                    }
                    var val = binding.pipe(elem.value, binding, "get")
                    avalon.Array[method](array, val)
                    callback.call(elem, array)
                })
                break
            case "change":
                bound("change", updateVModel)
                break
            case "input":
                bound("input", updateVModel)
                bound("keyup", updateVModel)
                if (!IEVersion) {
                    bound("compositionstart", compositionStart)
                    bound("compositionend", compositionEnd)
                    bound("DOMAutoComplete", updateVModel)
                }
                break
            case "select":
                bound("change", function () {
                    var val = avalon(elem).val() //字符串或字符串数组
                    if (Array.isArray(val)) {
                        val = val.map(function (v) {
                            return binding.pipe(v, binding, "get")
                        })
                    } else {
                        val = binding.pipe(val, binding, "get")
                    }
                    if (val + "" !== binding.oldValue) {
                        try {
                            binding.setter(val)
                        } catch (ex) {
                            log(ex)
                        }
                    }
                })
                bound("datasetchanged", function (e) {
                    if (e.bubble === "selectDuplex") {
                        var value = binding._value
                        var curValue = Array.isArray(value) ? value.map(String) : value + ""
                        avalon(elem).val(curValue)
                        elem.oldValue = curValue + ""
                        callback.call(elem, curValue)
                    }
                })
                break
        }
        if (binding.xtype === "input" && !rnoduplexInput.test(elem.type)) {
            if (elem.type !== "hidden") {
                bound("focus", function () {
                    elem.msFocus = true
                })
                bound("blur", function () {
                    elem.msFocus = false
                })
            }
            elem.avalonSetter = updateVModel //#765
            watchValueInTimer(function () {
                if (root.contains(elem)) {
                    if (!elem.msFocus) {
                        updateVModel()
                    }
                } else if (!elem.msRetain) {
                    return false
                }
            })
        }
    },
    update: function (value) {
        var elem = this.element, binding = this, curValue
        if (!this.init) {
            for (var i in avalon.vmodels) {
                var v = avalon.vmodels[i]
                v.$fire("avalon-ms-duplex-init", binding)
            }
            var cpipe = binding.pipe || (binding.pipe = pipe)
            cpipe(null, binding, "init")
            this.init = 1
        }
        switch (this.xtype) {
            case "input":
            case "change":
                curValue = this.pipe(value, this, "set")  //fix #673
                if (curValue !== this.oldValue) {
                    var fixCaret = false
                    if (elem.msFocus) {
                        try {
                            var start = elem.selectionStart
                            var end = elem.selectionEnd
                            if (start === end) {
                                var pos = start
                                fixCaret = true
                            }
                        } catch (e) {
                        }
                    }
                    elem.value = this.oldValue = curValue
                    if (fixCaret && !elem.readOnly) {
                        elem.selectionStart = elem.selectionEnd = pos
                    }
                }
                break
            case "radio":
                curValue = binding.isChecked ? !!value : value + "" === elem.value
                elem.checked = curValue
                break
            case "checkbox":
                var array = [].concat(value) //强制转换为数组
                curValue = this.pipe(elem.value, this, "get")
                elem.checked = array.indexOf(curValue) > -1
                break
            case "select":
                //必须变成字符串后才能比较
                binding._value = value
                if (!elem.msHasEvent) {
                    elem.msHasEvent = "selectDuplex"
                    //必须等到其孩子准备好才触发
                } else {
                    avalon.fireDom(elem, "datasetchanged", {
                        bubble: elem.msHasEvent
                    })
                }
                break
        }
    }
})
function fixNull(val) {
    return val == null ? "" : val
}
avalon.duplexHooks = {
    checked: {
        get: function (val, binding) {
            return !binding.oldValue
        }
    },
    string: {
        get: function (val) { //同步到VM
            return val
        },
        set: fixNull
    },
    "boolean": {
        get: function (val) {
            return val === "true"
        },
        set: fixNull
    },
    number: {
        get: function (val, binding) {
            var number = parseFloat(val)
            if (-val === -number) {
                return number
            }
            var arr = /strong|medium|weak/.exec(binding.element.getAttribute("data-duplex-number")) || ["medium"]
            switch (arr[0]) {
                case "strong":
                    return 0
                case "medium":
                    return val === "" ? "" : 0
                case "weak":
                    return val
            }
        },
        set: fixNull
    }
}
function pipe(val, binding, action, e) {
    binding.param.replace(rw20g, function (name) {
        var hook = avalon.duplexHooks[name]
        if (hook && typeof hook[action] === "function") {
            val = hook[action](val, binding)
        }
    })
    return val
}
var TimerID, ribbon = []
avalon.tick = function (fn) {
    if (ribbon.push(fn) === 1) {
        TimerID = setInterval(ticker, 60)
    }
}
function ticker() {
    for (var n = ribbon.length - 1; n >= 0; n--) {
        var el = ribbon[n]
        if (el() === false) {
            ribbon.splice(n, 1)
        }
    }
    if (!ribbon.length) {
        clearInterval(TimerID)
    }
}
var watchValueInTimer = noop
new function () { // jshint ignore:line
    try { //#272 IE9-IE11, firefox
        var setters = {}
        var aproto = HTMLInputElement.prototype
        var bproto = HTMLTextAreaElement.prototype
        function newSetter(value) { // jshint ignore:line
            setters[this.tagName].call(this, value)
            if (!this.msFocus && this.avalonSetter) {
                this.avalonSetter()
            }
        }
        var inputProto = HTMLInputElement.prototype
        Object.getOwnPropertyNames(inputProto) //故意引发IE6-8等浏览器报错
        setters["INPUT"] = Object.getOwnPropertyDescriptor(aproto, "value").set
        Object.defineProperty(aproto, "value", {
            set: newSetter
        })
        setters["TEXTAREA"] = Object.getOwnPropertyDescriptor(bproto, "value").set
        Object.defineProperty(bproto, "value", {
            set: newSetter
        })
    } catch (e) {
        //在chrome 43中 ms-duplex终于不需要使用定时器实现双向绑定了
        // http://updates.html5rocks.com/2015/04/DOM-attributes-now-on-the-prototype
        // https://docs.google.com/document/d/1jwA8mtClwxI-QJuHT7872Z0pxpZz8PBkf2bGAbsUtqs/edit?pli=1
        watchValueInTimer = avalon.tick
    }
} // jshint ignore:line
avalon.directive("effect", {
    priority: 5,
    init: function (binding) {
        var text = binding.expr,
                className,
                rightExpr
        var colonIndex = text.replace(rexprg, function (a) {
            return a.replace(/./g, "0")
        }).indexOf(":") //取得第一个冒号的位置
        if (colonIndex === -1) { // 比如 ms-class/effect="aaa bbb ccc" 的情况
            className = text
            rightExpr = true
        } else { // 比如 ms-class/effect-1="ui-state-active:checked" 的情况
            className = text.slice(0, colonIndex)
            rightExpr = text.slice(colonIndex + 1)
        }
        if (!rexpr.test(text)) {
            className = quote(className)
        } else {
            className = normalizeExpr(className)
        }
        binding.expr = "[" + className + "," + rightExpr + "]"
    },
    update: function (arr) {
        var name = arr[0]
        var elem = this.element
        if (elem.getAttribute("data-effect-name") === name) {
            return
        } else {
            elem.removeAttribute("data-effect-driver")
        }
        var inlineStyles = elem.style
        var computedStyles = window.getComputedStyle ? window.getComputedStyle(elem) : null
        var useAni = false
        if (computedStyles && (supportTransition || supportAnimation)) {
            //如果支持CSS动画
            var duration = inlineStyles[transitionDuration] || computedStyles[transitionDuration]
            if (duration && duration !== '0s') {
                elem.setAttribute("data-effect-driver", "t")
                useAni = true
            }
            if (!useAni) {
                duration = inlineStyles[animationDuration] || computedStyles[animationDuration]
                if (duration && duration !== '0s') {
                    elem.setAttribute("data-effect-driver", "a")
                    useAni = true
                }
            }
        }
        if (!useAni) {
            if (avalon.effects[name]) {
                elem.setAttribute("data-effect-driver", "j")
                useAni = true
            }
        }
        if (useAni) {
            elem.setAttribute("data-effect-name", name)
        }
    }
})
avalon.effects = {}
avalon.effect = function (name, callbacks) {
    avalon.effects[name] = callbacks
}
var supportTransition = false
var supportAnimation = false
var transitionEndEvent
var animationEndEvent
var transitionDuration = avalon.cssName("transition-duration")
var animationDuration = avalon.cssName("animation-duration")
new function () {// jshint ignore:line
    var checker = {
        'TransitionEvent': 'transitionend',
        'WebKitTransitionEvent': 'webkitTransitionEnd',
        'OTransitionEvent': 'oTransitionEnd',
        'otransitionEvent': 'otransitionEnd'
    }
    var tran
    //有的浏览器同时支持私有实现与标准写法,比如webkit支持前两种,Opera支持1、3、4
    for (var name in checker) {
        if (window[name]) {
            tran = checker[name]
            break;
        }
        try {
            var a = document.createEvent(name);
            tran = checker[name]
            break;
        } catch (e) {
        }
    }
    if (typeof tran === "string") {
        supportTransition = true
        transitionEndEvent = tran
    }
    //大致上有两种选择
    //IE10+, Firefox 16+ & Opera 12.1+: animationend
    //Chrome/Safari: webkitAnimationEnd
    //http://blogs.msdn.com/b/davrous/archive/2011/12/06/introduction-to-css3-animat ions.aspx
    //IE10也可以使用MSAnimationEnd监听,但是回调里的事件 type依然为animationend
    //  el.addEventListener("MSAnimationEnd", function(e) {
    //     alert(e.type)// animationend!!!
    // })
    checker = {
        'AnimationEvent': 'animationend',
        'WebKitAnimationEvent': 'webkitAnimationEnd'
    }
    var ani;
    for (name in checker) {
        if (window[name]) {
            ani = checker[name];
            break;
        }
    }
    if (typeof ani === "string") {
        supportTransition = true
        animationEndEvent = ani
    }
}()
var effectPool = []//重复利用动画实例
function effectFactory(el, opts) {
    if (!el || el.nodeType !== 1) {
        return null
    }
    if (opts) {
        var name = opts.effectName
        var driver = opts.effectDriver
    } else {
        name = el.getAttribute("data-effect-name")
        driver = el.getAttribute("data-effect-driver")
    }
    if (!name || !driver) {
        return null
    }
    var instance = effectPool.pop() || new Effect()
    instance.el = el
    instance.driver = driver
    instance.useCss = driver !== "j"
    if (instance.useCss) {
        opts && avalon(el).addClass(opts.effectClass)
        instance.cssEvent = driver === "t" ? transitionEndEvent : animationEndEvent
    }
    instance.name = name
    instance.callbacks = avalon.effects[name] || {}
    return instance
}
function effectBinding(elem, binding) {
    var name = elem.getAttribute("data-effect-name")
    if (name) {
        binding.effectName = name
        binding.effectDriver = elem.getAttribute("data-effect-driver")
        var stagger = +elem.getAttribute("data-effect-stagger")
        binding.effectLeaveStagger = +elem.getAttribute("data-effect-leave-stagger") || stagger
        binding.effectEnterStagger = +elem.getAttribute("data-effect-enter-stagger") || stagger
        binding.effectClass = elem.className || NaN
    }
}
function upperFirstChar(str) {
    return str.replace(/^[\S]/g, function (m) {
        return m.toUpperCase()
    })
}
var effectBuffer = new Buffer()
function Effect() {
}// 动画实例,做成类的形式,是为了共用所有原型方法
Effect.prototype = {
    contrustor: Effect,
    enterClass: function () {
        return getEffectClass(this, "enter")
    },
    leaveClass: function () {
        return getEffectClass(this, "leave")
    },
    // 共享一个函数
    actionFun: function (name, before, after) {
        if (document.hidden) {
            return
        }
        var me = this
        var el = me.el
        var isLeave = name === "leave"
        name = isLeave ? "leave" : "enter"
        var oppositeName = isLeave ? "enter" : "leave"
        callEffectHook(me, "abort" + upperFirstChar(oppositeName))
        callEffectHook(me, "before" + upperFirstChar(name))
        if (!isLeave)
            before(el) //  这里可能做插入DOM树的操作,因此必须在修改类名前执行
        var cssCallback = function (cancel) {
            el.removeEventListener(me.cssEvent, me.cssCallback)
            if (isLeave) {
                before(el) //这里可能做移出DOM树操作,因此必须位于动画之后
                avalon(el).removeClass(me.cssClass)
            } else {
                if (me.driver === "a") {
                    avalon(el).removeClass(me.cssClass)
                }
            }
            if (cancel !== true) {
                callEffectHook(me, "after" + upperFirstChar(name))
                after && after(el)
            }
            me.dispose()
        }
        if (me.useCss) {
            if (me.cssCallback) { //如果leave动画还没有完成,立即完成
                me.cssCallback(true)
            }
            me.cssClass = getEffectClass(me, name)
            me.cssCallback = cssCallback
            me.update = function () {
                el.addEventListener(me.cssEvent, me.cssCallback)
                if (!isLeave && me.driver === "t") {//transtion延迟触发
                    avalon(el).removeClass(me.cssClass)
                }
            }
            avalon(el).addClass(me.cssClass)//animation会立即触发
            effectBuffer.render(true)
            effectBuffer.queue.push(me)
        } else {
            callEffectHook(me, name, cssCallback)
        }
    },
    enter: function (before, after) {
        this.actionFun.apply(this, ["enter"].concat(avalon.slice(arguments)))
    },
    leave: function (before, after) {
        this.actionFun.apply(this, ["leave"].concat(avalon.slice(arguments)))
    },
    dispose: function () {//销毁与回收到池子中
        this.update = this.cssCallback = null
        if (effectPool.unshift(this) > 100) {
            effectPool.pop()
        }
    }
}
function getEffectClass(instance, type) {
    var a = instance.callbacks[type + "Class"]
    if (typeof a === "string")
        return a
    if (typeof a === "function")
        return a()
    return instance.name + "-" + type
}
function callEffectHook(effect, name, cb) {
    var hook = effect.callbacks[name]
    if (hook) {
        hook.call(effect, effect.el, cb)
    }
}
var applyEffect = function (el, dir/*[before, [after, [opts]]]*/) {
    var args = aslice.call(arguments, 0)
    if (typeof args[2] !== "function") {
        args.splice(2, 0, noop)
    }
    if (typeof args[3] !== "function") {
        args.splice(3, 0, noop)
    }
    var before = args[2]
    var after = args[3]
    var opts = args[4]
    var effect = effectFactory(el, opts)
    if (!effect) {
        before()
        after()
        return false
    } else {
        var method = dir ? 'enter' : 'leave'
        effect[method](before, after)
    }
}
avalon.mix(avalon.effect, {
    apply: applyEffect,
    append: function (el, parent, after, opts) {
        return applyEffect(el, 1, function () {
            parent.appendChild(el)
        }, after, opts)
    },
    before: function (el, target, after, opts) {
        return applyEffect(el, 1, function () {
            target.parentNode.insertBefore(el, target)
        }, after, opts)
    },
    remove: function (el, parent, after, opts) {
        return applyEffect(el, 0, function () {
            if (el.parentNode === parent)
                parent.removeChild(el)
        }, after, opts)
    }
})
avalon.directive("html", {
    update: function (val) {
        var binding = this
        var elem = this.element
        var isHtmlFilter = elem.nodeType !== 1
        var parent = isHtmlFilter ? elem.parentNode : elem
        if (!parent)
            return
        val = val == null ? "" : val
        if (elem.nodeType === 3) {
            var signature = generateID("html")
            parent.insertBefore(DOC.createComment(signature), elem)
            binding.element = DOC.createComment(signature + ":end")
            parent.replaceChild(binding.element, elem)
            elem = binding.element
        }
        if (typeof val !== "object") {//string, number, boolean
            var fragment = avalon.parseHTML(String(val))
        } else if (val.nodeType === 11) { //将val转换为文档碎片
            fragment = val
        } else if (val.nodeType === 1 || val.item) {
            var nodes = val.nodeType === 1 ? val.childNodes : val.item
            fragment = avalonFragment.cloneNode(true)
            while (nodes[0]) {
                fragment.appendChild(nodes[0])
            }
        }
        nodes = avalon.slice(fragment.childNodes)
        //插入占位符, 如果是过滤器,需要有节制地移除指定的数量,如果是html指令,直接清空
        if (isHtmlFilter) {
            var endValue = elem.nodeValue.slice(0, -4)
            while (true) {
                var node = elem.previousSibling
                if (!node || node.nodeType === 8 && node.nodeValue === endValue) {
                    break
                } else {
                    parent.removeChild(node)
                }
            }
            parent.insertBefore(fragment, elem)
        } else {
            avalon.clearHTML(elem).appendChild(fragment)
        }
        scanNodeArray(nodes, binding.vmodels)
    }
})
avalon.directive("if", {
    priority: 10,
    update: function (val) {
        var binding = this
        var elem = this.element
        var stamp = binding.stamp = +new Date()
        var par
        var after = function () {
            if (stamp !== binding.stamp)
                return
            binding.recoverNode = null
        }
        if (binding.recoverNode)
            binding.recoverNode() // 还原现场,有移动节点的都需要还原现场
        try {
            if (!elem.parentNode)
                return
            par = elem.parentNode
        } catch (e) {
            return
        }
        if (val) { //插回DOM树
            function alway() {// jshint ignore:line
                if (elem.getAttribute(binding.name)) {
                    elem.removeAttribute(binding.name)
                    scanAttr(elem, binding.vmodels)
                }
                binding.rollback = null
            }
            if (elem.nodeType === 8) {
                var keep = binding.keep
                var hasEffect = avalon.effect.apply(keep, 1, function () {
                    if (stamp !== binding.stamp)
                        return
                    elem.parentNode.replaceChild(keep, elem)
                    elem = binding.element = keep //这时可能为null
                    if (keep.getAttribute("_required")) {//#1044
                        elem.required = true
                        elem.removeAttribute("_required")
                    }
                    if (elem.querySelectorAll) {
                        avalon.each(elem.querySelectorAll("[_required=true]"), function (el) {
                            el.required = true
                            el.removeAttribute("_required")
                        })
                    }
                    alway()
                }, after)
                hasEffect = hasEffect === false
            }
            if (!hasEffect)
                alway()
        } else { //移出DOM树,并用注释节点占据原位置
            if (elem.nodeType === 1) {
                if (elem.required === true) {
                    elem.required = false
                    elem.setAttribute("_required", "true")
                }
                try {// 如果不支持querySelectorAll或:required,可以直接无视
                    avalon.each(elem.querySelectorAll(":required"), function (el) {
                        elem.required = false
                        el.setAttribute("_required", "true")
                    })
                } catch (e) {
                }
                var node = binding.element = DOC.createComment("ms-if"),
                        pos = elem.nextSibling
                binding.recoverNode = function () {
                    binding.recoverNode = null
                    if (node.parentNode !== par) {
                        par.insertBefore(node, pos)
                        binding.keep = elem
                    }
                }
                avalon.effect.apply(elem, 0, function () {
                    binding.recoverNode = null
                    if (stamp !== binding.stamp)
                        return
                    elem.parentNode.replaceChild(node, elem)
                    binding.keep = elem //元素节点
                    ifGroup.appendChild(elem)
                    binding.rollback = function () {
                        if (elem.parentNode === ifGroup) {
                            ifGroup.removeChild(elem)
                        }
                    }
                }, after)
            }
        }
    }
})
//ms-important绑定已经在scanTag 方法中实现
var rnoscripts = /<noscript.*?>(?:[\s\S]+?)<\/noscript>/img
var rnoscriptText = /<noscript.*?>([\s\S]+?)<\/noscript>/im
var getXHR = function () {
    return new window.XMLHttpRequest() // jshint ignore:line
}
//将所有远程加载的模板,以字符串形式存放到这里
var templatePool = avalon.templateCache = {}
function getTemplateContainer(binding, id, text) {
    var div = binding.templateCache && binding.templateCache[id]
    if (div) {
        var dom = DOC.createDocumentFragment(),
                firstChild
        while (firstChild = div.firstChild) {
            dom.appendChild(firstChild)
        }
        return dom
    }
    return avalon.parseHTML(text)
}
function nodesToFrag(nodes) {
    var frag = DOC.createDocumentFragment()
    for (var i = 0, len = nodes.length; i < len; i++) {
        frag.appendChild(nodes[i])
    }
    return frag
}
avalon.directive("include", {
    init: directives.attr.init,
    update: function (val) {
        var binding = this
        var elem = this.element
        var vmodels = binding.vmodels
        var rendered = binding.includeRendered
        var effectClass = binding.effectName && binding.effectClass // 是否开启动画
        var templateCache = binding.templateCache // 是否data-include-cache
        var outer = binding.includeReplace // 是否data-include-replace
        var loaded = binding.includeLoaded
        var target = outer ? elem.parentNode : elem
        var _ele = binding._element // data-include-replace binding.element === binding.end
        binding.recoverNodes = binding.recoverNodes || avalon.noop
        var scanTemplate = function (text) {
            var _stamp = binding._stamp = +(new Date()) // 过滤掉频繁操作
            if (loaded) {
                var newText = loaded.apply(target, [text].concat(vmodels))
                if (typeof newText === "string")
                    text = newText
            }
            if (rendered) {
                checkScan(target, function () {
                    rendered.call(target)
                }, NaN)
            }
            var lastID = binding.includeLastID || "_default" // 默认
            binding.includeLastID = val
            var leaveEl = templateCache && templateCache[lastID] || DOC.createElement(elem.tagName || binding._element.tagName) // 创建一个离场元素
            if (effectClass) {
                leaveEl.className = effectClass
                target.insertBefore(leaveEl, binding.start) // 插入到start之前,防止被错误的移动
            }
            // cache or animate,移动节点
            (templateCache || {})[lastID] = leaveEl
            var fragOnDom = binding.recoverNodes() // 恢复动画中的节点
            if (fragOnDom) {
                target.insertBefore(fragOnDom, binding.end)
            }
            while (true) {
                var node = binding.start.nextSibling
                if (node && node !== leaveEl && node !== binding.end) {
                    leaveEl.appendChild(node)
                } else {
                    break
                }
            }
            // 元素退场
            avalon.effect.remove(leaveEl, target, function () {
                if (templateCache) { // write cache
                    if (_stamp === binding._stamp)
                        ifGroup.appendChild(leaveEl)
                }
            }, binding)
            var enterEl = target,
                    before = avalon.noop,
                    after = avalon.noop
            var fragment = getTemplateContainer(binding, val, text)
            var nodes = avalon.slice(fragment.childNodes)
            if (outer && effectClass) {
                enterEl = _ele
                enterEl.innerHTML = "" // 清空
                enterEl.setAttribute("ms-skip", "true")
                target.insertBefore(enterEl, binding.end.nextSibling) // 插入到bingding.end之后避免被错误的移动
                before = function () {
                    enterEl.insertBefore(fragment, null) // 插入节点
                }
                after = function () {
                    binding.recoverNodes = avalon.noop
                    if (_stamp === binding._stamp) {
                        fragment = nodesToFrag(nodes)
                        target.insertBefore(fragment, binding.end) // 插入真实element
                        scanNodeArray(nodes, vmodels)
                    }
                    if (enterEl.parentNode === target)
                        target.removeChild(enterEl) // 移除入场动画元素
                }
                binding.recoverNodes = function () {
                    binding.recoverNodes = avalon.noop
                    return nodesToFrag(nodes)
                }
            } else {
                before = function () {// 新添加元素的动画 
                    target.insertBefore(fragment, binding.end)
                    scanNodeArray(nodes, vmodels)
                }
            }
            avalon.effect.apply(enterEl, "enter", before, after)
        }
        if (binding.param === "src") {
            if (typeof templatePool[val] === "string") {
                avalon.nextTick(function () {
                    scanTemplate(templatePool[val])
                })
            } else if (Array.isArray(templatePool[val])) { //#805 防止在循环绑定中发出许多相同的请求
                templatePool[val].push(scanTemplate)
            } else {
                var xhr = getXHR()
                xhr.onload = function () {
                    var text = xhr.responseText
                    for (var f = 0, fn; fn = templatePool[val][f++]; ) {
                        fn(text)
                    }
                    templatePool[val] = text
                }
                xhr.onerror = function () {
                    log("ms-include load [" + val + "] error")
                }
                templatePool[val] = [scanTemplate]
                xhr.open("GET", val, true)
                if ("withCredentials" in xhr) {
                    xhr.withCredentials = true
                }
                xhr.setRequestHeader("X-Requested-With", "XMLHttpRequest")
                xhr.send(null)
            }
        } else {
            //IE系列与够新的标准浏览器支持通过ID取得元素(firefox14+)
            //http://tjvantoll.com/2012/07/19/dom-element-references-as-global-variables/
            var el = val && val.nodeType === 1 ? val : DOC.getElementById(val)
            if (el) {
                avalon.nextTick(function () {
                    scanTemplate(el.value || el.innerText || el.innerHTML)
                })
            }
        }
    }
})
var rdash = /\(([^)]*)\)/
var onDir = avalon.directive("on", {
    priority: 3000,
    init: function (binding) {
        var value = binding.expr
        binding.type = "on"
        var eventType = binding.param.replace(/-\d+$/, "") // ms-on-mousemove-10
        if (typeof onDir[eventType + "Hook"] === "function") {
            onDir[eventType + "Hook"](binding)
        }
        if (value.indexOf("(") > 0 && value.indexOf(")") > -1) {
            var matched = (value.match(rdash) || ["", ""])[1].trim()
            if (matched === "" || matched === "$event") { // aaa() aaa($event)当成aaa处理
                value = value.replace(rdash, "")
            }
        }
        binding.expr = value
    },
    update: function (callback) {
        var binding = this
        var elem = this.element
        callback = function (e) {
            var fn = binding.getter || noop
            return fn.apply(this, binding.args.concat(e))
        }
        
        var eventType = binding.param.replace(/-\d+$/, "") // ms-on-mousemove-10
        if (eventType === "scan") {
            callback.call(elem, {
                type: eventType
            })
        } else if (typeof binding.specialBind === "function") {
            binding.specialBind(elem, callback)
        } else {
            var removeFn = avalon.bind(elem, eventType, callback)
        }
        binding.rollback = function () {
            if (typeof binding.specialUnbind === "function") {
                binding.specialUnbind()
            } else {
                avalon.unbind(elem, eventType, removeFn)
            }
        }
    }
})
avalon.directive("repeat", {
    priority: 90,
    init: function (binding) {
        var type = binding.type
        binding.cache = {} //用于存放代理VM
        binding.enterCount = 0
        var elem = binding.element
        if (elem.nodeType === 1) {
            elem.removeAttribute(binding.name)
            effectBinding(elem, binding)
            binding.param = binding.param || "el"
            binding.sortedCallback = getBindingCallback(elem, "data-with-sorted", binding.vmodels)
            var rendered = getBindingCallback(elem, "data-" + type + "-rendered", binding.vmodels)
            var signature = generateID(type)
            var start = DOC.createComment(signature + ":start")
            var end = binding.element = DOC.createComment(signature + ":end")
            binding.signature = signature
            binding.start = start
            binding.template = avalonFragment.cloneNode(false)
            if (type === "repeat") {
                var parent = elem.parentNode
                parent.replaceChild(end, elem)
                parent.insertBefore(start, end)
                binding.template.appendChild(elem)
            } else {
                while (elem.firstChild) {
                    binding.template.appendChild(elem.firstChild)
                }
                elem.appendChild(start)
                elem.appendChild(end)
                parent = elem
            }
            binding.element = end
            if (rendered) {
                var removeFn = avalon.bind(parent, "datasetchanged", function () {
                    rendered.apply(parent, parent.args)
                    avalon.unbind(parent, "datasetchanged", removeFn)
                    parent.msRendered = rendered
                })
            }
        }
    },
    update: function (value, oldValue) {
        var binding = this
        var xtype = this.xtype
        this.enterCount += 1
        var init = !oldValue
        if (init) {
            binding.$outer = {}
            var check0 = "$key"
            var check1 = "$val"
            if (xtype === "array") {
                check0 = "$first"
                check1 = "$last"
            }
            for (var i = 0, v; v = binding.vmodels[i++]; ) {
                if (v.hasOwnProperty(check0) && v.hasOwnProperty(check1)) {
                    binding.$outer = v
                    break
                }
            }
        }
        var track = this.track
        if (binding.sortedCallback) { //如果有回调,则让它们排序
            var keys2 = binding.sortedCallback.call(parent, track)
            if (keys2 && Array.isArray(keys2)) {
                track = keys2
            }
        }
        var action = "move"
        binding.$repeat = value
        var fragments = []
        var transation = init && avalonFragment.cloneNode(false)
        var proxies = []
        var param = this.param
        var retain = avalon.mix({}, this.cache)
        var elem = this.element
        var length = track.length
        var parent = elem.parentNode
        for (i = 0; i < length; i++) {
            var keyOrId = track[i] //array为随机数, object 为keyName
            var proxy = retain[keyOrId]
            if (!proxy) {
                
                proxy = getProxyVM(this)
                proxy.$up = null
                if (xtype === "array") {
                    action = "add"
                    proxy.$id = keyOrId
                    var valueItem = value[i]
                    proxy[param] = valueItem //index
                    if(Object(valueItem) === valueItem){
                        valueItem.$ups = valueItem.$ups || {}
                        valueItem.$ups[param] = proxy
                    }
                } else {
                    action = "append"
                    proxy.$key = keyOrId
                    proxy.$val = value[keyOrId] //key
                }
                this.cache[keyOrId] = proxy
                var node = proxy.$anchor || (proxy.$anchor = elem.cloneNode(false))
                node.nodeValue = this.signature
                shimController(binding, transation, proxy, fragments, init && !binding.effectDriver)
                decorateProxy(proxy, binding, xtype)
            } else {
//                if (xtype === "array") {
//                    proxy[param] = value[i]
//                }
                fragments.push({})
                retain[keyOrId] = true
            }
            //重写proxy
            if (this.enterCount === 1) {// 防止多次进入,导致位置不对
                proxy.$active = false
                proxy.$oldIndex = proxy.$index
                proxy.$active = true
                proxy.$index = i
            }
            if (xtype === "array") {
                proxy.$first = i === 0
                proxy.$last = i === length - 1
                // proxy[param] = value[i]
            } else {
                proxy.$val = toJson(value[keyOrId]) // 这里是处理vm.object = newObject的情况 
            }
            proxies.push(proxy)
        }
        this.proxies = proxies
        if (init && !binding.effectDriver) {
            parent.insertBefore(transation, elem)
            fragments.forEach(function (fragment) {
                scanNodeArray(fragment.nodes || [], fragment.vmodels)
                //if(fragment.vmodels.length > 2)
                fragment.nodes = fragment.vmodels = null
            })// jshint ignore:line
        } else {
            var staggerIndex = binding.staggerIndex = 0
            for (keyOrId in retain) {
                if (retain[keyOrId] !== true) {
                    action = "del"
                    removeItem(retain[keyOrId].$anchor, binding)
                    // avalon.log("删除", keyOrId)
                    // 相当于delete binding.cache[key]
                    proxyRecycler(this.cache, keyOrId, param)
                    retain[keyOrId] = null
                }
            }
            //  console.log(effectEnterStagger)
            for (i = 0; i < length; i++) {
                proxy = proxies[i]
                keyOrId = xtype === "array" ? proxy.$id : proxy.$key
                var pre = proxies[i - 1]
                var preEl = pre ? pre.$anchor : binding.start
                if (!retain[keyOrId]) {//如果还没有插入到DOM树
                    (function (fragment, preElement) {
                        var nodes = fragment.nodes
                        var vmodels = fragment.vmodels
                        if (nodes) {
                            staggerIndex = mayStaggerAnimate(binding.effectEnterStagger, function () {
                                parent.insertBefore(fragment.content, preElement.nextSibling)
                                scanNodeArray(nodes, vmodels)
                                animateRepeat(nodes, 1, binding)
                            }, staggerIndex)
                        }
                        fragment.nodes = fragment.vmodels = null
                    })(fragments[i], preEl)// jshint ignore:line
                    // avalon.log("插入")
                } else if (proxy.$index !== proxy.$oldIndex) {
                    (function (proxy2, preElement) {
                        staggerIndex = mayStaggerAnimate(binding.effectEnterStagger, function () {
                            var curNode = removeItem(proxy2.$anchor)// 如果位置被挪动了
                            var inserted = avalon.slice(curNode.childNodes)
                            parent.insertBefore(curNode, preElement.nextSibling)
                            animateRepeat(inserted, 1, binding)
                        }, staggerIndex)
                    })(proxy, preEl)// jshint ignore:line
                    // avalon.log("移动", proxy.$oldIndex, "-->", proxy.$index)
                }
            }
        }
        if (!value.$track) {//如果是非监控对象,那么就将其$events清空,阻止其持续监听
            for (keyOrId in this.cache) {
                proxyRecycler(this.cache, keyOrId, param)
            }
        }
        //repeat --> duplex
        (function (args) {
            parent.args = args
            if (parent.msRendered) {//第一次事件触发,以后直接调用
                parent.msRendered.apply(parent, args)
            }
        })(kernel.newWatch ? arguments : [action]);
        var id = setTimeout(function () {
            clearTimeout(id)
            //触发上层的select回调及自己的rendered回调
            avalon.fireDom(parent, "datasetchanged", {
                bubble: parent.msHasEvent
            })
        })
        this.enterCount -= 1
    }
})
"with,each".replace(rword, function (name) {
    directives[name] = avalon.mix({}, directives.repeat, {
        priority: 1400
    })
})
function animateRepeat(nodes, isEnter, binding) {
    for (var i = 0, node; node = nodes[i++]; ) {
        if (node.className === binding.effectClass) {
            avalon.effect.apply(node, isEnter, noop, noop, binding)
        }
    }
}
function mayStaggerAnimate(staggerTime, callback, index) {
    if (staggerTime) {
        setTimeout(callback, (++index) * staggerTime)
    } else {
        callback()
    }
    return index
}
function removeItem(node, binding) {
    var fragment = avalonFragment.cloneNode(false)
    var last = node
    var breakText = last.nodeValue
    var staggerIndex = binding && Math.max(+binding.staggerIndex, 0)
    var nodes = avalon.slice(last.parentNode.childNodes)
    var index = nodes.indexOf(last)
    while (true) {
        var pre = nodes[--index] //node.previousSibling
        if (!pre || String(pre.nodeValue).indexOf(breakText) === 0) {
            break
        }
        if (binding && (pre.className === binding.effectClass)) {
            node = pre;
            (function (cur) {
                binding.staggerIndex = mayStaggerAnimate(binding.effectLeaveStagger, function () {
                    avalon.effect.apply(cur, 0, noop, function () {
                        fragment.appendChild(cur)
                    }, binding)
                }, staggerIndex)
            })(pre);// jshint ignore:line
        } else {
            fragment.insertBefore(pre, fragment.firstChild)
        }
    }
    fragment.appendChild(last)
    return fragment
}
function shimController(data, transation, proxy, fragments, init) {
    var content = data.template.cloneNode(true)
    var nodes = avalon.slice(content.childNodes)
    content.appendChild(proxy.$anchor)
    init && transation.appendChild(content)
    var nv = [proxy].concat(data.vmodels)
    var fragment = {
        nodes: nodes,
        vmodels: nv,
        content: content
    }
    fragments.push(fragment)
}
// {}  -->  {xx: 0, yy: 1, zz: 2} add
// {xx: 0, yy: 1, zz: 2}  -->  {xx: 0, yy: 1, zz: 2, uu: 3}
// [xx: 0, yy: 1, zz: 2}  -->  {xx: 0, zz: 1, yy: 2}
function getProxyVM(binding) {
    var agent = binding.xtype === "object" ? withProxyAgent : eachProxyAgent
    var proxy = agent(binding)
    var node = proxy.$anchor || (proxy.$anchor = binding.element.cloneNode(false))
    node.nodeValue = binding.signature
    proxy.$outer = binding.$outer
    return proxy
}
var eachProxyPool = []
function eachProxyAgent(data, proxy) {
    var itemName = data.param || "el"
    for (var i = 0, n = eachProxyPool.length; i < n; i++) {
        var candidate = eachProxyPool[i]
        if (candidate && candidate.hasOwnProperty(itemName)) {
            eachProxyPool.splice(i, 1)
            proxy = candidate
            break
        }
    }
    if (!proxy) {
        proxy = eachProxyFactory(itemName)
    }
    return proxy
}
function eachProxyFactory(itemName) {
    var source = {
        $outer: {},
        $index: 0,
        $oldIndex: 0,
        $anchor: null,
        //-----
        $first: false,
        $last: false,
        $remove: avalon.noop
    }
    source[itemName] = NaN
    var force = {
        $last: 1,
        $first: 1,
        $index: 1
    }
    force[itemName] = 1
    var proxy = modelFactory(source, {
        force: force
    })
    proxy.$id = generateID("$proxy$each")
    return proxy
}
function decorateProxy(proxy, binding, type) {
    if (type === "array") {
        proxy.$remove = function () {
            binding.$repeat.removeAt(proxy.$index)
        }
        var param = binding.param
        proxy.$watch(param, function (a) {
            var index = proxy.$index
            binding.$repeat[index] = a
        })
    } else {
        proxy.$watch("$val", function fn(a) {
            binding.$repeat[proxy.$key] = a
        })
    }
}
var withProxyPool = []
function withProxyAgent() {
    return withProxyPool.pop() || withProxyFactory()
}
function withProxyFactory() {
    var proxy = modelFactory({
        $key: "",
        $val: NaN,
        $index: 0,
        $oldIndex: 0,
        $outer: {},
        $anchor: null
    }, {
        force: {
            $key: 1,
            $val: 1,
            $index: 1
        }
    })
    proxy.$id = generateID("$proxy$with")
    return proxy
}
function proxyRecycler(cache, key, param) {
    var proxy = cache[key]
    if (proxy) {
        var proxyPool = proxy.$id.indexOf("$proxy$each") === 0 ? eachProxyPool : withProxyPool
        proxy.$outer = {}
        for (var i in proxy.$events) {
            var a = proxy.$events[i]
            if (Array.isArray(a)) {
                a.length = 0
                if (i === param) {
                    proxy[param] = NaN
                } else if (i === "$val") {
                    proxy.$val = NaN
                }
            }
        }
        if (proxyPool.unshift(proxy) > kernel.maxRepeatSize) {
            proxyPool.pop()
        }
        delete cache[key]
    }
}
/*********************************************************************
 *                         各种指令                                  *
 **********************************************************************/
//ms-skip绑定已经在scanTag 方法中实现
avalon.directive("text", {
    update: function (val) {
        var elem = this.element
        val = val == null ? "" : val //不在页面上显示undefined null
        if (elem.nodeType === 3) { //绑定在文本节点上
            try { //IE对游离于DOM树外的节点赋值会报错
                elem.data = val
            } catch (e) {
            }
        } else { //绑定在特性节点上
            elem.textContent = val
        }
    }
})
function parseDisplay(nodeName, val) {
    //用于取得此类标签的默认display值
    var key = "_" + nodeName
    if (!parseDisplay[key]) {
        var node = DOC.createElement(nodeName)
        root.appendChild(node)
        if (W3C) {
            val = getComputedStyle(node, null).display
        } else {
            val = node.currentStyle.display
        }
        root.removeChild(node)
        parseDisplay[key] = val
    }
    return parseDisplay[key]
}
avalon.parseDisplay = parseDisplay
avalon.directive("visible", {
    init: function (binding) {
        effectBinding(binding.element, binding)
    },
    update: function (val) {
        var binding = this, elem = this.element, stamp
        var noEffect = !this.effectName
        if (!this.stamp) {
            stamp = this.stamp = +new Date
            if (val) {
                elem.style.display = binding.display || ""
                if (avalon(elem).css("display") === "none") {
                    elem.style.display = binding.display = parseDisplay(elem.nodeName)
                }
            } else {
                elem.style.display = "none"
            }
            return
        }
        stamp = this.stamp = +new Date
        if (val) {
            avalon.effect.apply(elem, 1, function () {
                if (stamp !== binding.stamp)
                    return
                var driver = elem.getAttribute("data-effect-driver") || "a"
                if (noEffect) {//不用动画时走这里
                    elem.style.display = binding.display || ""
                }
                // "a", "t"
                if (driver === "a" || driver === "t") {
                    if (avalon(elem).css("display") === "none") {
                        elem.style.display = binding.display || parseDisplay(elem.nodeName)
                    }
                }
            })
        } else {
            avalon.effect.apply(elem, 0, function () {
                if (stamp !== binding.stamp)
                    return
                elem.style.display = "none"
            })
        }
    }
})
/*********************************************************************
 *                             自带过滤器                            *
 **********************************************************************/
var rscripts = /<script[^>]*>([\S\s]*?)<\/script\s*>/gim
var ron = /\s+(on[^=\s]+)(?:=("[^"]*"|'[^']*'|[^\s>]+))?/g
var ropen = /<\w+\b(?:(["'])[^"]*?(\1)|[^>])*>/ig
var rsanitize = {
    a: /\b(href)\=("javascript[^"]*"|'javascript[^']*')/ig,
    img: /\b(src)\=("javascript[^"]*"|'javascript[^']*')/ig,
    form: /\b(action)\=("javascript[^"]*"|'javascript[^']*')/ig
}
var rsurrogate = /[\uD800-\uDBFF][\uDC00-\uDFFF]/g
var rnoalphanumeric = /([^\#-~| |!])/g;
function numberFormat(number, decimals, point, thousands) {
    //form http://phpjs.org/functions/number_format/
    //number	必需,要格式化的数字
    //decimals	可选,规定多少个小数位。
    //point	可选,规定用作小数点的字符串(默认为 . )。
    //thousands	可选,规定用作千位分隔符的字符串(默认为 , ),如果设置了该参数,那么所有其他参数都是必需的。
    number = (number + '')
            .replace(/[^0-9+\-Ee.]/g, '')
    var n = !isFinite(+number) ? 0 : +number,
            prec = !isFinite(+decimals) ? 3 : Math.abs(decimals),
            sep = thousands || ",",
            dec = point || ".",
            s = '',
            toFixedFix = function(n, prec) {
                var k = Math.pow(10, prec)
                return '' + (Math.round(n * k) / k)
                        .toFixed(prec)
            }
    // Fix for IE parseFloat(0.55).toFixed(0) = 0;
    s = (prec ? toFixedFix(n, prec) : '' + Math.round(n))
            .split('.')
    if (s[0].length > 3) {
        s[0] = s[0].replace(/\B(?=(?:\d{3})+(?!\d))/g, sep)
    }
    if ((s[1] || '')
            .length < prec) {
        s[1] = s[1] || ''
        s[1] += new Array(prec - s[1].length + 1)
                .join('0')
    }
    return s.join(dec)
}
var filters = avalon.filters = {
    uppercase: function(str) {
        return str.toUpperCase()
    },
    lowercase: function(str) {
        return str.toLowerCase()
    },
    truncate: function(str, length, truncation) {
        //length,新字符串长度,truncation,新字符串的结尾的字段,返回新字符串
        length = length || 30
        truncation = typeof truncation === "string" ?  truncation : "..." 
        return str.length > length ? str.slice(0, length - truncation.length) + truncation : String(str)
    },
    $filter: function(val) {
        for (var i = 1, n = arguments.length; i < n; i++) {
            var array = arguments[i]
            var fn = avalon.filters[array[0]]
            if (typeof fn === "function") {
                var arr = [val].concat(array.slice(1))
                val = fn.apply(null, arr)
            }
        }
        return val
    },
    camelize: camelize,
    //https://www.owasp.org/index.php/XSS_Filter_Evasion_Cheat_Sheet
    //    <a href="javasc&NewLine;ript&colon;alert('XSS')">chrome</a> 
    //    <a href="data:text/html;base64, PGltZyBzcmM9eCBvbmVycm9yPWFsZXJ0KDEpPg==">chrome</a>
    //    <a href="jav	ascript:alert('XSS');">IE67chrome</a>
    //    <a href="jav&#x09;ascript:alert('XSS');">IE67chrome</a>
    //    <a href="jav&#x0A;ascript:alert('XSS');">IE67chrome</a>
    sanitize: function(str) {
        return str.replace(rscripts, "").replace(ropen, function(a, b) {
            var match = a.toLowerCase().match(/<(\w+)\s/)
            if (match) { //处理a标签的href属性,img标签的src属性,form标签的action属性
                var reg = rsanitize[match[1]]
                if (reg) {
                    a = a.replace(reg, function(s, name, value) {
                        var quote = value.charAt(0)
                        return name + "=" + quote + "javascript:void(0)" + quote// jshint ignore:line
                    })
                }
            }
            return a.replace(ron, " ").replace(/\s+/g, " ") //移除onXXX事件
        })
    },
    escape: function(str) {
        //将字符串经过 str 转义得到适合在页面中显示的内容, 例如替换 < 为 &lt 
        return String(str).
                replace(/&/g, '&amp;').
                replace(rsurrogate, function(value) {
                    var hi = value.charCodeAt(0)
                    var low = value.charCodeAt(1)
                    return '&#' + (((hi - 0xD800) * 0x400) + (low - 0xDC00) + 0x10000) + ';'
                }).
                replace(rnoalphanumeric, function(value) {
                    return '&#' + value.charCodeAt(0) + ';'
                }).
                replace(/</g, '&lt;').
                replace(/>/g, '&gt;')
    },
    currency: function(amount, symbol, fractionSize) {
        return (symbol || "\uFFE5") + numberFormat(amount, isFinite(fractionSize) ? fractionSize : 2)
    },
    number: numberFormat
}
/*
 'yyyy': 4 digit representation of year (e.g. AD 1 => 0001, AD 2010 => 2010)
 'yy': 2 digit representation of year, padded (00-99). (e.g. AD 2001 => 01, AD 2010 => 10)
 'y': 1 digit representation of year, e.g. (AD 1 => 1, AD 199 => 199)
 'MMMM': Month in year (January-December)
 'MMM': Month in year (Jan-Dec)
 'MM': Month in year, padded (01-12)
 'M': Month in year (1-12)
 'dd': Day in month, padded (01-31)
 'd': Day in month (1-31)
 'EEEE': Day in Week,(Sunday-Saturday)
 'EEE': Day in Week, (Sun-Sat)
 'HH': Hour in day, padded (00-23)
 'H': Hour in day (0-23)
 'hh': Hour in am/pm, padded (01-12)
 'h': Hour in am/pm, (1-12)
 'mm': Minute in hour, padded (00-59)
 'm': Minute in hour (0-59)
 'ss': Second in minute, padded (00-59)
 's': Second in minute (0-59)
 'a': am/pm marker
 'Z': 4 digit (+sign) representation of the timezone offset (-1200-+1200)
 format string can also be one of the following predefined localizable formats:
 
 'medium': equivalent to 'MMM d, y h:mm:ss a' for en_US locale (e.g. Sep 3, 2010 12:05:08 pm)
 'short': equivalent to 'M/d/yy h:mm a' for en_US locale (e.g. 9/3/10 12:05 pm)
 'fullDate': equivalent to 'EEEE, MMMM d,y' for en_US locale (e.g. Friday, September 3, 2010)
 'longDate': equivalent to 'MMMM d, y' for en_US locale (e.g. September 3, 2010
 'mediumDate': equivalent to 'MMM d, y' for en_US locale (e.g. Sep 3, 2010)
 'shortDate': equivalent to 'M/d/yy' for en_US locale (e.g. 9/3/10)
 'mediumTime': equivalent to 'h:mm:ss a' for en_US locale (e.g. 12:05:08 pm)
 'shortTime': equivalent to 'h:mm a' for en_US locale (e.g. 12:05 pm)
 */
new function() {// jshint ignore:line
    function toInt(str) {
        return parseInt(str, 10) || 0
    }
    function padNumber(num, digits, trim) {
        var neg = ""
        if (num < 0) {
            neg = '-'
            num = -num
        }
        num = "" + num
        while (num.length < digits)
            num = "0" + num
        if (trim)
            num = num.substr(num.length - digits)
        return neg + num
    }
    function dateGetter(name, size, offset, trim) {
        return function(date) {
            var value = date["get" + name]()
            if (offset > 0 || value > -offset)
                value += offset
            if (value === 0 && offset === -12) {
                value = 12
            }
            return padNumber(value, size, trim)
        }
    }
    function dateStrGetter(name, shortForm) {
        return function(date, formats) {
            var value = date["get" + name]()
            var get = (shortForm ? ("SHORT" + name) : name).toUpperCase()
            return formats[get][value]
        }
    }
    function timeZoneGetter(date) {
        var zone = -1 * date.getTimezoneOffset()
        var paddedZone = (zone >= 0) ? "+" : ""
        paddedZone += padNumber(Math[zone > 0 ? "floor" : "ceil"](zone / 60), 2) + padNumber(Math.abs(zone % 60), 2)
        return paddedZone
    }
    //取得上午下午
    function ampmGetter(date, formats) {
        return date.getHours() < 12 ? formats.AMPMS[0] : formats.AMPMS[1]
    }
    var DATE_FORMATS = {
        yyyy: dateGetter("FullYear", 4),
        yy: dateGetter("FullYear", 2, 0, true),
        y: dateGetter("FullYear", 1),
        MMMM: dateStrGetter("Month"),
        MMM: dateStrGetter("Month", true),
        MM: dateGetter("Month", 2, 1),
        M: dateGetter("Month", 1, 1),
        dd: dateGetter("Date", 2),
        d: dateGetter("Date", 1),
        HH: dateGetter("Hours", 2),
        H: dateGetter("Hours", 1),
        hh: dateGetter("Hours", 2, -12),
        h: dateGetter("Hours", 1, -12),
        mm: dateGetter("Minutes", 2),
        m: dateGetter("Minutes", 1),
        ss: dateGetter("Seconds", 2),
        s: dateGetter("Seconds", 1),
        sss: dateGetter("Milliseconds", 3),
        EEEE: dateStrGetter("Day"),
        EEE: dateStrGetter("Day", true),
        a: ampmGetter,
        Z: timeZoneGetter
    }
    var rdateFormat = /((?:[^yMdHhmsaZE']+)|(?:'(?:[^']|'')*')|(?:E+|y+|M+|d+|H+|h+|m+|s+|a|Z))(.*)/
    var raspnetjson = /^\/Date\((\d+)\)\/$/
    filters.date = function(date, format) {
        var locate = filters.date.locate,
                text = "",
                parts = [],
                fn, match
        format = format || "mediumDate"
        format = locate[format] || format
        if (typeof date === "string") {
            if (/^\d+$/.test(date)) {
                date = toInt(date)
            } else if (raspnetjson.test(date)) {
                date = +RegExp.$1
            } else {
                var trimDate = date.trim()
                var dateArray = [0, 0, 0, 0, 0, 0, 0]
                var oDate = new Date(0)
                //取得年月日
                trimDate = trimDate.replace(/^(\d+)\D(\d+)\D(\d+)/, function(_, a, b, c) {
                    var array = c.length === 4 ? [c, a, b] : [a, b, c]
                    dateArray[0] = toInt(array[0])     //年
                    dateArray[1] = toInt(array[1]) - 1 //月
                    dateArray[2] = toInt(array[2])     //日
                    return ""
                })
                var dateSetter = oDate.setFullYear
                var timeSetter = oDate.setHours
                trimDate = trimDate.replace(/[T\s](\d+):(\d+):?(\d+)?\.?(\d)?/, function(_, a, b, c, d) {
                    dateArray[3] = toInt(a) //小时
                    dateArray[4] = toInt(b) //分钟
                    dateArray[5] = toInt(c) //秒
                    if (d) {                //毫秒
                        dateArray[6] = Math.round(parseFloat("0." + d) * 1000)
                    }
                    return ""
                })
                var tzHour = 0
                var tzMin = 0
                trimDate = trimDate.replace(/Z|([+-])(\d\d):?(\d\d)/, function(z, symbol, c, d) {
                    dateSetter = oDate.setUTCFullYear
                    timeSetter = oDate.setUTCHours
                    if (symbol) {
                        tzHour = toInt(symbol + c)
                        tzMin = toInt(symbol + d)
                    }
                    return ""
                })
                dateArray[3] -= tzHour
                dateArray[4] -= tzMin
                dateSetter.apply(oDate, dateArray.slice(0, 3))
                timeSetter.apply(oDate, dateArray.slice(3))
                date = oDate
            }
        }
        if (typeof date === "number") {
            date = new Date(date)
        }
        if (avalon.type(date) !== "date") {
            return
        }
        while (format) {
            match = rdateFormat.exec(format)
            if (match) {
                parts = parts.concat(match.slice(1))
                format = parts.pop()
            } else {
                parts.push(format)
                format = null
            }
        }
        parts.forEach(function(value) {
            fn = DATE_FORMATS[value]
            text += fn ? fn(date, locate) : value.replace(/(^'|'$)/g, "").replace(/''/g, "'")
        })
        return text
    }
    var locate = {
        AMPMS: {
            0: "上午",
            1: "下午"
        },
        DAY: {
            0: "星期日",
            1: "星期一",
            2: "星期二",
            3: "星期三",
            4: "星期四",
            5: "星期五",
            6: "星期六"
        },
        MONTH: {
            0: "1月",
            1: "2月",
            2: "3月",
            3: "4月",
            4: "5月",
            5: "6月",
            6: "7月",
            7: "8月",
            8: "9月",
            9: "10月",
            10: "11月",
            11: "12月"
        },
        SHORTDAY: {
            "0": "周日",
            "1": "周一",
            "2": "周二",
            "3": "周三",
            "4": "周四",
            "5": "周五",
            "6": "周六"
        },
        fullDate: "y年M月d日EEEE",
        longDate: "y年M月d日",
        medium: "yyyy-M-d H:mm:ss",
        mediumDate: "yyyy-M-d",
        mediumTime: "H:mm:ss",
        "short": "yy-M-d ah:mm",
        shortDate: "yy-M-d",
        shortTime: "ah:mm"
    }
    locate.SHORTMONTH = locate.MONTH
    filters.date.locate = locate
}// jshint ignore:line
/*********************************************************************
 *                      AMD加载器                                   *
 **********************************************************************/
//https://www.devbridge.com/articles/understanding-amd-requirejs/
//http://maxogden.com/nested-dependencies.html
var modules = avalon.modules = {
    "domReady!": {
        exports: avalon,
        state: 3
    },
    "avalon": {
        exports: avalon,
        state: 4
    }
}
//Object(modules[id]).state拥有如下值 
// undefined  没有定义
// 1(send)    已经发出请求
// 2(loading) 已经被执行但还没有执行完成,在这个阶段define方法会被执行
// 3(loaded)  执行完毕,通过onload/onreadystatechange回调判定,在这个阶段checkDeps方法会执行
// 4(execute)  其依赖也执行完毕, 值放到exports对象上,在这个阶段fireFactory方法会执行
modules.exports = modules.avalon
var otherRequire = window.require
var otherDefine = window.define
var innerRequire
plugins.loader = function (builtin) {
    var flag = innerRequire && builtin
    window.require = flag ? innerRequire : otherRequire
    window.define = flag ? innerRequire.define : otherDefine
}
new function () {// jshint ignore:line
    var loadings = [] //正在加载中的模块列表
    var factorys = [] //放置define方法的factory函数
    var rjsext = /\.js$/i
    function makeRequest(name, config) {
//1. 去掉资源前缀
        var res = "js"
        name = name.replace(/^(\w+)\!/, function (a, b) {
            res = b
            return ""
        })
        if (res === "ready") {
            log("debug: ready!已经被废弃,请使用domReady!")
            res = "domReady"
        }
//2. 去掉querystring, hash
        var query = ""
        name = name.replace(rquery, function (a) {
            query = a
            return ""
        })
        //3. 去掉扩展名
        var suffix = "." + res
        var ext = /js|css/.test(suffix) ? suffix : ""
        name = name.replace(/\.[a-z0-9]+$/g, function (a) {
            if (a === suffix) {
                ext = a
                return ""
            } else {
                return a
            }
        })
        var req = avalon.mix({
            query: query,
            ext: ext,
            res: res,
            name: name,
            toUrl: toUrl
        }, config)
        req.toUrl(name)
        return req
    }
    function fireRequest(req) {
        var name = req.name
        var res = req.res
        //1. 如果该模块已经发出请求,直接返回
        var module = modules[name]
        var urlNoQuery = name && req.urlNoQuery
        if (module && module.state >= 1) {
            return name
        }
        module = modules[urlNoQuery]
        if (module && module.state >= 3) {
            innerRequire(module.deps || [], module.factory, urlNoQuery)
            return urlNoQuery
        }
        if (name && !module) {
            module = modules[urlNoQuery] = {
                id: urlNoQuery,
                state: 1 //send
            }
            var wrap = function (obj) {
                resources[res] = obj
                obj.load(name, req, function (a) {
                    if (arguments.length && a !== void 0) {
                        module.exports = a
                    }
                    module.state = 4
                    checkDeps()
                })
            }
            if (!resources[res]) {
                innerRequire([res], wrap)
            } else {
                wrap(resources[res])
            }
        }
        return name ? urlNoQuery : res + "!"
    }
//核心API之一 require
    var requireQueue = []
    var isUserFirstRequire = false
    innerRequire = avalon.require = function (array, factory, parentUrl, defineConfig) {
        if (!isUserFirstRequire) {
            requireQueue.push(avalon.slice(arguments))
            if (arguments.length <= 2) {
                isUserFirstRequire = true
                var queue = requireQueue.splice(0, requireQueue.length), args
                while (args = queue.shift()) {
                    innerRequire.apply(null, args)
                }
            }
            return
        }
        if (!Array.isArray(array)) {
            avalon.error("require方法的第一个参数应为数组 " + array)
        }
        var deps = [] // 放置所有依赖项的完整路径
        var uniq = createMap()
        var id = parentUrl || "callback" + setTimeout("1")// jshint ignore:line
        defineConfig = defineConfig || createMap()
        defineConfig.baseUrl = kernel.baseUrl
        var isBuilt = !!defineConfig.built
        if (parentUrl) {
            defineConfig.parentUrl = parentUrl.substr(0, parentUrl.lastIndexOf("/"))
            defineConfig.mapUrl = parentUrl.replace(rjsext, "")
        }
        if (isBuilt) {
            var req = makeRequest(defineConfig.defineName, defineConfig)
            id = req.urlNoQuery
        } else {
            array.forEach(function (name) {
                var req = makeRequest(name, defineConfig)
                var url = fireRequest(req) //加载资源,并返回该资源的完整地址
                if (url) {
                    if (!uniq[url]) {
                        deps.push(url)
                        uniq[url] = "司徒正美" //去重
                    }
                }
            })
        }
        var module = modules[id]
        if (!module || module.state !== 4) {
            modules[id] = {
                id: id,
                deps: isBuilt ? array.concat() : deps,
                factory: factory || noop,
                state: 3
            }
        }
        if (!module) {
            //如果此模块是定义在另一个JS文件中, 那必须等该文件加载完毕, 才能放到检测列队中
            loadings.push(id)
        }
        checkDeps()
    }
//核心API之二 require
    innerRequire.define = function (name, deps, factory) { //模块名,依赖列表,模块本身
        if (typeof name !== "string") {
            factory = deps
            deps = name
            name = "anonymous"
        }
        if (!Array.isArray(deps)) {
            factory = deps
            deps = []
        }
        var config = {
            built: !isUserFirstRequire, //用r.js打包后,所有define会放到requirejs之前
            defineName: name
        }
        var args = [deps, factory, config]
        factory.require = function (url) {
            args.splice(2, 0, url)
            if (modules[url]) {
                modules[url].state = 3 //loaded
                var isCycle = false
                try {
                    isCycle = checkCycle(modules[url].deps, url)
                } catch (e) {
                }
                if (isCycle) {
                    avalon.error(url + "模块与之前的模块存在循环依赖,请不要直接用script标签引入" + url + "模块")
                }
            }
            delete factory.require //释放内存
            innerRequire.apply(null, args) //0,1,2 --> 1,2,0
        }
//根据标准,所有遵循W3C标准的浏览器,script标签会按标签的出现顺序执行。
//老的浏览器中,加载也是按顺序的:一个文件下载完成后,才开始下载下一个文件。
//较新的浏览器中(IE8+ 、FireFox3.5+ 、Chrome4+ 、Safari4+),为了减小请求时间以优化体验,
//下载可以是并行的,但是执行顺序还是按照标签出现的顺序。
//但如果script标签是动态插入的, 就未必按照先请求先执行的原则了,目测只有firefox遵守
//唯一比较一致的是,IE10+及其他标准浏览器,一旦开始解析脚本, 就会一直堵在那里,直接脚本解析完毕
//亦即,先进入loading阶段的script标签(模块)必然会先进入loaded阶段
        var url = config.built ? "unknown" : getCurrentScript()
        if (url) {
            var module = modules[url]
            if (module) {
                module.state = 2
            }
            factory.require(url)
        } else {//合并前后的safari,合并后的IE6-9走此分支
            factorys.push(factory)
        }
    }
    //核心API之三 require.config(settings)
    innerRequire.config = kernel
    //核心API之四 define.amd 标识其符合AMD规范
    innerRequire.define.amd = modules
    //==========================对用户配置项进行再加工==========================
    var allpaths = kernel["orig.paths"] = createMap()
    var allmaps = kernel["orig.map"] = createMap()
    var allpackages = kernel["packages"] = []
    var allargs = kernel["orig.args"] = createMap()
    avalon.mix(plugins, {
        paths: function (hash) {
            avalon.mix(allpaths, hash)
            kernel.paths = makeIndexArray(allpaths)
        },
        map: function (hash) {
            avalon.mix(allmaps, hash)
            var list = makeIndexArray(allmaps, 1, 1)
            avalon.each(list, function (_, item) {
                item.val = makeIndexArray(item.val)
            })
            kernel.map = list
        },
        packages: function (array) {
            array = array.concat(allpackages)
            var uniq = createMap()
            var ret = []
            for (var i = 0, pkg; pkg = array[i++]; ) {
                pkg = typeof pkg === "string" ? {name: pkg} : pkg
                var name = pkg.name
                if (!uniq[name]) {
                    var url = joinPath(pkg.location || name, pkg.main || "main")
                    url = url.replace(rjsext, "")
                    ret.push(pkg)
                    uniq[name] = pkg.location = url
                    pkg.reg = makeMatcher(name)
                }
            }
            kernel.packages = ret.sort()
        },
        urlArgs: function (hash) {
            if (typeof hash === "string") {
                hash = {"*": hash}
            }
            avalon.mix(allargs, hash)
            kernel.urlArgs = makeIndexArray(allargs, 1)
        },
        baseUrl: function (url) {
            if (!isAbsUrl(url)) {
                var baseElement = head.getElementsByTagName("base")[0]
                if (baseElement) {
                    head.removeChild(baseElement)
                }
                var node = DOC.createElement("a")
                node.href = url
                url = node.href
                if (baseElement) {
                    head.insertBefore(baseElement, head.firstChild)
                }
            }
            if (url.length > 3)
                kernel.baseUrl = url
        },
        shim: function (obj) {
            for (var i in obj) {
                var value = obj[i]
                if (Array.isArray(value)) {
                    value = obj[i] = {
                        deps: value
                    }
                }
                if (!value.exportsFn && (value.exports || value.init)) {
                    value.exportsFn = makeExports(value)
                }
            }
            kernel.shim = obj
        }
    })
    //==============================内部方法=================================
    function checkCycle(deps, nick) {
        //检测是否存在循环依赖
        for (var i = 0, id; id = deps[i++]; ) {
            if (modules[id].state !== 4 &&
                    (id === nick || checkCycle(modules[id].deps, nick))) {
                return true
            }
        }
    }
    function checkFail(node, onError) {
        var id = trimQuery(node.src) //检测是否死链
        node.onload = node.onerror = null
        if (onError) {
            setTimeout(function () {
                head.removeChild(node)
                node = null // 处理旧式IE下的循环引用问题
            })
            log("debug: 加载 " + id + " 失败" + onError + " " + (!modules[id].state))
        } else {
            return true
        }
    }
    function checkDeps() {
        //检测此JS模块的依赖是否都已安装完毕,是则安装自身
        loop: for (var i = loadings.length, id; id = loadings[--i]; ) {
            var obj = modules[id],
                    deps = obj.deps
            if (!deps)
                continue
            for (var j = 0, key; key = deps[j]; j++) {
                if (Object(modules[key]).state !== 4) {
                    continue loop
                }
            }
            //如果deps是空对象或者其依赖的模块的状态都是4
            if (obj.state !== 4) {
                loadings.splice(i, 1) //必须先移除再安装,防止在IE下DOM树建完后手动刷新页面,会多次执行它
                fireFactory(obj.id, obj.deps, obj.factory)
                checkDeps() //如果成功,则再执行一次,以防有些模块就差本模块没有安装好
            }
        }
    }
    function loadJS(url, id, callback) {
        //通过script节点加载目标模块
        var node = DOC.createElement("script")
        node.className = subscribers //让getCurrentScript只处理类名为subscribers的script节点
        node.onload = function () {
            var factory = factorys.pop()
            factory && factory.require(id)
            if (callback) {
                callback()
            }
            log("debug: 已成功加载 " + url)
            id && loadings.push(id)
            checkDeps()
        }
        node.onerror = function () {
            checkFail(node, true)
        }
        head.insertBefore(node, head.firstChild) //chrome下第二个参数不能为null
        node.src = url //插入到head的第一个节点前,防止IE6下head标签没闭合前使用appendChild抛错
        log("debug: 正准备加载 " + url) //更重要的是IE6下可以收窄getCurrentScript的寻找范围
    }
    var resources = innerRequire.plugins = {
        //三大常用资源插件 js!, css!, text!, domReady!
        domReady: {
            load: noop
        },
        js: {
            load: function (name, req, onLoad) {
                var url = req.url
                var id = req.urlNoQuery
                var shim = kernel.shim[name.replace(rjsext, "")]
                if (shim) { //shim机制
                    innerRequire(shim.deps || [], function () {
                        var args = avalon.slice(arguments)
                        loadJS(url, id, function () {
                            onLoad(shim.exportsFn ? shim.exportsFn.apply(0, args) : void 0)
                        })
                    })
                } else {
                    loadJS(url, id)
                }
            }
        },
        css: {
            load: function (name, req, onLoad) {
                var url = req.url
                head.insertAdjacentHTML("afterBegin", '<link rel="stylesheet" href="' + url + '">')
                log("debug: 已成功加载 " + url)
                onLoad()
            }
        },
        text: {
            load: function (name, req, onLoad) {
                var url = req.url
                var xhr = getXHR()
                xhr.onload = function () {
                    var status = xhr.status;
                    if (status > 399 && status < 600) {
                        avalon.error(url + " 对应资源不存在或没有开启 CORS")
                    } else {
                        log("debug: 已成功加载 " + url)
                        onLoad(xhr.responseText)
                    }
                }
                var time = "_=" + (new Date() - 0)
                var _url = url.indexOf("?") === -1 ? url + "?" + time : url + "&" + time
                xhr.open("GET", _url, true)
                if ("withCredentials" in xhr) {//这是处理跨域
                    xhr.withCredentials = true
                }
                xhr.setRequestHeader("X-Requested-With", "XMLHttpRequest")//告诉后端这是AJAX请求
                xhr.send()
                log("debug: 正准备加载 " + url)
            }
        }
    }
    innerRequire.checkDeps = checkDeps
    var rquery = /(\?[^#]*)$/
    function trimQuery(url) {
        return (url || "").replace(rquery, "")
    }
    function isAbsUrl(path) {
        //http://stackoverflow.com/questions/10687099/how-to-test-if-a-url-string-is-absolute-or-relative
        return  /^(?:[a-z]+:)?\/\//i.test(String(path))
    }
    function getCurrentScript() {
        // inspireb by https://github.com/samyk/jiagra/blob/master/jiagra.js
        var stack
        try {
            a.b.c() //强制报错,以便捕获e.stack
        } catch (e) { //safari5的sourceURL,firefox的fileName,它们的效果与e.stack不一样
            stack = e.stack
        }
        if (stack) {
            /**e.stack最后一行在所有支持的浏览器大致如下:
             *chrome23:
             * at http://113.93.50.63/data.js:4:1
             *firefox17:
             *@http://113.93.50.63/query.js:4
             *opera12:http://www.oldapps.com/opera.php?system=Windows_XP
             *@http://113.93.50.63/data.js:4
             *IE10:
             *  at Global code (http://113.93.50.63/data.js:4:1)
             *  //firefox4+ 可以用document.currentScript
             */
            stack = stack.split(/[@ ]/g).pop() //取得最后一行,最后一个空格或@之后的部分
            stack = stack[0] === "(" ? stack.slice(1, -1) : stack.replace(/\s/, "") //去掉换行符
            return trimQuery(stack.replace(/(:\d+)?:\d+$/i, "")) //去掉行号与或许存在的出错字符起始位置
        }
        var nodes = head.getElementsByTagName("script") //只在head标签中寻找
        for (var i = nodes.length, node; node = nodes[--i]; ) {
            if (node.className === subscribers && node.readyState === "interactive") {
                var url = node.src
                return node.className = trimQuery(url)
            }
        }
    }
    var rcallback = /^callback\d+$/
    function fireFactory(id, deps, factory) {
        var module = Object(modules[id])
        module.state = 4
        for (var i = 0, array = [], d; d = deps[i++]; ) {
            if (d === "exports") {
                var obj = module.exports || (module.exports = createMap())
                array.push(obj)
            } else {
                array.push(modules[d].exports)
            }
        }
        try {
            var ret = factory.apply(window, array)
        } catch (e) {
            log("执行[" + id + "]模块的factory抛错: ", e)
        }
        if (ret !== void 0) {
            module.exports = ret
        }
        if (rcallback.test(id)) {
            delete modules[id]
        }
        delete module.factory
        return ret
    }
    function toUrl(id) {
        if (id.indexOf(this.res + "!") === 0) {
            id = id.slice(this.res.length + 1) //处理define("css!style",[], function(){})的情况
        }
        var url = id
        //1. 是否命中paths配置项
        var usePath = 0
        var baseUrl = this.baseUrl
        var rootUrl = this.parentUrl || baseUrl
        eachIndexArray(id, kernel.paths, function (value, key) {
            url = url.replace(key, value)
            usePath = 1
        })
        //2. 是否命中packages配置项
        if (!usePath) {
            eachIndexArray(id, kernel.packages, function (value, key, item) {
                url = url.replace(item.name, item.location)
            })
        }
        //3. 是否命中map配置项
        if (this.mapUrl) {
            eachIndexArray(this.mapUrl, kernel.map, function (array) {
                eachIndexArray(url, array, function (mdValue, mdKey) {
                    url = url.replace(mdKey, mdValue)
                    rootUrl = baseUrl
                })
            })
        }
        var ext = this.ext
        if (ext && usePath && url.slice(-ext.length) === ext) {
            url = url.slice(0, -ext.length)
        }
        //4. 转换为绝对路径
        if (!isAbsUrl(url)) {
            rootUrl = this.built || /^\w/.test(url) ? baseUrl : rootUrl
            url = joinPath(rootUrl, url)
        }
        //5. 还原扩展名,query
        var urlNoQuery = url + ext
        url = urlNoQuery + this.query
        urlNoQuery = url.replace(rquery, function (a) {
          this.query = a
          return ""
        })
        //6. 处理urlArgs
        eachIndexArray(id, kernel.urlArgs, function (value) {
            url += (url.indexOf("?") === -1 ? "?" : "&") + value;
        })
        this.url = url
        return  this.urlNoQuery = urlNoQuery
    }
    function makeIndexArray(hash, useStar, part) {
        //创建一个经过特殊算法排好序的数组
        var index = hash2array(hash, useStar, part)
        index.sort(descSorterByName)
        return index
    }
    function makeMatcher(prefix) {
        return new RegExp('^' + prefix + '(/|$)')
    }
    function makeExports(value) {
        return function () {
            var ret
            if (value.init) {
                ret = value.init.apply(window, arguments)
            }
            return ret || (value.exports && getGlobal(value.exports))
        }
    }
    function hash2array(hash, useStar, part) {
        var array = [];
        for (var key in hash) {
            // if (hash.hasOwnProperty(key)) {//hash是由createMap创建没有hasOwnProperty
            var item = {
                name: key,
                val: hash[key]
            }
            array.push(item)
            item.reg = key === "*" && useStar ? /^/ : makeMatcher(key)
            if (part && key !== "*") {
                item.reg = new RegExp('\/' + key.replace(/^\//, "") + '(/|$)')
            }
            //   }
        }
        return array
    }
    function eachIndexArray(moduleID, array, matcher) {
        array = array || []
        for (var i = 0, el; el = array[i++]; ) {
            if (el.reg.test(moduleID)) {
                matcher(el.val, el.name, el)
                return false
            }
        }
    }
    // 根据元素的name项进行数组字符数逆序的排序函数
    function descSorterByName(a, b) {
        var aaa = a.name
        var bbb = b.name
        if (bbb === "*") {
            return -1
        }
        if (aaa === "*") {
            return 1
        }
        return bbb.length - aaa.length
    }
    var rdeuce = /\/\w+\/\.\./
    function joinPath(a, b) {
        if (a.charAt(a.length - 1) !== "/") {
            a += "/"
        }
        if (b.slice(0, 2) === "./") { //相对于兄弟路径
            return a + b.slice(2)
        }
        if (b.slice(0, 2) === "..") { //相对于父路径
            a += b
            while (rdeuce.test(a)) {
                a = a.replace(rdeuce, "")
            }
            return a
        }
        if (b.slice(0, 1) === "/") {
            return a + b.slice(1)
        }
        return a + b
    }
    function getGlobal(value) {
        if (!value) {
            return value
        }
        var g = window
        value.split(".").forEach(function (part) {
            g = g[part]
        })
        return g
    }
    var mainNode = DOC.scripts[DOC.scripts.length - 1]
    var dataMain = mainNode.getAttribute("data-main")
    if (dataMain) {
        plugins.baseUrl(dataMain)
        var href = kernel.baseUrl
        kernel.baseUrl = href.slice(0, href.lastIndexOf("/") + 1)
        loadJS(href.replace(rjsext, "") + ".js")
    } else {
        var loaderUrl = trimQuery(mainNode.src)
        kernel.baseUrl = loaderUrl.slice(0, loaderUrl.lastIndexOf("/") + 1)
    }
}// jshint ignore:line
/*********************************************************************
 *                    DOMReady                                         *
 **********************************************************************/
var readyList = [],
    isReady
var fireReady = function (fn) {
    isReady = true
    var require = avalon.require
    if (require && require.checkDeps) {
        modules["domReady!"].state = 4
        require.checkDeps()
    }
    while (fn = readyList.shift()) {
        fn(avalon)
    }
}
if (DOC.readyState === "complete") {
    setTimeout(fireReady) //如果在domReady之外加载
} else {
    DOC.addEventListener("DOMContentLoaded", fireReady)
}
window.addEventListener("load", fireReady)
avalon.ready = function (fn) {
    if (!isReady) {
        readyList.push(fn)
    } else {
        fn(avalon)
    }
}
avalon.config({
    loader: false
})
avalon.ready(function () {
    avalon.scan(DOC.body)
})
// Register as a named AMD module, since avalon can be concatenated with other
// files that may use define, but not via a proper concatenation script that
// understands anonymous AMD modules. A named AMD is safest and most robust
// way to register. Lowercase avalon is used because AMD module names are
// derived from file names, and Avalon is normally delivered in a lowercase
// file name. Do this after creating the global so that if an AMD module wants
// to call noConflict to hide this version of avalon, it will work.
// Note that for maximum portability, libraries that are not avalon should
// declare themselves as anonymous modules, and avoid setting a global if an
// AMD loader is present. avalon is a special case. For more information, see
// https://github.com/jrburke/requirejs/wiki/Updating-existing-libraries#wiki-anon
    if (typeof define === "function" && define.amd) {
        define("avalon", [], function() {
            return avalon
        })
    }
// Map over avalon in case of overwrite
    var _avalon = window.avalon
    avalon.noConflict = function(deep) {
        if (deep && window.avalon === avalon) {
            window.avalon = _avalon
        }
        return avalon
    }
// Expose avalon identifiers, even in AMD
// and CommonJS for browser emulators
    if (noGlobal === void 0) {
        window.avalon = avalon
    }
    return avalon
}));

+ 126 - 0
html/jkda/js/elastic-columns.js

@ -0,0 +1,126 @@
(function($)
{
    $.elasticColumns = function(element, options)
    {
        this.defaults =
        {
            columns:        3,
            innerMargin:    10,
            outerMargin:    10
        };
        this.settings =   {};
        this.$element =   $(element);
        this.columns =    [];
        /**
         * Inits
         */
        this.init = function()
        {
            this.settings = $.extend({}, this.defaults, options);
            this.buildLayout();
        };
        /**
         * Builds the layout using the given settings
         */
        this.buildLayout = function()
        {
            var $items =           this.$element.children(':not(.elastic-columns-ignore)');
            var container_width =  this.$element.width();
            var column_width =     (container_width - (this.settings.innerMargin * (this.settings.columns - 1)) - (this.settings.outerMargin * 2)) / this.settings.columns;
            for(var index = 0; index < this.settings.columns; index += 1)
            {
                this.columns[index] = this.settings.outerMargin;
            }
            // Iterates into elements
            for(var item_id = 0; item_id < $items.length; item_id += 1)
            {
                var $item = $($items.get(item_id));
                // Looks for the smallest column
                var smallest_column = 0;
                for(var column_id = 0; column_id < this.settings.columns; column_id += 1)
                {
                    if (this.columns[column_id] < this.columns[smallest_column])
                    {
                        smallest_column = column_id;
                    }
                }
                // Gets the item padding
                var horizontal_padding =    parseInt($item.css('padding-left') )+ parseInt($item.css('padding-right'));
                var vertical_padding =      parseInt($item.css('padding-top') )+ parseInt($item.css('padding-bottom'));
                // Sets the item CSS properties
                $item.css('position', 'absolute');
                $item.css('width', (column_width - horizontal_padding) + 'px');
                $item.css('left', (this.settings.outerMargin + (this.settings.innerMargin * smallest_column) + (smallest_column * column_width)) + 'px');
                $item.css('top', this.columns[smallest_column] + 'px');
                // Updates columns height
                this.columns[smallest_column] += $item.outerHeight() + this.settings.innerMargin + vertical_padding;
            }
            // Looks for the highest column and sets the container height
            var highest_column = 0;
            for(var column_id = 0; column_id < this.settings.columns; column_id += 1)
            {
                if (this.columns[column_id] > this.columns[highest_column])
                {
                    highest_column = column_id;
                }
            }
            this.$element.outerHeight(this.columns[highest_column] + 'px');
        };
        /**
         * Destroys the layout restoring its initial appearance
         */
        this.destroyLayout = function()
        {
            // Iterates into elements and clear the styles set by the plugin
            var $items = this.$element.children(':not(.elastic-columns-ignore)');
            for(var item_id = 0; item_id < $items.length; item_id += 1)
            {
                var $item = $($items.get(item_id));
                $item.css({'position':'','width':'','left':'','top':''});
            }
            // Restores the container's height
            this.$element.css({'height':''});
        };
    };
    $.fn.elasticColumns = function(options, option, value)
    {
        return this.each(function()
        {
            // Plugin instanciation
            var plugin = $(this).data('elasticColumns');
            if (typeof plugin == 'undefined')
            {
                plugin = new $.elasticColumns(this, options);
                $(this).data('elasticColumns', plugin);
                plugin.init();
            }
            // API calls
            else
            {
                if (options == 'refresh')
                {
                    plugin.buildLayout();
                }
                if (options == 'set')
                {
                    plugin.settings[option] = value;
                }
                if (options == 'destroy')
                {
                    plugin.destroyLayout();
                }
            }
        });
    }
})(jQuery);

+ 309 - 0
html/jkda/js/event-profile.js

@ -0,0 +1,309 @@
var Profile = {
	url: '',
	link: '',
	thatEventId: '',
	thatPromise: null,
	thatTempalteCode: '',
	thatSerial: '',
	thatPageContent: null,
	index: 0,
	firstCode: '',
	profileRes: [],
	dc: [],
	htmlStr:['<div id="no_result_wrap" style="margin-top: 85px;">',
				'<img class="no-result-img" src="../../../images/shujuweikong_img.png" />',
				'<div class="f-fs14 c-323232 c-t-center" style="text-align:center">抱歉,暂未找到符合条件的结果。</div>',
			'</div>'].join(''),
	init: function (ops) {
		var me = this;
		if (!(!!ops && typeof ops === 'object')) {
			showTip('参数有误!');
			return;
		}
		ops.cb && ops.cb.call(me);
		me.url = ops.url;
		me.link = ops.link;
		me.thatPromise = ops.thatPromise;
		me.thatEventId = ops.thatEventId;
		me.thatTempalteCode = ops.thatTempalteCode;
		me.thatSerial = ops.thatSerial;
		me.thatPageContent = ops.thatPageContent;
		me.index = 0;
		me.firstCode = '';
		me.profileRes = [];
		me.dc = [];
		window['dataCode']=[];
	},
	//获取模板
	templateRequest: function () {
		var me = this;
		return new me.thatPromise(function(resolve, reject) {
			$.ajax('../template/'+me.thatTempalteCode+'.html', 
			{ dataType: 'html',
			  type:'GET', 
			  error: function(xht, type, throwErr) {
			  	showTip("档案模板获取失败。");
			  },
			  success: function(html) {
			  	resolve(html);
			  }
			})
		})
	},
	//根据thatTempalteCode获取数据
	profileDataRequest: function () {
		var me = this;
		return getReqPromise( me.url,{
								event: me.thatEventId ,	// 事件ID
								catalog: me.thatTempalteCode, // 档案类型
								serial: me.thatSerial || "1"  // 该类别顺序号,默认填1
							},'JSON','GET');
	},
	promiseAll: function () {
		var me = this,
			fistDc = me.thatTempalteCode;
		Promise.all([ me.templateRequest(), me.profileDataRequest()]).then(function (datas) {
			if(datas[1].data){
				var html = datas[0];
				me.profileRes.push(datas[1]);
				me.thatPageContent.html(html);
				me.firstCode = me.thatTempalteCode;
				me.dc = window['dataCode'];
				if (me.dc.length > 0) {
					me.reqDataMore(me);
				} else {
					me.changeData(fistDc);
				}
			}else{
				plus.nativeUI.closeWaiting();
				mui.toast('档案数据为空');
			}
		}).catch(function(e) {d.close();console && console.error(e);});
	}, 
	//获取多个数据
	reqDataMore: function (me) {
		me.thatTempalteCode = me.dc[me.index];
		Promise.all([ me.profileDataRequest()]).then(function (datas) {
			me.profileRes.push(datas[0]);
			me.index++;
			if (me.dc.length > me.index) {
				me.reqDataMore(me);
			} else {
				me.changeData(me.firstCode);
			}
		});
	},
	
	changeData: function (fistDc) {
		var me = this,
			jsonData = [];
		me.dc.unshift(me.firstCode);
		$.each( me.profileRes, function (index) {
			jsonData.push(me.selectXmlDom(me.profileRes[index],me.dc[index]));
		});
		if (jsonData.length > 0) {
			if (jsonData.length === 1 && !!!jsonData[0]) {
				me.thatPageContent.html(me.htmlStr);
			} else {
				var data = me.mosaicData(jsonData);
				me.renderProfileTemplate($.extend(true,{},data));
			}
		} else {
			me.thatPageContent.html(me.htmlStr);
		}
		d.close();
	},
	//渲染模板
	renderProfileTemplate: function (data) {
		this.thatPageContent.removeAttr('avalonctrl').attr('ms-controller',"viewController");
		var vm = avalon.define($.extend({},{"$id": "viewController"},data));
		avalon.scan();
	},
	//获取xml数据
	selectXmlDom: function (profileRes,tempalteCode) {
		if(profileRes.status == 200){
			var me = this,
				$dom = $(profileRes.data.replace(/<\?xml .*\?>/,'')),
				version = $dom.find(">version").length?$dom.find(">version").attr("code"):$dom.attr('version');
			$.trim(version) || (function () {
				version = $dom.find(">ClinicalDocument").length? '2.0.0.1' : '';
			})();
			if($.trim(version)) {
				var verNum = version.split('.')[0];
				var xmlToJson = window["dsXmlToJson"+tempalteCode+'_'+verNum],
					jsonData = {};
					 
				if(xmlToJson && $.isFunction(xmlToJson)) { 
					if(!profileRes.data || profileRes.data=="[]") {
						if(version=2) {
							profileRes.data = '<?xml version="1.0" encoding="utf-8"?><ClinicalDocument></ClinicalDocument>';
						} else {
							profileRes.data = '<?xml version="1.0" encoding="utf-8"?><root></root>';
						}
					}
					// xml 转 json
					if((typeof profileRes.data=='string')&&profileRes.data.constructor==String) {
						// 去除携带的脚本内容
						profileRes.data = profileRes.data.replace(/<script[^>]*?>[\s\S]*?<\/script>/ig,'');
						jsonData = xmlToJson(profileRes.data.replace(/<\?xml .*\?>/,''));
					}
				}
			}
		}else{
			jsonData = ''
		}
		return jsonData;
	},
	//数据拼接
	mosaicData: function (data) {
		for (var i = 1; i < data.length; i++) {
			data[i] && (function () {
				for (key in data[i]['data']) {
					data[0]['data'][key] = data[i]['data'][key];
				}
			})();
		}
		return data[0];
	}
};
var dataCode = [];
var Request = GetRequest(),
	eventId = Request.event;
var d = dialog({contentType:'load', skin:'bk-popup'});
var $profileItemList = $('.lin-sel-group'),
	// 搜索无结果时显示
	$noResultWrap = $('#no_result_wrap'),
	$selectedProfileName = $('#selected_profile_name'),
	$pageContent = $('.page-content');
// 分页查询当前页数
var curPage = 1,
	// iscroll 滚动条实例
	iscroller,
	catalogs = [];
	
// 初始化就诊事件列表
initProfileList = function() {
	var list = [],
		list2 = [];
	if(catalogs) {
		var inspection = [],
			check = [],
			index = [],
			operation = [];
		_.map(catalogs,function(item){
			switch (item.catalog){
				case '0131': check.push(item); break;
				case '0121': inspection.push(item); break;
				case '0231': check.push(item); break;
				case '0221': inspection.push(item); break;
				case '0216': operation.push(item); break;
				default : index.push(item); break;
			}
		})
		list[0] = _.find(index,function(o){ return o.catalog == '0101'});
		list[1] = _.find(index,function(o){ return o.catalog == '0141'});
		list[2] = check;
		list[3] = inspection;
		list[4] = _.find(index,function(o){ return o.catalog == '0102'});
		
		list2[0] = _.find(index,function(o){ return o.catalog == '0201'});
		list2[1] = _.find(index,function(o){ return o.catalog == '0211'});
		list2[2] = _.find(index,function(o){ return o.catalog == '0214'});
		list2[3] = _.find(index,function(o){ return o.catalog == '0215'});
		list2[4] = _.find(index,function(o){ return o.catalog == '0241'});
		list2[5] = _.find(index,function(o){ return o.catalog == '0212'});
		list2[6] = _.find(index,function(o){ return o.catalog == '0213'});
		list2[7] = check;
		list2[8] = inspection;
		list2[9] = operation;
		list2[10] = _.find(index,function(o){ return o.catalog == '0202'});
		
		var html = template("profile_item_tmpl", {arr:list,arr2:list2});
		$profileItemList.append(html);
	}
	var $first = $profileItemList.find("li.j-hascode").eq(0),
		name = $.trim($first.attr("data-name")),
		code = $.trim($first.attr("data-code"));
	$first.find('a').addClass('active');
	if(name&&code) {
		$selectedProfileName.text(name);
		getProfileTemplateHtml(code);
	}
},
getProfileTemplateHtml = function(tempalteCode,serial){
	if(!(/^0[12]\d{2}/.test(tempalteCode))) {
		dialog({
	        content: '对不起,因数据对接问题,暂不支持本记录的展示,请查看其他就诊记录。',
	        okValue:'我知道了',
	        ok: function (){				            		
	        	window.history.go(-1);
	        }
		}).showModal();
		return ;
	}
	d.show();
	Profile.init({
		url: "patient/archives/event/healthData",
		link: '../template/'+tempalteCode+'.html',
		thatPromise: Promise,
		thatEventId: eventId,
		thatTempalteCode: tempalteCode,
		thatSerial: serial,
		thatPageContent: $pageContent,
	});
	Profile.promiseAll();
},
// 绑定页面事件
bindEvents = function () {
	var saveCode = '';
	var saveSerial = '';
	$profileItemList.on('click', 'li.j-hascode', function(){
		var $this = $(this);
		var code = $.trim($this.attr("data-code")),
		name = $.trim($this.attr("data-name")),
		serial = $.trim($this.attr("data-serial"));
		if(code != saveCode){
			getProfileTemplateHtml(code, serial);
			saveCode = code;
			$selectedProfileName.text(name);
		}else{
			if(serial != saveSerial){
				getProfileTemplateHtml(code, serial);
				saveSerial = serial;
				$selectedProfileName.text(name);
			}
		}
	})
},
showTip = function(msg) {
	if(msg) {
		var d = dialog({contentType:'', skin:'bk-popup',content: msg}).show();
		setTimeout(function() {
			d.close();
		},1000)
	}
};
//// 页面业务处理流程开始
getReqPromise('patient/archives/event/catalog',{event: eventId},'JSON','GET')
.then(function(res) {
	if(res.status==200) {
		catalogs = res.data
	} else {
		showTip('档案类型获取失败。');
	}
},function() {
	showTip('档案类型获取失败。');
}).then(function() {
	
	initProfileList();
	// 绑定页面事件
	bindEvents();
}).catch(function(e) {
	console && console.error(e);
});

+ 61 - 0
html/jkda/js/info.js

@ -0,0 +1,61 @@
$(function () {
    var info = {
        $sidebar: $('.sidebar'),
        $sidebarMain: $('.sidebar-main'),
        $sidebarBody: $('.sidebar-body'),
        events: [ 'click', 'touchstart', 'touchend', 'touchmove'],
        init:function () {
            this.setSidebarEvent();
            this.setSidebarMainEvent();
            this.setSbItemEvent();
        },
        setSidebarEvent: function () {
            var me = this;
            me.bindEvent( me.$sidebar, me.events[0], function () {
                me.hidePop();
            });
        },
        setSidebarMainEvent: function () {
            var me = this;
            me.bindEvent( me.$sidebarMain, me.events[0], function (e) {
                if (!!$(e.target).hasClass('sidebar-body') || !!$(e.target).hasClass('sidebar-main')) {
                    me.hidePop();
                }
            });
        },
        setSbItemEvent: function () {
            var me = this;
            me.$sidebarBody.on('click','li.sb-item a',function(){
            	var $this = $(this)
                if ($this.parent().hasClass('j-hascode')) {
                    $('li.sb-item a').removeClass('active');
                    $this.addClass('active');
                    me.hidePop();
                }else{
                	var sbIList = $this.siblings('.sb-i-list');
                    var dis = sbIList.css('display');
                        if (dis == 'none') {
                            me.hideDownSideBar();
                            sbIList.slideDown();
                            $this.find('.i-d').addClass('active');
                        }else {
                        me.hideDownSideBar();
                    }
                }
            })
        },
        hidePop: function () {
            var me = this;
            me.$sidebarMain.hasClass('active') ? me.$sidebarMain.removeClass('active') : me.$sidebarMain.addClass('active');
            me.$sidebarBody.hasClass('active') ? me.$sidebarBody.removeClass('active') : me.$sidebarBody.addClass('active');
        },
        hideDownSideBar: function () {
            $('.sb-i-list').slideUp();
            $('.i-d').removeClass('active');
        },
        bindEvent: function ( d, ev, cb, nd) {
           cb && d.on( ev, nd, cb);
        }
    };
    info.init();
});

+ 234 - 0
html/jkda/js/jianchajianyan.js

@ -0,0 +1,234 @@
var d= dialog({contentType:'load', skin:'bk-popup'}).show();
var pagetype = 29;
var $records = $('#records'),
	$wrapper = $('#wrapper'),
	$content =  $('.div-content'),
	$noResult = $('#no_result_wrap');
	
var scrollIns = null;	
var page = 1;
appendFamilyMember($('#memberContainer'),function(){
	queryInit();
},function(){
	//判断有授权家人,修改样式
	if($('#memberContainer').is(':hidden')){
		$('#wrapper').css('top','0px');
		$('.no-result-img').css('margin-top','150px')
	}else{
		$('#wrapper').css('top','90px');
		$('.vertical-line').css('top','90px');
	}
});
function getYear(date) {
	if(date) {
		return date.substr(0,4);
	}
	return "";
}
function getMD(date) {
	if(date) {
		return date.substr(5,5);
	}
	return "";
}
function getEventTypeClass(v) {
	if(v.catalogCode=="0131"||v.catalogCode=="0231"||v.type=="检查") {
		return "jiancha";
	} else if(v.catalogCode=="0121"||v.catalogCode=="0221"||v.type=="检验"){
		return "jianyan";
	} 
	return  "";
}
function getEventTypeName(v) {
	if(v.catalogCode=="0131"||v.catalogCode=="0231"||v.type=="检查") {
		return "检查";
	} else if(v.catalogCode=="0121"||v.catalogCode=="0221"||v.type=="检验"){
		return "检验";
	} 
	return  "";
}
function hasGroup(date) {
	var year = getYear(date),
		$year = $('.record-year[data-year="'+ year +'"]');
		
	if($year.length) {
		return true;
	}
	return false;
}
function updatePullUpText(scroller,list) {
	scroller.off('refresh');
	scroller.on('refresh',function() {
		var $wrap = $(scroller.wrapper),
		$pullupLabel = $wrap.find('.pullUpLabel');
		if(!list || !list.length) {
			$pullupLabel.text('没有更多');
		} else {
			$pullupLabel.text('上拉加载更多');
		}
	});
}
function parseToHtml(eventData) {
	var sortedEvents = _.sortBy(eventData.data,function(event) {
		return -Date.parse(event.eventDate)
	});
	var groupEvents = _.groupBy(sortedEvents,function(event) {
		return getYear(event.eventDate)
	});
	var years = _.chain(groupEvents).keys().sortBy(function(year) {
		return -year;
	}).value();
	_.each(years,function(year) {
		var yearHtml = '', html = '';
		if(!hasGroup(year)) {
			yearHtml = '<li class="record-year c-909090" data-year="'+year+'">'+year+'</li>'
		} 
		html = template('li_tmpl', {list: groupEvents[year]});
		$records.append(yearHtml+html);
	})
}
function toJson(o) {
	if(o) {
		return JSON.stringify(o);
	}
	return "{}";
}
scrollIns = new IScrollPullUpDown('wrapper',{
				probeType:2,
				bounceTime: 250,
				bounceEasing: 'quadratic',
				mouseWheel:false,
				scrollbars:true,
				fadeScrollbars:true,
				click: true,
				interactiveScrollbars:false
},null,function pullUpAction() {
	var lastTime = $records.find('li:last').attr('data-event-date');
	getReqPromise('patient/archives/event/report',{page:page+1,pageSize:10},'JSON','GET')
	.then(function(res) {
		if(res.status==200) {
				page++;
				parseToHtml(res)
				updatePullUpText(scrollIns.myScroll,res.data);
				setTimeout(function() {
					scrollIns.myScroll.refresh();
				},100)
		}
		
	}).catch(function(e) { console && console.error(e) });
});
checkUserAgent();
function queryInit(){
	page = 1;
	$records.empty();
	getReqPromise('patient/archives/event/report?timestamp='+$.now(),{page:page,pageSize:10},'JSON','GET')
	.then(function(res) {
		template.helper("getYear", getYear);
		template.helper("getMD", getMD);
		template.helper("getEventTypeClass", getEventTypeClass);
		template.helper("getEventTypeName", getEventTypeName);
		template.helper("hasGroup", hasGroup);
		template.helper("toJson", toJson);
		return res;
	})
	.then(function(res) {
		d.close();
		if(res.status == 200) {
			if(res.data && res.data.length) {
				$noResult.hide();
				$content.show();
				parseToHtml(res);
				return true;
			} else {
				$content.hide();
				$noResult.show();
				return false;
			}	
		} else {
			d.close();
			dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:res.msg}).show();
		}	
	})
	.then(function() {
		$records.on('click','li',function() {
			var data = JSON.parse($(this).attr('data-json'));
			if(data.dataFrom==1) {
	            function checkSign(){
	                d.show();
	                var userAgent = window.localStorage.getItem(agentName);
	                if(userAgent){
	                    var datas = {};
	                    $.ajax(server + "patient/is_sign", {
	                        data: datas,
	                        type: 'POST',
	                        dataType: 'json',
	                        beforeSend: function(request) {
	                            request.setRequestHeader("userAgent", userAgent);
	                        },
	                        error: function(res) {
	                            d.close();
	                            if(res.status == 999 || res.status == 998 || res.status == 997){
	                                loginUrl(res.status);
	                                return;
	                            }
	                            dialog({contentType:'tipsbox', skin:'bk-popup' , content:'校验失败',bottom:true}).show();
	                        },
	                        success: function(res) {
	                            d.close();
	                            
	                            if(res.status == 999 || res.status == 998 || res.status == 997){
	                                loginUrl(res.status);
	                            }
	                            else if (res.status == 200) {
	                            	
	                                // -1 未签约  0 待签约 1 已签约 2待解约
	                                var is_sign = res.data;
		
	                                if(is_sign > 0){
	                                   
	                                        window.location.href = "single-profile.html?event="+data.id+'&catalog='+data.catalogCode+'&typeName='+encodeURIComponent(data.label)+"&serial="+data.serial;
	                                  
	                                }else{
	                                    dialog({
	                                        title: '提示',
	                                        content: '对不起,签约家庭医生之后才能查看健康档案!',
	                                        okValue:'我要签约',
	                                        ok: function (){
	                                            window.location.href = "../../qygl/html/signing-doctors.html";
	                                        },
	                                        cancelValue: '了解签约',
	                                        cancel: function () {
	                                            window.location.href = "../../qygl/html/signing-share2.html";
	                                        }
	                                    }).showModal();
	                                }
	                            } else {
	                                dialog({contentType:'tipsbox', skin:'bk-popup' , content:res.msg,bottom:true}).show();
	                            }
	                        }
	                    });
	                }
	                else{
	                    dialog({contentType:'tipsbox', skin:'bk-popup' , content:'用户信息错误',bottom:true}).show();
	                }
	            }
	            checkSign();
			} else if(data.dataFrom==2){
	            window.location.href = "jiuzhenxiangqing.html?event="+data.id+'&catalog='+data.catalogCode+"&serial="+data.serial;
			}	
		});
	}).catch(function(e) { console && console.error(e) });
}

+ 137 - 0
html/jkda/js/jiankangtijian.js

@ -0,0 +1,137 @@
var d= dialog({contentType:'load', skin:'bk-popup'});
var $eventListWrapper = $('#recent_event_list_wrap'),
	$eventList = $('#recent_event_list'),
	// 搜索无结果时显示
	$noResultWrap = $('#no_result_wrap');
// 分页查询当前页数
var curPage = 1,
	// iscroll 滚动条实例
	iscroller;
var pagetype = 32;
appendFamilyMember($('#memberContainer'),function(){
	queryInit();
},function(){
	//判断有授权家人,修改样式
	if($('#memberContainer').is(':hidden')){
		$('#recent_event_scroller').css('top','0px');
		$('.no-result-img').css('margin-top','150px')
	}else{
		$('#recent_event_scroller').css('top','90px');
	}
})
template.helper("toJson", function(v, i) {
	return JSON.stringify(v);
});
	
// 初始化就诊事件列表
var initEventList = function(list) {
	var html = template("recent_event_tmpl", {list: list})
	$eventList.append(html);
},
// 分页查询列表
searchByPaging = function () {
	var userAgent = JSON.parse(window.localStorage.getItem(agentName));
	var url = "patient/archives/list_medical",
	curPage = 1,
	pagesize = 50,
	params = {
		pageIndex: curPage,
		pageSize: pagesize
	};
	getReqPromise(url,params,'','POST').then(function(res){
		if(!iscroller) {
			iscroller = initScroller($eventListWrapper,url);
		}
		if(res.status == 200) {
			curPage++;
			var  list = res.list;
			if(!list|| !list.length) {
				$eventListWrapper.hide();
				$noResultWrap.show();
			} else {
				$noResultWrap.hide();
				$eventListWrapper.show();
				initEventList(list);
			}
		} else {
			dialog({contentType:'tipsbox', skin:'bk-popup' , content:res.msg,bottom:true}).show();
		}
		iscroller.refresh();
	}).catch(function(e) {
		console && console.error(e)
	});
},
// 滚动条分页实例初始化
initScroller = function($el,url,getData,pullUpAction) {
	var scroller = $el.initScroll({pullDown: false,pullUp: false});
	return scroller;
},
checkSignPromise = function (){
    d.show();
    return getReqPromise("patient/is_sign",{},'','POST').then(function(res) {
    	d.close();
		if (res.status == 200) {
			// -1 未签约  0 待签约 1 已签约 2待解约
            var is_sign = res.data;
            if(is_sign > 0){
                return true;
            }else{
                return false;
            }
		} else {
            dialog({contentType:'tipsbox', skin:'bk-popup' , content:res.msg,bottom:true}).show();
        }
	}).catch(function(e) {
		d.close();
		console && console.error(e);
	})
},
            
// 绑定页面事件
bindEvents = function () {
	$eventList.on('click','li',function() {
		var data = JSON.parse($(this).attr("data-json"));
		checkSignPromise()
		.then(function(isSign) {
			if(isSign === true) {
				window.location.href = "jiankangtijianxiangqing.html?medicalNo="+data.medicalNo
			} else if(isSign === false) {
				dialog({
                    title: '提示',
                    content: '对不起,签约家庭医生之后才能查看健康档案!',
                    okValue:'我要签约',
                    ok: function (){
                        window.location.href = "../../qygl/html/signing-doctors.html";
                    },
                    cancelValue: '了解签约',
                    cancel: function () {
                        window.location.href = "../../qygl/html/signing-share2.html";
                    }
                }).showModal();
			}
		})
		
	});
};
function queryInit(){
	curPage = 1;
	$eventList.empty();
    Promise.resolve().then(function() {
        searchByPaging();
        bindEvents();
    }).catch(function(e) {
        console && console.error(e);
    });
}
$(function() {
    checkUserAgent();
	// 页面业务处理流程开始
})

+ 67 - 0
html/jkda/js/jiankangtijianxiangqing.js

@ -0,0 +1,67 @@
var d= dialog({contentType:'load', skin:'bk-popup'}).show();
var Requests = GetRequest(),
	medicalNo = Requests.medicalNo;
getReqPromise('patient/archives/medical_detail',{
	medicalNo: medicalNo
},'JSON','POST').then(function(res){
		d.close();
		var data = {};
		if(res.status == 200) {
			data = res.medical_detail;
		} else {
			mui.toast(res.msg);
		}
		
		var vm = avalon.define($.extend({},{"$id": "viewController"},{
				data: data
			}));
		avalon.scan();
	}).catch(function(e) {
		d.close();
		console && console.error(e);
	})
.then(function() {
	function showAutoItems(el) {
		var $item = $(el).closest('[auto-item]');
		if($item.length && $item.is(":hidden")) {
			$item.removeClass('elastic-columns-ignore')
			$item.show();
			showAutoItems($item.parent());
		}
	}
	_.each($('[item-value]'),function(el) {
		var $el = $(el);
		var text = $.trim($el.text());
		if(text) {
			showAutoItems($el);
		}
	})
})
.then(function() {
	$('.c-panel').on('click','.c-panel-bar',function() {
		var $panel = $(this).closest('.c-panel'),
			$content = $panel.find('.c-panel-content');
		$('.c-panel.expanding').not($panel[0]).removeClass('expanding').find('.c-panel-content').slideUp();
		$panel.toggleClass('expanding');
		if($panel.hasClass('expanding')) {
			var $container = $panel.find('.card-layout');
			$content.slideDown(function() {
				if($container.length) {
					$container.elasticColumns(
					{
					    columns:        2,  // the number of colums
					    innerMargin:    5, // the gap between two tiles
					    outerMargin:    5  // the gap between the tiles and
					                        // the edge of the container
					});
				}
			});
			
		} else {
			$content.slideUp();
		}
	});
}).catch(function(e) {
	d.close();
	console && console.error(e);
})

+ 257 - 0
html/jkda/js/jiuzhenjilu.js

@ -0,0 +1,257 @@
var d= dialog({contentType:'load', skin:'bk-popup'}).show();
var pagetype = 28;
var $records = $('#records'),
	$wrapper = $('#wrapper'),
	$content =  $('.div-content'),
	$noResult = $('#no_result_wrap');
	
var scrollIns = null;	
var page = 1;
appendFamilyMember($('#memberContainer'),function(){
	queryInit();
},function(){
	//判断有授权家人,修改样式
	if($('#memberContainer').is(':hidden')){
		$('#wrapper').css('top','0px');
	}else{
		$('#wrapper').css('top','90px');
		$('.vertical-line').css('top','90px');
		$('.no-result-img').css('margin-top','150px')
	}
})
function getYear(date) {
	if(date) {
		return date.substr(0,4);
	}
	 return "";
}
function getMD(date) {
	if(date) {
		return date.substr(5,5);
	}
	return "";
}
function getEventTypeClass(type) {
	if(type=="1") {
		return "menzhen";
	} else if(type=="2"){
		return "zhuyuan";
	} else if(type == "3"){
		return "tijian";
	}
	return  "menzhen";
}
function getEventTypeName(type) {
	if(type=="1") {
		return "门诊";
	} else if(type=="2"){
		return "住院";
	} else if(type == "3"){
		return "体检";
	}
}
function hasGroup(date) {
	var year = getYear(date),
		$year = $('.record-year[data-year="'+ year +'"]');
	if($year.length) {
		return true;
	}
	return false;
}
function updatePullUpText(scroller,list) {
	scroller.off('refresh');
	scroller.on('refresh',function() {
		var $wrap = $(scroller.wrapper),
		$pullupLabel = $wrap.find('.pullUpLabel');
		if(!list || !list.length) {
			$pullupLabel.text('没有更多');
		} else {
			$pullupLabel.text('上拉加载更多');
		}
	});
}
function parseToHtml(eventData) {
	var sortedEvents = _.sortBy(eventData.data,function(event) {
		return -Date.parse(event.eventDate)
	});
	var groupEvents = _.groupBy(sortedEvents,function(event) {
		return getYear(event.eventDate)
	});
	var years = _.chain(groupEvents).keys().sortBy(function(year) {
		return -year;
	}).value();
	_.each(years,function(year) {
		var yearHtml = '', html = '';
		if(!hasGroup(year)) {
			yearHtml = '<li class="record-year c-909090" data-year="'+year+'">'+year+'</li>'
		} 
		html = template('li_tmpl', {list: groupEvents[year]});
		$records.append(yearHtml+html);
	})
}
function toJson(o) {
	if(o) {
		return JSON.stringify(o);
	}
	return "{}";
}
scrollIns = new IScrollPullUpDown('wrapper',{
				probeType:2,
				bounceTime: 250,
				bounceEasing: 'quadratic',
				mouseWheel:false,
				scrollbars:true,
				fadeScrollbars:true,
				click: true,
				interactiveScrollbars:false
},null,function pullUpAction() {
	var lastTime = $records.find('li:last').attr('data-event-date');
	getReqPromise('patient/archives/event',{type:'',page:page+1,pageSize:10,lastTime: lastTime},'JSON','GET')
	.then(function(res) {
		if(res.status==200) {
				page++;
				parseToHtml(res)
				updatePullUpText(scrollIns.myScroll,res.data);
				setTimeout(function() {
					scrollIns.myScroll.refresh();
				},100)
		}
		
	}).catch(function(e) { console && console.error(e) });
});
checkUserAgent();
function bindEvents() {
	$records.on('click','li[data-from="1"]',function() {
        var id = $(this).attr('data-id');
        function checkSign(){
            d.show();
            var userAgent = window.localStorage.getItem(agentName);
            if(userAgent){
                var data = {};
                $.ajax(server + "patient/is_sign", {
                    data: data,
                    type: 'POST',
                    dataType: 'json',
                    beforeSend: function(request) {
                        request.setRequestHeader("userAgent", userAgent);
                    },
                    error: function(res) {
                        d.close();
                        if(res.status == 999 || res.status == 998 || res.status == 997){
                            loginUrl(res.status);
                            return;
                        }
                        dialog({contentType:'tipsbox', skin:'bk-popup' , content:'校验失败',bottom:true}).show();
                    },
                    success: function(res) {
                        d.close();
                        if(res.status == 999 || res.status == 998 || res.status == 997){
                            loginUrl(res.status);
                        }
                        else if (res.status == 200) {
                            // -1 未签约  0 待签约 1 已签约 2待解约
                            var is_sign = res.data;
                            if(is_sign > 0){
                                window.location.href = "event-profile.html?event="+id
                            }else{
                                dialog({
                                    title: '提示',
                                    content: '对不起,签约家庭医生之后才能查看健康档案!',
                                    okValue:'我要签约',
                                    ok: function (){
                                        window.location.href = "../../qygl/html/signing-doctors.html";
                                    },
                                    cancelValue: '了解签约',
                                    cancel: function () {
                                        window.location.href = "../../qygl/html/signing-share2.html";
                                    }
                                }).showModal();
                            }
                        } else {
                            dialog({contentType:'tipsbox', skin:'bk-popup' , content:res.msg,bottom:true}).show();
                        }
                    }
                });
            }
            else{
                dialog({contentType:'tipsbox', skin:'bk-popup' , content:'用户信息错误',bottom:true}).show();
            }
        }
        checkSign();
	}).on('click','li[data-from="2"]',function() {
        var id = $(this).attr('data-id');
        window.location.href = "jiuzhenxiangqing.html?event="+id
	})
}
function templateHelper() {
	template.helper("getYear", getYear);
	template.helper("getMD", getMD);
	template.helper("getEventTypeName", getEventTypeName);
	template.helper("getEventTypeClass", getEventTypeClass);
	template.helper("hasGroup", hasGroup);
	template.helper("toJson", toJson);
}
templateHelper();
bindEvents();
function queryInit() {
	page = 1;
	d.show();
	$records.empty();
	getReqPromise('patient/archives/event',{type:'',page:page,pageSize:10,lastTime: ''},'JSON','GET')
	.then(function(res) {
		d.close();
		if(res.status == 200) {
			if(res.data && res.data.length) {
				$noResult.hide();
				$content.show();
				parseToHtml(res);
				return true;
			} else {
				$content.hide();
				$noResult.show();
				return false;
			}	
		} else {
			d.close();
			dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:res.msg}).show();
		}
		
	}).then(function() {
		scrollIns.myScroll.refresh();
	}).catch(function(e) { 
		d.close();
		console && console.error(e);
	});
}
window.onpageshow = function() {
    var isLoaded = localStorage.getItem("jiuzhenjilu");
	localStorage.removeItem("jiuzhenjilu");
	if(isLoaded=="1") {
		localStorage.removeItem("jiuzhenjilu");
	}
	else {
		localStorage.setItem("jiuzhenjilu","1");
	}
}

+ 267 - 0
html/jkda/js/jiuzhenxiangqing.js

@ -0,0 +1,267 @@
var d= dialog({contentType:'load', skin:'bk-popup'}).show();
var Requests = GetRequest(),
	event = Requests.event;
var $time = $('#time'),
	$type = $('#type'),
	$deptDoctor = $('#dept_doctor'),
	$org = $('#org'),
	$diagnosis = $('#diagnosis');
var gallery = null;
// 修改页面标题
function setPageTitle(name) {
	//动态修改title的值
    var $body = $('body');
  	 document.title = name+"详情";
    // hack在微信等webview中无法修改document.title的情况
    var $iframe = $('<iframe src="/favicon.ico"></iframe>');
    $iframe.on('load',function() {
        setTimeout(function() {
            $iframe.off('load').remove();
        }, 0);
    }).appendTo($body);
}
function getEventTypeName(type) {
	if(type=="1") {
		return "门诊";
	} else if(type=="2"){
		return "住院";
	} else if(type == "3"){
		return "体检";
	}
}
function showDeptDoctor(dept,doctor) {
	if(!dept&&!doctor) {
		return ;
	} else if(dept&& doctor) {
		$deptDoctor.html('<label>科室/医生:</label>'+dept+'/'+doctor);
	} else if(dept) {
		$deptDoctor.html('<label>科室:</label>'+dept);
	} else if(doctor) {
		$deptDoctor.html('<label>医生:</label>'+doctor);
	}
	$deptDoctor.show();
}
function updateCatalogNameTip(img) {
	var catalog = $(img).attr('data-catalog')||"";
	var subCatalog = $(img).attr('data-sub-catalog')||"";
	var catalogName = catalog;
	if(subCatalog) {
		catalogName = catalogName + '_' + subCatalog;
	}
	$('#catalog_name').text(catalogName);
}
function updateCatalog(img) {
	var catalog = $(img).attr('data-catalog')||"";
	var subCatalog = $(img).attr('data-sub-catalog')||"";
	$('.img-catalog').find('a.c-btn-icon[data-type="'+catalog+'"]').trigger('click',[false]);
	$('.sub-catalog').find('a.c-btn-icon[data-type="'+subCatalog+'"]').trigger('click',[false]);
}
function previewImage(sid) {
	var pswpElement = document.querySelectorAll('.pswp')[0];
	var w = $(window).width(), h = $(window).height();
	var items = _.map($('img.preview-img'),function(img) {
		return {
			src: getImgUrl($(img).attr('src')),
			w: w,
			h: h,
			initialPosition: { x: 0, y:0 }
		}
	});
	var options = {
	    // optionName: 'option value'
	    // for example:
	    index: sid||0 // start at first slide
	};
	options.mainClass = 'pswp--minimal--dark';
    options.barsSize = {top:0,bottom:0};
	options.captionEl = false;
	options.fullscreenEl = false;
	options.shareEl = false;
	options.bgOpacity = 0.85;
	options.tapToToggleControls = false;
	options.pinchToClose = false;
	options.clickToCloseNonZoomable = false;
	options.tapToClose = false;
	// Initializes and opens PhotoSwipe
	gallery = new PhotoSwipe( pswpElement, PhotoSwipeUI_Default, items, options);
	gallery.init();
}
function updateImgTypeToDB($img) {
	var id = $img.attr('data-id'),
		catalog = $img.attr('data-catalog'),
		subCatalog = $img.attr('data-sub-catalog');
	getReqPromise('patient/archives/event/img/edit',{id: id, imgType: catalog, imgLabel: subCatalog},'JSON','POST')
	.then(function(res) {
		if(res.status == 200) {
			$('.pswp__scroll-wrap').trigger('click');
			dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'图片编辑成功!'}).show(); 
		} else {
			dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'图片编辑失败!'}).show(); 
		}
	}).catch(function(e) { 
		dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'图片编辑失败!'}).show();
		console && console.error(e);
	})
}
getReqPromise('patient/archives/event/detail',{event:Requests.event},'JSON','GET')
.then(function(res) {
	d.close();
	var data = {},
		imgsMap = {};
	if(res.status==200) {
		data = res.data;
		var eventName = getEventTypeName(data.eventType);
		setPageTitle(eventName);
		$type.text(eventName);
		showDeptDoctor(data.deptName,data.doctorName);
		$time.text(data.eventDate.substr(0,10));
		if(data.orgName) {
			$org.text(data.orgName);
			$org.parent().show();
		}
		
		$diagnosis.text(data.dianosis);
		imgsMap = _.groupBy(data.eventImg, function(v) {
			return v.imgType;
		});
		_.mapObject(imgsMap,function(val, key) {
			var catalog = key?key:"未分类";
			var $wrap = $('div[data-type="'+catalog+'"]'),
				$ul = $wrap.find('.img-list').eq(0);
				html = template('li_tmpl',{list: val});
			$ul.html(html);
			$wrap.show();
		});
	}
})
.then(function() {
	var $imgs = $('img.preview-img');
	$imgs.on('click',function() {
		var idx = $imgs.index(this);
		var length = $imgs.length;
		updateCatalogNameTip(this);
		$('#page_counter').text('('+(idx+1)+'/'+length+')')
		previewImage(idx);
		gallery.listen('afterChange', function() {
			var imgIdx = gallery.getCurrentIndex();
			var $img = $imgs.eq(imgIdx);
			updateCatalogNameTip($img);
			$('#page_counter').text('('+(imgIdx+1)+'/'+length+')')
			updateCatalog($img);
		});
		gallery.listen('close', function() {
			window.location.reload();
		});
		updateCatalog(this);
	});
	$('.pop-catalog-sel').on('click',function() {
		var imgIdx = gallery.getCurrentIndex();
		$('#cur_page').text(imgIdx+1);
		$('#amount_page').text($imgs.length);
		$('#catalog_bar').hide();
		$('#catalog_box').slideDown();
	});
	$('.pswp__scroll-wrap').on('tap',function() {
		if($('#catalog_box').css('display')!='none') {
			$('#catalog_box').hide();
			$('#catalog_bar').slideDown();
			var imgIdx = gallery.getCurrentIndex();
			var $img = $imgs.eq(imgIdx);
			updateCatalogNameTip($img);
		} else {
			gallery.close();
		}
	});
	
	$('.img-catalog').on('click','a.c-btn-icon',function(e,readOnly) {
		var ref = $(this).attr('data-ref');		
		var imgIdx = gallery.getCurrentIndex();
		var $img = $imgs.eq(imgIdx);
		if(ref) {
			$('.sub-catalog').not('#'+ref).hide();
			$('#'+ref).slideDown().find('a.c-btn-icon').removeClass('active');
		} else {
			$('.sub-catalog').hide();
		}
		
		var $catalog = $(this).closest('.img-catalog');
		$catalog.find('a.c-btn-icon').removeClass('active');
		$(this).addClass('active');
		if(readOnly!==false){
			$img.attr('data-catalog',$(this).attr('data-type'));
			$img.attr('data-sub-catalog','');
			if(!ref){
				updateImgTypeToDB($img);
			}
		}
	})
	
	$('.sub-catalog').on('click','a.c-btn-icon',function(e,readOnly) {
		var $catalog = $(this).closest('.sub-catalog');
		$catalog.find('a.c-btn-icon').removeClass('active');
		$(this).addClass('active');
		
		var imgIdx = gallery.getCurrentIndex();
		var $img = $imgs.eq(imgIdx);
		
		if(readOnly!==false){
			$img.attr('data-sub-catalog',$(this).attr('data-type'));
			updateImgTypeToDB($img);
		}
	});
	
	$('#delete_img_btn').on('click',function() {
		var imgIdx = gallery.getCurrentIndex();
		var $img = $imgs.eq(imgIdx);
		var id = $img.attr("data-id");
		getReqPromise('patient/archives/event/img/delete',{id: id},'JSON','POST')
		.then(function(res) {
			if(res.status == 200) {
				gallery.close();
				dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'图片删除成功!'}).show(); 
				window.location.reload();
			} else {
				dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'图片删除失败!'}).show(); 
			}
		}).catch(function(e) { 
			dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'图片删除失败!'}).show();
			console && console.error(e);
		})
	})
})
.then(function() {
	$('#edit_btn').on('click',function() {
		window.location.href = "shangchuanjiuzhenjilu-edit.html?event="+Requests.event
	})
})
.catch(function(e) { 
	d.close();
	console && console.error(e) 
})
window.onpageshow = function() {
	var isLoaded = localStorage.getItem("jiuzhenxiangqing")
	if(isLoaded=="1") {
		localStorage.removeItem("jiuzhenxiangqing");
		location.reload(true);
	}
	else {
		localStorage.setItem("jiuzhenxiangqing","1");
	}
}
template.helper("setPhoto", function(p) {		
		return getImgUrl(p);
});

+ 315 - 0
html/jkda/js/shangchuanjiuzhenjilu-edit.js

@ -0,0 +1,315 @@
var $date = $("#date"),
	$type = $('#type'),
	$hospital = $('#hospital'),
	$dept = $('#dept'),
	$docName = $('#doc_name');
var Requests = GetRequest(),
	eventId = Requests.event;
var userAgent = JSON.parse(window.localStorage.getItem(agentName));
var eventInfo = null;
function updateImageCounter() {
	var cur = gallery.getCurrentIndex()+1;
	var amount = gallery.items.length;
	$('#cur_page').text(cur);
	$('#amount_page').text(amount);
}
function initImageTypeBox($img) {
	var catalog = $img.attr('data-catalog');
	var subCatalog = $img.attr('data-sub-catalog');
	$('.img-catalog').find('a.c-btn-icon').removeClass('active');
	$('.sub-catalog').find('a.c-btn-icon').removeClass('active');
	$('.img-catalog').find('a.c-btn-icon[data-type="'+catalog+'"]').trigger('click',[false]);
	$('.sub-catalog').find('a.c-btn-icon[data-type="'+subCatalog+'"]').trigger('click',[false]);
}
function validRequired() {
	var form = getFormData();
	var date = form.date,
		type = form.type;
	
	if(!date || !type) {
		return false;
	}
	return true;
}
function getFormData() {
	return {
		date: $('#date').val(),
		type: $('#type').attr('data-val'),
		hospital: $('#hospital').val(),
		dept: $('#dept').val(),
		doctor: $('#doc_name').val(),
		diagnosis: _.map($('#diagnosis li'),function(el) {
			return $(el).find('.c-list-info').text()
		})
	}
}
getReqPromise('patient/archives/event/detail',{
	event: eventId
},'JSON','GET')
.then(function(res) {
	return new Promise(function(resolve,reject) {
		eventInfo = res.data;
		if(eventInfo) {
			resolve(true)
		} else {
			reject(res)
		}
	})
})
.then(function() {
	/* 选择日期  */
	var opt = {
		preset: 'date',
		theme: 'ios',
		lang: 'zh',
		minDate: new Date(1900, 01, 01)
	};
	$('input[data-time=date]').mobiscroll(opt);
	if(eventInfo.eventDate) {
		$date.val(eventInfo.eventDate.slice(0,10));
	}
	
})
.then(function() {
	var arr_key=['1', '2', '3'];
    var arr_value=['门/急诊', '住院','体检']; 
    $type.mobiscroll({
		theme: 'ios',
		lang: 'zh',
		formatValue: function(d) {
			return d.join(',');
		},
		customWheels: true,
		wheels: [
			[{
				keys: arr_key,
				values: arr_value
			}]
		],
		onSelect: function(valueText, inst) {
			var dd = eval("[" + valueText + "]");
			$type.attr('data-val',dd[0].keys);
			$type.val(dd[0].values);
		}
	});
	
	var eventName = "";
	for(var i=0;i<arr_key.length;i++) {
		if((i+1)==eventInfo.eventType) {
			eventName = arr_value[i];
			break;
		}
	}
	if(eventName) {
		$type.attr('data-val',eventInfo.eventType);
		$type.val(eventName);
	}
	
})
.then(function() {
	$hospital.val(eventInfo.orgName);
	$dept.val(eventInfo.deptName);
	$docName.val(eventInfo.doctorName);
	var dianosis = [];
	if(eventInfo.dianosis) {
		dianosis = eventInfo.dianosis.split(',');
		var html = '';
		_.each(dianosis,function(diag) {
			html += '<li class="ptb12">'
	            +'<div class="c-list-info">'+ diag +'</div>'
	            +'<div class="c-list-key pl20 c-909090"><img class="del-icon mt5" src="../images/shanchu01_btn.png"/></div>'
	        +'</li>';
		});
		$('#diagnosis').html(html);
	}
})
.then(function() {
	var imgs = eventInfo.eventImg;
	if(imgs) {
		_.each(imgs,function(img) {
			var $li = $('<li>' + '<img src="' + getImgUrl(img.imgUrl) + '"  data-id="'+img.id+'" data-catalog="'+img.imgType+'" data-sub-catalog="'+img.imgLabel+'"/><div class="del-wrap"><img src="../images/shanchu02_btn.png" class="del-icon"/></div><p class="catalog-name"></p></li>');
			var name = img.imgType+(img.imgLabel?('_'+img.imgLabel):"");
			if(name!="_") {
				$li.find('.catalog-name').text(name);
			}
			$('#add_img_li').before($li);	
		});
	}
})
.then(function() {
	$('#add_diag').on('click',function() {
		var $diagInp = $('#diag_input'),
			diag = $.trim($diagInp.val());
		if(diag) {
			var li = '<li class="ptb12">'
                        +'<div class="c-list-info">'+ diag +'</div>'
                        +'<div class="c-list-key pl20 c-909090"><img class="del-icon mt5" src="../images/shanchu01_btn.png"/></div>'
                     +'</li>';
			$('#diagnosis').append(li);
			$diagInp.val('');
		}
	});
	
	$('#diagnosis').on('click','.del-icon',function(){
		var $li = $(this).closest('li');
		$li.remove();
	});
	
	$('#img_ul').on('click','li:not(#add_img_li)',function() {
		previewImage($(this).index());
		var preIdx = $(this).index();
		gallery.listen('beforeChange', function() { 
			var imgIdx = preIdx;
			var $li = $('#img_ul').find('li:not(#add_img_li)').eq(imgIdx);
			var $img = $li.find('img:not(.del-icon)');
			var $p = $li.find('.catalog-name');
			var catalog = $img.attr('data-catalog')||"";
			var subCatalog = $img.attr('data-sub-catalog')||"";
			var name = catalog+(subCatalog?('_'+subCatalog):"");
			if(name=="_") {
				$p.hide();
			} else {
				$p.text(name).show();
			}
			
		});
		gallery.listen('afterChange', function() {
			updateImageCounter();
			var imgIdx = gallery.getCurrentIndex();
			preIdx = imgIdx;
			var $li = $('#img_ul').find('li:not(#add_img_li)').eq(imgIdx);
			var $img = $li.find('img:not(.del-icon)');
			initImageTypeBox($img);
		});
		updateImageCounter();
		initImageTypeBox($(this).find('img:not(.del-icon)'));
	}).on('click','.del-wrap',function() {
		$(this).closest('li').remove();
		return false;
	})
	
	$('.img-catalog').on('click','a.c-btn-icon',function(e,toNext) {
		var ref = $(this).attr('data-ref');
		if(ref) {
			$('.sub-catalog').not('#'+ref).hide();
			$('#'+ref).slideDown().find('a.c-btn-icon').removeClass('active');
		} else {
			$('.sub-catalog').hide();
		}
		
		var $catalog = $(this).closest('.img-catalog');
		$catalog.find('a.c-btn-icon').removeClass('active');
		$(this).addClass('active');
		
		var imgIdx = gallery.getCurrentIndex();
		var $li = $('#img_ul').find('li:not(#add_img_li)').eq(imgIdx);
		var $img = $li.find('img:not(.del-icon)');
		$img.attr('data-catalog',$(this).attr('data-type'));
		
		if(toNext!==false && !ref) {
			//gallery.next();
		}
	})
	
	$('.sub-catalog').on('click','a.c-btn-icon',function(e,toNext) {
		var $catalog = $(this).closest('.sub-catalog');
		$catalog.find('a.c-btn-icon').removeClass('active');
		$(this).addClass('active');
		
		var imgIdx = gallery.getCurrentIndex();
		var $li = $('#img_ul').find('li:not(#add_img_li)').eq(imgIdx);
		var $img = $li.find('img:not(.del-icon)');
		$img.attr('data-sub-catalog',$(this).attr('data-type'));
		
		if(toNext!==false) {
			//gallery.next();
		}
	});
	$('#set_type_ack').on('click',function() {
		gallery.close();
	});
	
	$('#save_btn').on('click',function() {
		if(validRequired()) {
			var form = getFormData();
			var images = _.map($('#img_ul img:not(.del-icon)'),function(img){
				var $img = $(img);
				return  {
			        "imgUrl": $img.attr('src'),
			        "imgLabel": $img.attr('data-sub-catalog')||"",
			        "imgType": $img.attr('data-catalog') || ""
			     }
			});
			var diagnosis = _.map($('#diagnosis li'),function(el) {
				return $(el).find('.c-list-info').text()
			});
			var d = dialog({contentType:'load', skin:'bk-popup',content: '正在保存,请稍后'}).showModal();
			var params = {
				id: eventId,
				patient: userAgent.uid,
				orgName: form.hospital,
				deptName: form.dept,
				doctorName: form.doctor,
				eventDate: form.date,
				eventType: form.type,
				dianosis: diagnosis.join(','),
				eventImg: images
			};
			getReqPromise("patient/archives/event/save",{data: JSON.stringify(params)},'JSON','POST')
			.then(function(res) {
				d.close();
				if(res.status == 200) {
					dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'保存成功!'}).show(); 
					window.history.back();
				} else {
					dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'保存失败!'}).show(); 
				}
				
			}).catch(function(e) {
				d.close();
				dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'保存失败!'}).show(); 
				console && console.error(e);
			});
		} else {
			dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'请填写完整信息'}).show(); 
		}
		
	});
	
	$('#delete_btn').on('click',function(){
		// TODO 删除请求
		dialog({
	        content: '确定删除该病历?',
	        okValue:'确定',
	        ok: function (){				            		
	        	getReqPromise("patient/archives/event/delete",{event: eventId},'JSON','POST')
	        	.then(function(res) {
	        		if(res.status == 200) {
	        			dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'病历删除成功!'}).show(); 
	        			window.location.href = "jiuzhenjilu.html?"+$.now();
	        		} else {
	        			dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'病历删除失败!'}).show(); 
	        		}
	        	}).catch(function(e){
	        		dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'病历删除失败!'}).show(); 
	        	})
	        },
	        cancelValue: '取消',
	        cancel: function () {
				return;
	        }
		}).showModal();
	})
	
}).catch(function(e) { console && console.error(e); })

+ 239 - 0
html/jkda/js/shangchuanjiuzhenjilu.js

@ -0,0 +1,239 @@
var Requests = GetRequest(),
	fromEventType = Requests.eventType;
var $date = $("#date"),
	$type = $('#type'),
	$member = $('#member'),
	$hospital = $('#hospital'),
	$dept = $('#dept'),
	$docName = $('#doc_name');
var userAgent = JSON.parse(window.localStorage.getItem(agentName));
function updateImageCounter() {
	var cur = gallery.getCurrentIndex()+1;
	var amount = gallery.items.length;
	$('#cur_page').text(cur);
	$('#amount_page').text(amount);
}
function initImageTypeBox($img) {
	var catalog = $img.attr('data-catalog');
	var subCatalog = $img.attr('data-sub-catalog');
	$('.img-catalog').find('a.c-btn-icon').removeClass('active');
	$('.sub-catalog').find('a.c-btn-icon').removeClass('active');
	$('.img-catalog').find('a.c-btn-icon[data-type="'+catalog+'"]').trigger('click',[false]);
	$('.sub-catalog').find('a.c-btn-icon[data-type="'+subCatalog+'"]').trigger('click',[false]);
}
function validRequired() {
	var form = getFormData();
	var date = form.date,
		type = form.type;
	
	if(!date || !type) {
		return false;
	}
	return true;
}
function getFormData() {
	return {
		date: $('#date').val(),
		type: $('#type').attr('data-val'),
		hospital: $('#hospital').val(),
		dept: $('#dept').val(),
		doctor: $('#doc_name').val(),
		diagnosis: _.map($('#diagnosis li'),function(el) {
			return $(el).find('.c-list-info').text()
		})
	}
}
Promise.resolve()
.then(function() {
	/* 选择日期  */
	var opt = {
		preset: 'date',
		theme: 'ios',
		lang: 'zh',
		minDate: new Date(1900, 01, 01)
	};
	$('input[data-time=date]').mobiscroll(opt);
	var date = new Date()
	$date.val(date.Format("yyyy-MM-dd"));
	
})
.then(function() {
	var arr_key=['1', '2', '3'];
    var arr_value=['门/急诊', '住院','体检']; 
    $type.mobiscroll({
		theme: 'ios',
		lang: 'zh',
		formatValue: function(d) {
			return d.join(',');
		},
		customWheels: true,
		wheels: [
			[{
				keys: arr_key,
				values: arr_value
			}]
		],
		onSelect: function(valueText, inst) {
			var dd = eval("[" + valueText + "]");
			$type.attr('data-val',dd[0].keys);
			$type.val(dd[0].values);
		}
	});
	
	//关联被代理人
	$member.attr('data-val',userAgent.represented?userAgent.represented:userAgent.uid);
	$member.val(window.localStorage.getItem('nowPatientName'));
}).then(function() {
	$('#add_diag').on('click',function() {
		var $diagInp = $('#diag_input'),
			diag = $.trim($diagInp.val());
		if(diag) {
			var li = '<li class="ptb12">'
                        +'<div class="c-list-info">'+ diag +'</div>'
                        +'<div class="c-list-key pl20 c-909090"><img class="del-icon mt5" src="../images/shanchu01_btn.png"/></div>'
                     +'</li>'
			$('#diagnosis').append(li);
			$diagInp.val('');
		}
	});
	
	$('#diagnosis').on('click','.del-icon',function(){
		var $li = $(this).closest('li');
		$li.remove();
	});
	
	$('#img_ul').on('click','li:not(#add_img_li)',function() {
		previewImage($(this).index());
		var preIdx = $(this).index();
		gallery.listen('beforeChange', function() { 
			var imgIdx = preIdx;
			var $li = $('#img_ul').find('li:not(#add_img_li)').eq(imgIdx);
			var $img = $li.find('img:not(.del-icon)');
			var $p = $li.find('.catalog-name');
			var catalog = $img.attr('data-catalog')||"";
			var subCatalog = $img.attr('data-sub-catalog')||"";
			var name = catalog+(subCatalog?('_'+subCatalog):"");
			if(name=="_") {
				$p.hide();
			} else {
				$p.text(name).show();;
			}
		});
		gallery.listen('afterChange', function() {
			updateImageCounter();
			var imgIdx = gallery.getCurrentIndex();
			preIdx = imgIdx;
			var $li = $('#img_ul').find('li:not(#add_img_li)').eq(imgIdx);
			var $img = $li.find('img:not(.del-icon)');
			initImageTypeBox($img);
		});
		updateImageCounter();
		initImageTypeBox($(this).find('img:not(.del-icon)'));
	}).on('click','.del-wrap',function() {
		$(this).closest('li').remove();
		return false;
	});
	
	$('.img-catalog').on('click','a.c-btn-icon',function(e,toNext) {
		var ref = $(this).attr('data-ref');
		if(ref) {
			$('.sub-catalog').not('#'+ref).hide();
			$('#'+ref).slideDown().find('a.c-btn-icon').removeClass('active');
		} else {
			$('.sub-catalog').hide();
		}
		
		var $catalog = $(this).closest('.img-catalog');
		$catalog.find('a.c-btn-icon').removeClass('active');
		$(this).addClass('active');
		
		var imgIdx = gallery.getCurrentIndex();
		var $li = $('#img_ul').find('li:not(#add_img_li)').eq(imgIdx);
		var $img = $li.find('img:not(.del-icon)');
		$img.attr('data-catalog',$(this).attr('data-type'));
		
		if(toNext!==false && !ref) {
			//gallery.next();
		}
	})
	
	$('.sub-catalog').on('click','a.c-btn-icon',function(e,toNext) {
		var $catalog = $(this).closest('.sub-catalog');
		$catalog.find('a.c-btn-icon').removeClass('active');
		$(this).addClass('active');
		
		var imgIdx = gallery.getCurrentIndex();
		var $li = $('#img_ul').find('li:not(#add_img_li)').eq(imgIdx);
		var $img = $li.find('img:not(.del-icon)');
		$img.attr('data-sub-catalog',$(this).attr('data-type'));
		
		if(toNext!==false) {
			//gallery.next();
		}
	});
	$('#set_type_ack').on('click',function() {
		gallery.close();
	});
	$('#save_btn').on('click',function() {
		if(validRequired()) {
			var form = getFormData();
			var images = _.map($('#img_ul img:not(.del-icon)'),function(img){
				var $img = $(img);
				return  {
			        "imgUrl": $img.attr('src'),
			        "imgLabel": $img.attr('data-sub-catalog')||"",
			        "imgType": $img.attr('data-catalog') || ""
			     }
			});
			var diagnosis = _.map($('#diagnosis li'),function(el) {
				return $(el).find('.c-list-info').text()
			});
			
			var $diagInp = $('#diag_input'),
				diag = $.trim($diagInp.val());
			if(diag) { // 如果用户忘记点击“添加”诊断,则自动保存
				diagnosis.push(diag);
			}
			
			var d = dialog({contentType:'load', skin:'bk-popup',content: '正在保存,请稍后'}).showModal();
			var params = {
				patient: userAgent.represented?userAgent.represented:userAgent.uid,
				orgName: form.hospital,
				deptName: form.dept,
				doctorName: form.doctor,
				eventDate: form.date,
				eventType: form.type,
				dianosis: diagnosis.join(','),
				eventImg: images
			};
			getReqPromise("patient/archives/event/save",{data: JSON.stringify(params)},'JSON','POST')
			.then(function(res) {
				d.close();
				if(res.status == 200) {
					dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'保存成功!'}).show(); 
					window.history.back();
				} else {
					dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'保存失败!'}).show(); 
				}
				
			}).catch(function(e) {
				d.close();
				dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'保存失败!'}).show(); 
				console && console.error(e);
			});
		} else {
			dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'请填写完整信息'}).show(); 
		}
		
	});
	
}).catch(function(e) { console && console.error(e); })

+ 245 - 0
html/jkda/js/single-profile.js

@ -0,0 +1,245 @@
var Profile = {
	url: '',
	link: '',
	thatEventId: '',
	thatPromise: null,
	thatTempalteCode: '',
	thatSerial: '',
	thatPageContent: null,
	index: 0,
	firstCode: '',
	profileRes: [],
	dc: [],
	htmlStr:['<div id="no_result_wrap" style="margin-top: 85px;">',
				'<img class="no-result-img" src="../../../images/shujuweikong_img.png" />',
				'<div class="f-fs14 c-323232 c-t-center" style="text-align:center">抱歉,暂未找到符合条件的结果。</div>',
			'</div>'].join(''),
	init: function (ops) {
		var me = this;
		if (!(!!ops && typeof ops === 'object')) {
			showTip('参数有误!');
			return;
		}
		ops.cb && ops.cb.call(me);
		me.url = ops.url;
		me.link = ops.link;
		me.thatPromise = ops.thatPromise;
		me.thatEventId = ops.thatEventId;
		me.thatTempalteCode = ops.thatTempalteCode;
		me.thatSerial = ops.thatSerial;
		me.thatPageContent = ops.thatPageContent;
		me.index = 0;
		me.firstCode = '';
		me.profileRes = [];
		me.dc = [];
		window['dataCode']=[];
	},
	//获取模板
	templateRequest: function () {
		var me = this;
		return new me.thatPromise(function(resolve, reject) {
			$.ajax('../template/'+me.thatTempalteCode+'.html', 
			{ dataType: 'html',
			  type:'GET', 
			  error: function(xht, type, throwErr) {
			  	showTip("档案模板获取失败。");
			  },
			  success: function(html) {
			  	resolve(html);
			  }
			})
		})
	},
	//根据thatTempalteCode获取数据
	profileDataRequest: function () {
		var me = this;
		return getReqPromise( me.url,{
								event: me.thatEventId ,	// 事件ID
								catalog: me.thatTempalteCode, // 档案类型
								serial: me.thatSerial || "1"  // 该类别顺序号,默认填1
							},'JSON','GET');
	},
	promiseAll: function () {
		var me = this,
			fistDc = me.thatTempalteCode;
		Promise.all([ me.templateRequest(), me.profileDataRequest()]).then(function (datas) {
			var html = datas[0];
			me.profileRes.push(datas[1]);
			me.thatPageContent.html(html);
			me.firstCode = me.thatTempalteCode;
			me.dc = window['dataCode'];
			if (me.dc.length > 0) {
				me.reqDataMore(me);
			} else {
				me.changeData(fistDc);
			}
		}).catch(function(e) {d.close();console && console.error(e);});
	}, 
	//获取多个数据
	reqDataMore: function (me) {
		me.thatTempalteCode = me.dc[me.index];
		Promise.all([ me.profileDataRequest()]).then(function (datas) {
			me.profileRes.push(datas[0]);
			me.index++;
			if (me.dc.length > me.index) {
				me.reqDataMore(me);
			} else {
				me.changeData(me.firstCode);
			}
		});
	},
	
	changeData: function (fistDc) {
		var me = this,
			jsonData = [];
		me.dc.unshift(me.firstCode);
		$.each( me.profileRes, function (index) {
			jsonData.push(me.selectXmlDom(me.profileRes[index],me.dc[index]));
		});
		if (jsonData.length > 0) {
			if (jsonData.length === 1 && !!!jsonData[0]) {
				me.thatPageContent.html(me.htmlStr);
			} else {
				var data = me.mosaicData(jsonData);
				me.renderProfileTemplate($.extend(true,{},data));
			}
		} else {
			me.thatPageContent.html(me.htmlStr);
		}
		d.close();
	},
	//渲染模板
	renderProfileTemplate: function (data) {
		this.thatPageContent.removeAttr('avalonctrl').attr('ms-controller',"viewController");
		var vm = avalon.define($.extend({},{"$id": "viewController"},data));
		avalon.scan();
	},
	//获取xml数据
	selectXmlDom: function (profileRes,tempalteCode) {
		var me = this,
			$dom = $(profileRes.data.replace(/<\?xml .*\?>/,'')),
			version = $dom.find(">version").length?$dom.find(">version").attr("code"):$dom.attr('version');
		$.trim(version) || (function () {
			version = $dom.find(">ClinicalDocument").length? '2.0.0.1' : '';
		})();
		if($.trim(version)) {
			var verNum = version.split('.')[0];
			var xmlToJson = window["dsXmlToJson"+tempalteCode+'_'+verNum],
				jsonData = {};
				 
			if(xmlToJson && $.isFunction(xmlToJson)) { 
				if(!profileRes.data || profileRes.data=="[]") {
					if(version=2) {
						profileRes.data = '<?xml version="1.0" encoding="utf-8"?><ClinicalDocument></ClinicalDocument>';
					} else {
						profileRes.data = '<?xml version="1.0" encoding="utf-8"?><root></root>';
					}
				}
				// xml 转 json
				if((typeof profileRes.data=='string')&&profileRes.data.constructor==String) {
					// 去除携带的脚本内容
					profileRes.data = profileRes.data.replace(/<script[^>]*?>[\s\S]*?<\/script>/ig,'');
//					console.log(profileRes.data.replace(/<\?xml .*\?>/,''))
					jsonData = xmlToJson(profileRes.data.replace(/<\?xml .*\?>/,''));
				}
			}
			return jsonData;
		} 
	},
	//数据拼接
	mosaicData: function (data) {
		for (var i = 1; i < data.length; i++) {
			data[i] && (function () {
				for (key in data[i]['data']) {
					data[0]['data'][key] = data[i]['data'][key];
				}
			})();
		}
		return data[0];
	}
};
var dataCode = [];
var Request = GetRequest(),
	eventId = Request.event,
	typeName = decodeURIComponent(Request.typeName),
	serial = Request.serial,
	catalog = Request.catalog;
var d = dialog({contentType:'load', skin:'bk-popup'});
var $profileItemList = $('.lin-sel-group'),
	// 搜索无结果时显示
	$noResultWrap = $('#no_result_wrap'),
	$selectedProfileName = $('#selected_profile_name'),
	$pageContent = $('.page-content');
// 分页查询当前页数
var curPage = 1,
	// iscroll 滚动条实例
	iscroller;
// 初始化就诊事件列表
initProfileList = function() {
	$selectedProfileName.text(typeName);
	if(catalog) {
		getProfileTemplateHtml(catalog);
	}
},
getProfileTemplateHtml = function(tempalteCode){
	if(!(/^0[12]\d{2}/.test(tempalteCode))) {
		dialog({
	        content: '对不起,因数据对接问题,暂不支持本记录的展示,请查看其他就诊记录。',
	        okValue:'我知道了',
	        ok: function (){				            		
	        	window.history.go(-1);
	        }
		}).showModal();
		return ;
	}
	d.show();
	Profile.init({
		url: "patient/archives/event/healthData",
		link: '../template/'+tempalteCode+'.html',
		thatPromise: Promise,
		thatEventId: eventId,
		thatTempalteCode: tempalteCode,
		thatSerial: serial,
		thatPageContent: $pageContent,
	});
	Profile.promiseAll();
},
showTip = function(msg) {
	if(msg) {
		var d = dialog({contentType:'', skin:'bk-popup',content: msg}).show();
		setTimeout(function() {
			d.close();
		},1000)
	}
},
// 绑定页面事件
bindEvents = function () {
	$('#xiangqing_btn').on('click',function() {
		window.location.href = 'event-profile.html?event='+eventId+'&catalog='+catalog
	});
};
// 页面业务处理流程开始
getReqPromise('patient/archives/event/catalog',{event: eventId},'JSON','GET')
.then(function(res) {
	if(res.status==200) {
		catalogs = res.data
	} else {
		showTip('档案类型获取失败。');
	}
},function() {
	showTip('档案类型获取失败。');
}).then(function() {
	
	initProfileList();
	// 绑定页面事件
	bindEvents();
}).catch(function(e) {
	console && console.error(e);
});

+ 151 - 0
html/jkda/js/upload-file.js

@ -0,0 +1,151 @@
$(function() {
	
	//从后台那边获取签名等信息
	var params = {};
	params.pageUrl = window.location.href;
	$.ajax(server + "weixin/getSign", {
		data: params,
		dataType: "json",
		type: "post",
		success: function(res){
			if (res.status == 200) {
				var t = res.data.timestamp;
				var noncestr = res.data.noncestr;
				var signature = res.data.signature;
				wx.config({		
					//debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
				    appId: appId, // 必填,公众号的唯一标识
				    timestamp: t, // 必填,生成签名的时间戳
				    nonceStr: noncestr, // 必填,生成签名的随机串
				    signature: signature,// 必填,签名,见附录1
				    jsApiList: [
				    	'chooseImage',
				        'uploadImage'
				    ] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
				});
			} 
		}
	});
});
//微信sdk配置出错
wx.error(function (res) {
	alert("wx.error:" + res.errMsg);
});
function chooseImage(){
	wx.chooseImage({
        success: function (res) {
        	var d = dialog({contentType:'load', skin:'bk-popup', content:'正在努力上传图片,请耐心等待~'}).showModal();
	        uploadImagesPromise(res.localIds).then(function(serverIds){
	        	return getReqPromises(_.map(serverIds,function(id) {
					return {
						url: 'patient/archives/event/uploadImg',
						data: {
							mediaId: id
						},
						reqType: 'POST'
					}
				})).then(function(datas) {
					//dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'上传成功!'}).show();
					_.each(datas,function(o) {
						if(o.status==200) {
							if(o.url) {
								appendFile(o.url);
							}
						}
						
					});
					d.close();
					$('#img_ul li>img:not("[data-id]")').eq(0).closest('li').trigger('click');
				})
	        },function() {
	        	d.close();
	        	dialog({contentType:'tipsbox',bottom:true, skin:'bk-popup' , content:'上传失败!'}).show(); 
	        }).catch(function(e) {
	        	d.close();
	        	console && console.log(e);
	        })
        }
    });
}
//获取需要上传的图片
function getImages() {
	var images = [];
	$("#img_ul").find("img:not(.del-icon)").each(function() {
		var imgSrc = $(this).attr("src");
		images.push(imgSrc);
	});	
	return images;
}
function uploadImagesPromise(localIds) {
	return new Promise(function(resolve, reject) {
		var serverIds = [];
		function syncUpload() {
	        if (!localIds.length) {
	            resolve(serverIds);
	        } else {
	            var localId = localIds.pop();
	            wx.uploadImage({
	                localId: localId,
	                isShowProgressTips: 0,
	                success: function(res) {
	                	serverIds.push(res.serverId);
	                    syncUpload();
	                },
	                fail: function (res) {
			         	reject(res)
			        }
	            });
		    }
	    }
		syncUpload();
	});
}
	
// 添加文件
function appendFile(p) {
	var $li = $('<li>' + '<img src="' + p + '" /><div class="del-wrap"><img src="../images/shanchu02_btn.png" class="del-icon"/></div><p class="catalog-name"></p></li>');
	$('#add_img_li').before($li);	
}
var gallery = null;
function previewImage(sid) {
	var pswpElement = document.querySelectorAll('.pswp')[0];
	var w = $(window).width(), h = $(window).height();
	var items = _.map(getImages(),function(url) {
		return {
			src: url,
			w: w,
			h: h,
			initialPosition: { x: 0, y:0 }
		}
	});
	var options = {
	    // optionName: 'option value'
	    // for example:
	    index: sid||0 // start at first slide
	};
	options.mainClass = 'pswp--minimal--dark';
    options.barsSize = {top:0,bottom:0};
	options.captionEl = false;
	options.fullscreenEl = false;
	options.shareEl = false;
	options.bgOpacity = 0.85;
	options.tapToToggleControls = false;
	options.pinchToClose = false;
	options.clickToCloseNonZoomable = false;
	options.tapToClose = false;
	options.errorMsg = '<div class="pswp__error-msg">对不起,该图片加载失败</div>';
	// Initializes and opens PhotoSwipe
	gallery = new PhotoSwipe( pswpElement, PhotoSwipeUI_Default, items, options);
	gallery.init();
}

+ 185 - 0
html/jkda/template/0101.html

@ -0,0 +1,185 @@
<!--
	门诊摘要
-->
<div class="os-main">
    <ul class="info-list">
        <li class="il-item">
            <h3 class="os-tit-o"><i class="icon i-ess-info"></i><span class="os-t-o-name">基本信息</span></h3>
            <ul class="os-base-info" ms-if="data['姓名'] || data['性别']">
                <li ms-if="data['姓名']"><label>姓&#x3000;&#x3000;名:</label><span ms-text="data['姓名']"></span></li>
                <li ms-if="data['性别']"><label>性&#x3000;&#x3000;别:</label><span ms-text="data['性别']"></span></li>
            </ul>
            <ul class="os-base-info" ms-if="data['出生日期'] || data['婚姻状况']">
                <li ms-if="data['出生日期']"><label>出生日期:</label><span ms-text="data['出生日期']"></span></li>
                <li ms-if="data['婚姻状况']"><label>婚姻状况:</label><span ms-text="data['婚姻状况']"></span></li>
            </ul>
            <ul class="os-base-info" ms-if="data['就诊日期']">
                <li ms-if="data['就诊日期']"><label>就诊日期:</label><span ms-text="data['就诊日期']"></span></li>
            </ul>
            <ul class="os-base-info" ms-if="data['主治医生']">
                <li ms-if="data['主治医生']"><label>主治医生:</label><span ms-text="data['主治医生']"></span></li>
            </ul>
            <ul class="os-base-info" ms-if="data['科室'] || data['医院']">
                <li><label>科室/医院:</label>
                	<span ms-if="data['科室'] && data['医院']"><span ms-text="data['科室']"></span> <span ms-text="data['斜杠']"></span> <span ms-text="data['医院']"></span></span>
                	<span ms-if="data['科室'] && !(data['医院'])" ms-text="data['科室']"></span>
                	<span ms-if="!(data['科室']) && data['医院']" ms-text="data['医院']"></span>
                </li>
            </ul>
        </li>
    </ul>
    <ul class="info-list-t" ms-if="data['诊断'].length >0 || data['治疗措施']">
    	<h3 class="os-tit-o" ms-if="data['诊断'].length >0 || data['治疗措施']"><i class="icon i-visiting-result"></i><span class="os-t-o-name">就诊结果</span></h3>
        <li class="il-t-item" ms-if="data['诊断'].length >0">
            <h4 class="os-tit-t">诊断:</h4>
            <p><span ms-repeat="data['诊断']"><span ms-text="el['诊断名称']"></span>&#x3000;</span></p>
        </li>
        <li class="il-t-item" ms-if="data['治疗措施']">
            <h4 class="os-tit-t">处理意见:</h4>
            <p><span ms-text="data['治疗措施']"></span></p>
        </li>
    </ul>
    <ul class="info-list-t" ms-if="data['主诉'] || data['体格检查'] || data['辅助检查'] || data['过敏史']">
    	<h3 class="os-tit-o" style="padding-bottom:0px;margin-left: 10px;"><i class="icon i-dia-basis"></i><span class="os-t-o-name">诊断依据</span></h3>
        <li class="il-t-item" ms-if="data['主诉']">
            <h4 class="os-tit-t" ms-text="主诉:"></h4>
            <p ms-text="data['主诉']"></p>
        </li>
        <li class="il-t-item" ms-if="data['体格检查']">
            <h4 class="os-tit-t" ms-text="体格检查:"></h4>
            <p ms-text="data['体格检查']"></p>
        </li>
        <li class="il-t-item" ms-if="data['辅助检查']">
            <h4 class="os-tit-t" ms-text="辅助检查:"></h4>
            <p ms-text="data['辅助检查']"></p>
        </li>
        <li class="il-t-item" ms-if="data['专科情况']">
            <h4 class="os-tit-t" ms-text="专科情况:"></h4>
            <p ms-text="data['专科情况']"></p>
        </li>
        <li class="il-t-item" ms-if="data['过敏史']">
            <h4 class="os-tit-t" ms-text="过敏史:"></h4>
            <p ms-text="data['过敏史']"></p>
        </li>
        <li class="il-t-item" ms-if="data['现病史']">
            <h4 class="os-tit-t" ms-text="现病史:"></h4>
            <p ms-text="data['现病史']"></p>
        </li>
        <li class="il-t-item" ms-if="data['既往史']">
            <h4 class="os-tit-t" ms-text="既往史:"></h4>
            <p ms-text="data['既往史']"></p>
        </li>
        <li class="il-t-item" ms-if="data['家族史']">
            <h4 class="os-tit-t" ms-text="家族史:"></h4>
            <p ms-text="data['家族史']"></p>
        </li>
    </ul>
    <p class="p-bottom">详情内容以医院出具纸质病例为准</p>
</div>
<script>
	dataCode = ['0111'];//新增数据请求
	function dsXmlToJson0101_2(xmlStr) {
		var $xmlDom = $(xmlStr),
			$nodes = {
				"基本诊疗信息" :$xmlDom.find('component section'),
				"病人基本信息":$xmlDom.find('recordTarget patient')
			} ;
		return {
			data:{
				"斜杠":'/',
				"姓名": $nodes["病人基本信息"].find('name').text(),
				"性别": $nodes["病人基本信息"].find('sex').text(),
				"出生日期": $nodes["病人基本信息"].find('birthDate').text(),
				"婚姻状况": $nodes["病人基本信息"].find('marriage').text(),
				"就诊日期": $nodes["基本诊疗信息"].find('entry treatTime').text(),
				"主治医生": $nodes["基本诊疗信息"].find('entry doctor name').text(),
				"科室": $nodes["基本诊疗信息"].find('entry dept').text(),
				"医院": $xmlDom.find('org').text(),
				"诊断": (function() {
						var arr = _.map($nodes["基本诊疗信息"].find('diagnosis item'),function(el) {
							var $ele = $(el); 
							return {
								"诊断名称": $ele.find('icd').text(),
							}
						});
						return arr;
				})()
			}
		}
	}
	
	function dsXmlToJson0101_1(xmlStr) {
		var $xmlDom = $(xmlStr),
			$nodes = {
				"基本诊疗信息" :$xmlDom
			} ;
		return {
			data:{
				"科室": $nodes["基本诊疗信息"].find('dept').text(),
				"主治医生": $nodes["基本诊疗信息"].find('doctor').text(),
				"诊断": (function() {
						var arr = [];
						arr = _.map($nodes["基本诊疗信息"].find('diagnosis item'),function(el) {
							var $ele = $(el); 
							return {
								"诊断名称": $ele.text(),
							}
						})
						return arr;
				})()
			}
		}
	}
	
	function dsXmlToJson0111_2(xmlStr) {
		var $xmlDom = $(xmlStr),
			$nodes = {
				"基本诊疗信息" :$xmlDom.find('component section entry'),
				"病人基本信息":$xmlDom.find('recordTarget patient')
			}
		return {
			data:{
				"主诉": $nodes["基本诊疗信息"].find('cc').text(),
				"既往史": $nodes["基本诊疗信息"].find('diseaseHistory').text(),
				"体格检查": $nodes["基本诊疗信息"].find('physicalExam').text(),
				"专科情况": $nodes["基本诊疗信息"].find('spec').text(),
				"辅助检查": $nodes["基本诊疗信息"].find('accessoryExam').text(),
				"家族史": $nodes["基本诊疗信息"].find('familyHistory').text(),
				"过敏史": $nodes["基本诊疗信息"].find('allergyDrugs').text(),
				"现病史": $nodes["基本诊疗信息"].find('currentDisease').text(),
				"治疗措施": $nodes["基本诊疗信息"].find('treatment').text(),
			}
		}
	}
	
	function dsXmlToJson0111_1(xmlStr) {
		var $xmlDom = $(xmlStr),
			$nodes = {
				"基本诊疗信息" :$xmlDom.find('component section entry'),
				"病人基本信息":$xmlDom.find('recordTarget patient')
			}
		return {
			data:{
				"姓名": $nodes["病人基本信息"].find('name').text(),
				"性别": $nodes["病人基本信息"].find('sex').text(),
				"出生日期": $nodes["病人基本信息"].find('birthTime').text(),
				"婚姻状况": $nodes["病人基本信息"].find('marriage').text(),
				"就诊日期": $xmlDom.find('inChargeDoctor time').attr('value'),
				"主诉": $nodes["基本诊疗信息"].find('cc').text(),
				"既往史": $nodes["基本诊疗信息"].find('diseaseHistory').text(),
				"体格检查": $nodes["基本诊疗信息"].find('physicalExam').text(),
				"专科情况": $nodes["基本诊疗信息"].find('spec').text(),
				"辅助检查": $nodes["基本诊疗信息"].find('accessoryExam').text(),
				"家族史": $nodes["基本诊疗信息"].find('familyHistory').text(),
				"过敏史": $nodes["基本诊疗信息"].find('allergyDrugs').text(),
				"现病史": $nodes["基本诊疗信息"].find('currentDisease').text(),
				"治疗措施": $nodes["基本诊疗信息"].find('treatment').text(),
			}
		}
	}
</script>

+ 81 - 0
html/jkda/template/0102.html

@ -0,0 +1,81 @@
<!--
	费用清单
-->
<div class="el-main">
    <div class="el-tit">
        <div class="el-t-l">费用总计</div>
        <div class="el-t-m" ms-text="data['费用总计']"></div>
    </div>
    <ul class="el-list">
        <li class="el-item" ms-repeat="data['门诊分类']">
            <div class="title"><span ms-text="el['分类名称']"></span><span ms-text="el['费用金额']"></span></div>
            <div class="list" ms-if="el['费用详情']" ms-repeat-item="el['费用详情']"><span ms-text="item['项目名称']"></span><span ms-text="item['总价']"></span></div>
        </li>
    </ul>
</div>
<script>
	function dsXmlToJson0102_2(xmlStr) {
		var $xmlDom = $(xmlStr),
			fee_sum = '';//费用总计
			$nodes = {
				"费用" :$xmlDom.find('component section entry')
			} ;
		return {
			data:{
				"门诊分类":(function(){
					var arr = [];
					_.each($nodes["费用"].find('group'),function(el) {
						var $ele = $(el); 
						arr.push({
							"分类名称": $ele.find('type').text(),
							"费用金额":$ele.find('fee').text() ?parseFloat($ele.find('fee').text()).toFixed(2):'',
							"费用详情": (function() {
								var arr1 = [];
								_.each($ele.find('item'),function(it) {
									var $it = $(it);
									arr1.push({
										"项目名称": $it.find('value').text(),
										"总价": $it.find('total').text() ? parseFloat($it.find('total').text()).toFixed(2) : ''
									})
								})
								return arr1;
							})()
						})
					})
					fee_sum = _.reduce( _.pluck(arr, '费用金额'), function(a, b){ return a*1 + b*1; }, 0).toFixed(2);
					return arr;
				})(),
				"费用总计":fee_sum,
			}
		}
	}
	function dsXmlToJson0102_1(xmlStr) {
		var $xmlDom = $(xmlStr),
			fee_sum = '',//费用总计
			$nodes = {
				"费用" :$xmlDom
			} ;
		return {
			data:{
				"门诊分类": (function() {
						var arr = [];
						_.each($nodes["费用"].find('item'),function(it) {
							var $it = $(it);
							arr.push({
								"分类名称": $it.text(),
								"费用金额":$it.attr('total') ? parseFloat($it.attr('total')).toFixed(2):'',
							})
						})
						fee_sum = _.reduce( _.pluck(arr, '费用金额'), function(a, b){ return a*1 + b*1; }, 0).toFixed(2);
						return arr;
				})(),
				"费用总计":fee_sum,
			}
		}
	}
</script>

+ 142 - 0
html/jkda/template/0111.html

@ -0,0 +1,142 @@
<!--
	门诊病历记录
-->
<div class="os-main">
    <ul class="info-list">
        <li class="il-item">
            <h3 class="os-tit-o"><i class="icon i-ess-info"></i><span class="os-t-o-name">基本信息</span></h3>
            <ul class="os-base-info" ms-if="data['姓名'] || data['性别']">
                <li ms-if="data['姓名']"><label>姓&#x3000;&#x3000;名:</label><span ms-text="data['姓名']"></span></li>
                <li ms-if="data['性别']"><label>性&#x3000;&#x3000;别:</label><span ms-text="data['性别']"></span></li>
            </ul>
            <ul class="os-base-info" ms-if="data['出生日期'] || data['婚姻状况']">
                <li ms-if="data['出生日期']"><label>出生日期:</label><span ms-text="data['出生日期']"></span></li>
                <li ms-if="data['婚姻状况']"><label>婚姻状况:</label><span ms-text="data['婚姻状况']"></span></li>
            </ul>
            <ul class="os-base-info" ms-if="data['就诊日期'] || data['主治医生']">
                <li ms-if="data['就诊日期']"><label>就诊日期:</label><span ms-text="data['就诊日期']"></span></li>
                <li ms-if="data['主治医生']"><label>主治医生:</label><span ms-text="data['主治医生']"></span></li>
            </ul>
            <ul class="os-base-info" ms-if="data['科室'] || data['医院']">
                <li><label>科室/医院:</label>
                	<span ms-if="data['科室'] && data['医院']"><span ms-text="data['科室']"></span> <span ms-text="data['斜杠']"></span> <span ms-text="data['医院']"></span></span>
                	<span ms-if="data['科室'] && !(data['医院'])" ms-text="data['科室']"></span>
                	<span ms-if="!(data['科室']) && data['医院']" ms-text="data['医院']"></span>
            </ul>
        </li>
    </ul>
    <ul class="info-list-t">
    	<h3 class="os-tit-o" ms-if="data['主要诊断'] || data['治疗措施']" style="padding-bottom:0px;margin-left: 10px;"><i class="icon i-visiting-result"></i><span class="os-t-o-name">就诊结果</span></h3>
        <li class="il-t-item" ms-if="data['主要诊断']">
            <h4 class="os-tit-t">主要诊断:</h4>
            <p><span ms-text="data['主要诊断']"></span></p>
        </li>
        <li class="il-t-item" ms-if="data['治疗措施']">
            <h4 class="os-tit-t">处理意见:</h4>
            <p><span ms-text="data['治疗措施']"></span></p>
        </li>
    </ul>
    <ul class="info-list-t">
    	<h3 class="os-tit-o" style="padding-bottom:0px;margin-left: 10px;"><i class="icon i-dia-basis"></i><span class="os-t-o-name">诊断依据</span></h3>
        <li class="il-t-item" ms-if="data['主诉']">
            <h4 class="os-tit-t">主诉:</h4>
            <p ms-text="data['主诉']"></p>
        </li>
        <li class="il-t-item" ms-if="data['体格检查']">
            <h4 class="os-tit-t">体格检查:</h4>
            <p ms-text="data['体格检查']"></p>
        </li>
        <li class="il-t-item" ms-if="data['辅助检查']">
            <h4 class="os-tit-t">辅助检查:</h4>
            <p ms-text="data['辅助检查']"></p>
        </li>
        <li class="il-t-item" ms-if="data['专科情况']">
            <h4 class="os-tit-t">专科情况:</h4>
            <p ms-text="data['专科情况']"></p>
        </li>
        <li class="il-t-item" ms-if="data['过敏史']">
            <h4 class="os-tit-t">过敏史:</h4>
            <p ms-text="data['过敏史']"></p>
        </li>
        <li class="il-t-item" ms-if="data['现病史']">
            <h4 class="os-tit-t">现病史:</h4>
            <p ms-text="data['现病史']"></p>
        </li>
        <li class="il-t-item" ms-if="data['既往史']">
            <h4 class="os-tit-t">既往史:</h4>
            <p ms-text="data['既往史']"></p>
        </li>
        <li class="il-t-item" ms-if="data['家族史']">
            <h4 class="os-tit-t">家族史:</h4>
            <p ms-text="data['家族史']"></p>
        </li>
    </ul>
    <p class="p-bottom">详情内容以医院出具纸质病例为准</p>
</div>
<script>
 
	function dsXmlToJson0111_2(xmlStr) {
		var $xmlDom = $(xmlStr),
			$nodes = {
				"基本诊疗信息" :$xmlDom.find('component section entry'),
				"病人基本信息":$xmlDom.find('recordTarget patient')
			}
		return {
			data:{
				"斜杠":'/',
				"姓名": $nodes["病人基本信息"].find('name').text(),
				"性别": $nodes["病人基本信息"].find('sex').text(),
				"出生日期": $nodes["病人基本信息"].find('birthDate').text(),
				"婚姻状况": $nodes["病人基本信息"].find('marriage').text(),
				"就诊日期": $nodes["基本诊疗信息"].find('treatTime').text(),
				"主治医生": $nodes["基本诊疗信息"].find('doctor name').text(),
				"科室": $nodes["基本诊疗信息"].find('dept').text(),
				"医院": $xmlDom.find('org').text(),
				"主诉": $nodes["基本诊疗信息"].find('cc').text(),
				"既往史": $nodes["基本诊疗信息"].find('diseaseHistory').text(),
				"体格检查": $nodes["基本诊疗信息"].find('physicalExam').text(),
				"专科情况": $nodes["基本诊疗信息"].find('spec').text(),
				"辅助检查": $nodes["基本诊疗信息"].find('accessoryExam').text(),
				"主要诊断": $nodes["基本诊疗信息"].find('diagnosis').text(),
				"家族史": $nodes["基本诊疗信息"].find('familyHistory').text(),
				"过敏史": $nodes["基本诊疗信息"].find('allergyDrugs').text(),
				"现病史": $nodes["基本诊疗信息"].find('currentDisease').text(),
				"治疗措施": $nodes["基本诊疗信息"].find('treatment').text(),
			}
		}
	}
	
	function dsXmlToJson0111_1(xmlStr) {
		var $xmlDom = $(xmlStr),
			$nodes = {
				"基本诊疗信息" :$xmlDom.find('component section entry'),
				"病人基本信息":$xmlDom.find('recordTarget patient')
			}
		return {
			data:{
				"斜杠":'/',
				"姓名": $nodes["病人基本信息"].find('name').text(),
				"性别": $nodes["病人基本信息"].find('sex').text(),
				"出生日期": $nodes["病人基本信息"].find('birthTime').text(),
				"婚姻状况": $nodes["病人基本信息"].find('marriage').text(),
				"就诊日期": $xmlDom.find('inChargeDoctor time').attr('value'),
				"主治医生": $xmlDom.find('inChargeDoctor name').text(),
				"科室": $xmlDom.find('title').text(),
				"医院": $xmlDom.find('org').text(),
				"主诉": $nodes["基本诊疗信息"].find('cc').text(),
				"既往史": $nodes["基本诊疗信息"].find('diseaseHistory').text(),
				"体格检查": $nodes["基本诊疗信息"].find('physicalExam').text(),
				"专科情况": $nodes["基本诊疗信息"].find('spec').text(),
				"辅助检查": $nodes["基本诊疗信息"].find('accessoryExam').text(),
				"主要诊断": $nodes["基本诊疗信息"].find('diagnosis').text(),
				"家族史": $nodes["基本诊疗信息"].find('familyHistory').text(),
				"过敏史": $nodes["基本诊疗信息"].find('allergyDrugs').text(),
				"现病史": $nodes["基本诊疗信息"].find('currentDisease').text(),
				"治疗措施": $nodes["基本诊疗信息"].find('treatment').text(),
			}
		}
	}
</script>

+ 0 - 0
html/jkda/template/0121.html


Some files were not shown because too many files changed in this diff