qiandao.html 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
  6. <meta name="apple-mobile-web-app-capable" content="yes">
  7. <meta name="apple-mobile-web-app-status-bar-style" content="black">
  8. <title>签到记录</title>
  9. <link href="../../css/mui.min.css" rel="stylesheet" />
  10. <link href="../../css/OA-style.css" rel="stylesheet" />
  11. <link href="../../css/mui.picker.css" rel="stylesheet" />
  12. <link href="../../css/mui.picker.all.css" rel="stylesheet" />
  13. <link rel="stylesheet" type="text/css" href="../../css/mui.picker.min.css" />
  14. </head>
  15. <body>
  16. <header class="mui-bar mui-bar-nav" id="login">
  17. <a href="" class="mui-action-back back mui-pull-left"><img src="../../images/back.png"></a>
  18. <h1 class="mui-title" id="title">打卡记录</h1>
  19. <!--设置查询时间-->
  20. <a id="menu" class="mui-action-menu mui-icon mui-pull-right" href="#topPopover">
  21. <img src="../../images/dd_search.png" style="width: 25px;margin-top: -2px;">
  22. </a>
  23. </header>
  24. <div class="mui-content">
  25. <div id="topPopover" class="mui-popover">
  26. <div class="mui-popover-arrow"></div>
  27. <div class="mui-scroll-wrapper">
  28. <div class="mui-scroll">
  29. <ul class="mui-table-view">
  30. <li class="mui-table-view-cell">
  31. <div class="mui-content-padded">
  32. <button id='demo6' class="btn mui-btn mui-btn-block" onclick="searchkstime()">
  33. <span id="ks_riqi">开始时间</span>
  34. </button>
  35. <button id='demo6' class="btn mui-btn mui-btn-block" onclick="searchjstime()">
  36. <span id="js_riqi">结束时间</span>
  37. </button>
  38. <div id='result' class="ui-alert"></div>
  39. </div>
  40. </li>
  41. <li class="mui-button-row">
  42. <button type="button" class="mui-btn mui-btn-primary" id="save">查找</button>&nbsp;&nbsp;
  43. <!-- <button type="button" class="mui-btn mui-btn-primary" id="saveall">查找全部</button>
  44. --> </li>
  45. </ul>
  46. </div>
  47. </div>
  48. </div>
  49. <!--右上角弹出菜单-->
  50. <div id="pullrefresh" class="mui-content mui-scroll-wrapper" style="">
  51. <div class="qd_div" v-for="item in items">
  52. <div class="qd_div1">
  53. <div class="qd_div2">{{item.date}} <span class="qd_span">{{item.att_user_name}}</span></div>
  54. </div>
  55. <div class="qd_div3">
  56. <div class="qd_div4">晨签:<span class="qd_span1">{{item.morningCheck}}</span></div>
  57. <div class="qd_div5">晚签:<span class="qd_span1">{{item.nightCheck}}</span><br>
  58. <span style="color: red; margin-left: auto;" class="qd_span1">{{item.spcailText1}}</span><br>
  59. <span style="color: red; margin-left: auto;" class="qd_span1">{{item.spcailText2}}</span>
  60. </div>
  61. </div>
  62. </div>
  63. <div></div>
  64. </div>
  65. </div>
  66. <script type="text/javascript" src="../../js/jquery-1.11.2.min.js"></script>
  67. <script src="../../js/mui.min.js"></script>
  68. <script src="../../js/config.js"></script>
  69. <script src="../../js/app.js"></script>
  70. <script src="../../js/dj/article/list.js"></script>
  71. <script src="../../js/vue.min.js"></script>
  72. <script src="../../js/mui.picker.min.js"></script>
  73. <script>
  74. mui.init({
  75. pullRefresh: {
  76. container: '#pullrefresh',
  77. down: {
  78. style: 'circle', //必选,下拉刷新样式,目前支持原生5+ ‘circle’ 样式
  79. color: '#2BD009', //可选,默认“#2BD009” 下拉刷新控件颜色
  80. height: '50px', //可选,默认50px.下拉刷新控件的高度,
  81. range: '100px', //可选 默认100px,控件可下拉拖拽的范围
  82. offset: '0px', //可选 默认0px,下拉刷新控件的起始位置
  83. //auto: true, //可选,默认false.首次加载自动上拉刷新一次
  84. callback: reloadNews //必选,刷新函数,根据具体业务来编写,比如通过ajax从服务器获取新数据;
  85. },
  86. up: {
  87. contentrefresh: '正在加载...',
  88. contentnomore:'没有更多数据了',//可选,请求完毕若没有更多数据时显示的提醒内容;
  89. auto: true, //可选,默认false.自动上拉加载一次
  90. callback: pullupRefresh
  91. }
  92. }
  93. });
  94. var pageNo = 1;
  95. var type = 1;
  96. var vmA = new Vue({
  97. el: '#pullrefresh',
  98. data: {
  99. items: [] //列表信息流数据
  100. }
  101. });
  102. //下拉刷新具体业务实现(加载最新数据)
  103. function reloadNews() {
  104. vmA.items = [];
  105. type = 1;
  106. downaddData(type);
  107. }
  108. //上拉加载具体业务实现
  109. function pullupRefresh() {
  110. console.log(type + "------------------")
  111. if(type == 1){
  112. upaddData(type); //不限时间上拉刷新
  113. }else if(type == 2){
  114. upaddData2(); //时间限制上拉刷新
  115. }
  116. }
  117. function upaddData2(){
  118. var url = API.API_URL();
  119. var serviceId = "hr_2018V01GetMyQDQtAttendance";
  120. var state = app.getState(); //获取登陆信息
  121. var staffId = state.user.useId;
  122. var ks_att_time=document.getElementById("ks_riqi").innerHTML;
  123. var js_att_time=document.getElementById("js_riqi").innerHTML;
  124. var obj = {
  125. type : 2,
  126. universalid:staffId,
  127. ks_att_time: ks_att_time,
  128. js_att_time: js_att_time,
  129. pSize: APP.PageSize,
  130. p: pageNo
  131. };
  132. app.ajax(serviceId,obj, function(data) {
  133. //服务器返回响应
  134. //console.log(JSON.stringify(data))
  135. var result = data.returnParams;
  136. var totalRow = data.total;
  137. var totalPage = Math.ceil(totalRow / APP.PageSize);
  138. var list = data.list;
  139. //console.log(list.length);
  140. if(list.length > 0) {
  141. vmA.items = vmA.items.concat(convert(list));
  142. }
  143. mui('#pullrefresh').pullRefresh().endPullupToRefresh(totalPage == pageNo); //参数为true代表没有更多数据了。
  144. if( pageNo == 1 && totalPage>1) {
  145. mui('#pullrefresh').pullRefresh().endPullup();
  146. mui('#pullrefresh').pullRefresh().refresh(true);
  147. }
  148. if(totalPage == 1 ){
  149. mui('#pullrefresh').pullRefresh().endPullup();
  150. }
  151. pageNo = pageNo + 1;
  152. type = 2;
  153. });
  154. }
  155. //时间搜索
  156. document.getElementById("save").addEventListener('click',function(){
  157. pageNo = 1;
  158. var ks_att_time=document.getElementById("ks_riqi").innerHTML;
  159. if(ks_att_time == "开始时间"){
  160. mui.toast("请选择开始时间");
  161. return;
  162. }
  163. var js_att_time=document.getElementById("js_riqi").innerHTML;
  164. if(js_att_time == "结束时间"){
  165. mui.toast("请选择结束时间");
  166. return;
  167. }
  168. document.getElementById('topPopover').style.display='none';
  169. vmA.items = [];
  170. upaddData2(2);
  171. });
  172. function upaddData(p) {
  173. var url = API.API_URL();
  174. var serviceId = "hr_2018V01GetMyQDQtAttendance";
  175. var state = app.getState(); //获取登陆信息
  176. var staffId = state.user.useId;
  177. var ks_att_time=null;
  178. var js_att_time=null;
  179. var obj = {
  180. type:p,
  181. ks_att_time: ks_att_time,
  182. js_att_time: js_att_time,
  183. universalid:staffId,
  184. pSize: APP.PageSize,
  185. p: pageNo
  186. };
  187. app.ajax(serviceId,obj, function(data) {
  188. //服务器返回响应
  189. //console.log('-----qiandao.html------'+JSON.stringify(data))
  190. var result = data.returnParams;
  191. var totalRow = data.total;
  192. var totalPage = Math.ceil(totalRow / APP.PageSize);
  193. if(data.list.length > 0) {
  194. vmA.items = vmA.items.concat(convert(data.list));
  195. }
  196. mui('#pullrefresh').pullRefresh().endPullupToRefresh(totalPage == pageNo); //参数为true代表没有更多数据了。
  197. if(pageNo == 1 && totalPage>1) {
  198. mui('#pullrefresh').pullRefresh().endPullup();
  199. mui('#pullrefresh').pullRefresh().refresh(true);
  200. }
  201. if(totalPage == 1 ){
  202. mui('#pullrefresh').pullRefresh().endPullup();
  203. }
  204. pageNo = pageNo + 1;
  205. });
  206. }
  207. function downaddData(p) {
  208. var url = API.API_URL();
  209. var serviceId = "hr_2018V01GetMyQDQtAttendance";
  210. var state = app.getState(); //获取登陆信息
  211. var staffId = state.user.useId;
  212. var obj = {
  213. type:p,
  214. ks_att_time: null,
  215. js_att_time: null,
  216. universalid:staffId,
  217. pSize: APP.PageSize,
  218. p: 1
  219. };
  220. app.ajax(serviceId,obj, function(data) {
  221. //服务器返回响应
  222. var result = data.returnParams;
  223. if(data.list.length > 0) {
  224. vmA.items = vmA.items.concat(convert(data.list));
  225. mui('#pullrefresh').pullRefresh().endPulldown();
  226. }
  227. });
  228. }
  229. /**
  230. * 1、将服务端返回数据,转换成前端需要的格式
  231. * 2、若服务端返回格式和前端所需格式相同,则不需要改功能
  232. */
  233. function convert(items) {
  234. var newItems = [];
  235. items.forEach(function(item) {
  236. var date=item.att_time.substring(0,11); // "att_time":"2018-10-21 18:13:00",
  237. //"time":"2018-10-21 18:13:00, 2018-10-21 13:53:00, 2018-10-21 18:16:00, 2018-10-21 12:13:00, 2018-10-21 08:13:00",
  238. //"type":"2,1, 2, 2, 1",
  239. var timearr = item.time.split(',');
  240. var typearr = item.type.split(',');
  241. var rem =item.remark;
  242. var remarkarr = ( rem != null ) ? item.remark.split(',') : null;
  243. var type1 = true;
  244. var type2 = true;
  245. var morningCheck = '没有该记录';
  246. var nightCheck = '没有该记录';
  247. var spcailText1 = '';
  248. var spcailText2 = '';
  249. for(var i=0; i<typearr.length; i++){
  250. //console.log(timearr[i]+"-------"+typearr[i]);
  251. //考勤类型(1上班,2下班,3外出,4外出返回,5加班签到,6加班签退)
  252. if(typearr[i] == '1'){
  253. if(type1){ // 第一次为morningCheck赋值
  254. morningCheck = timearr[i];
  255. type1 = false;
  256. }else{ // 第二次为morningCheck赋值
  257. //var st="2009-10-20 14:38:40"
  258. //var et="2009-10-20 15:38:40"
  259. var stdt=new Date(morningCheck.replace("-","/"));
  260. var etdt=new Date(timearr[i].replace("-","/"));
  261. if(stdt>etdt) morningCheck = timearr[i];
  262. }
  263. }
  264. if(typearr[i] == '2'){ // 第一次为nightCheck赋值
  265. if(type2){
  266. nightCheck = timearr[i];
  267. type2 = false;
  268. }else{ // 第二次为nightCheck赋值
  269. //var st="2009-10-20 14:38:40"
  270. //var et="2009-10-20 15:38:40"
  271. var stdt=new Date(nightCheck.replace("-","/"));
  272. var etdt=new Date(timearr[i].replace("-","/"));
  273. if(stdt<etdt) nightCheck = timearr[i];
  274. }
  275. }
  276. if(typearr[i] == '3'){
  277. spcailText1 = "特殊考勤: " + timearr[i] + ' ----- 外出 ----- '+remarkarr[i];
  278. }
  279. if(typearr[i] == '4'){
  280. spcailText2 = "特殊考勤: " + timearr[i] + ' ----- 外出返回 ----- '+remarkarr[i];
  281. }
  282. if(typearr[i] == '6'){
  283. nightCheck += '加班';
  284. }
  285. }
  286. //console.log(morningCheck+"-------"+nightCheck);
  287. newItems.push({
  288. record_id: item.record_id,
  289. universalid: item.universalid,
  290. att_user_name: item.att_user_name,
  291. remark: item.remark,
  292. att_time: item.att_time,
  293. att_date: item.att_date,
  294. morningCheck: morningCheck,
  295. nightCheck: nightCheck,
  296. date: date,
  297. spcailText1: spcailText1,
  298. spcailText2: spcailText2
  299. });
  300. });
  301. return newItems;
  302. }
  303. //点击右上角搜索显示隐藏层
  304. document.getElementById("menu").addEventListener('tap',function(){
  305. //vmA.items = [];
  306. //downaddData(1);
  307. var state=document.getElementById('topPopover').style.display;
  308. if(state == 'none'){
  309. document.getElementById('topPopover').style.display="";
  310. }else{
  311. document.getElementById('topPopover').style.display='none';
  312. }
  313. })
  314. //选取开始时间
  315. function searchkstime() {
  316. var dDate = new Date();
  317. dDate.setFullYear(2014, 7, 16);
  318. var minDate = new Date();
  319. minDate.setFullYear(2010, 0, 1);
  320. var maxDate = new Date();
  321. maxDate.setFullYear(2016, 11, 31);
  322. plus.nativeUI.pickDate(function(e) {
  323. var d = e.date;
  324. var month=d.getMonth() + 1;
  325. if(month < 10){
  326. month= "0"+ month;
  327. }
  328. var day=d.getDate();
  329. if(day < 10){
  330. day= "0"+ day;
  331. }
  332. var a = d.getFullYear() + "-" + month + "-" + day;
  333. document.getElementById("ks_riqi").innerHTML=a;
  334. }, {
  335. title: "请选择日期",
  336. date: dDate,
  337. minDate: minDate,
  338. maxDate: maxDate
  339. });
  340. }
  341. //选取结束时间
  342. function searchjstime() {
  343. var dDate = new Date();
  344. dDate.setFullYear(2014, 7, 16);
  345. var minDate = new Date();
  346. minDate.setFullYear(2010, 0, 1);
  347. var maxDate = new Date();
  348. maxDate.setFullYear(2016, 11, 31);
  349. plus.nativeUI.pickDate(function(e) {
  350. var d = e.date;
  351. var month=d.getMonth() + 1;
  352. if(month < 10){
  353. month= "0"+ month;
  354. }
  355. var day=d.getDate();
  356. if(day < 10){
  357. day= "0"+ day;
  358. }
  359. var a = d.getFullYear() + "-" + month + "-" + day;
  360. document.getElementById("js_riqi").innerHTML=a;
  361. }, {
  362. title: "请选择日期",
  363. date: dDate,
  364. minDate: minDate,
  365. maxDate: maxDate
  366. });
  367. }
  368. </script>
  369. </body>
  370. </html>