qiandao.html 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395
  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. statusBarBackground: '#FFFFFF', //设置状态栏颜色,仅iOS可用
  94. //preloadLimit:5,
  95. });
  96. var pageNo = 1;
  97. var type = 1;
  98. var vmA = new Vue({
  99. el: '#pullrefresh',
  100. data: {
  101. items: [] //列表信息流数据
  102. }
  103. });
  104. //下拉刷新具体业务实现(加载最新数据)
  105. function reloadNews() {
  106. vmA.items = [];
  107. type = 1;
  108. downaddData(type);
  109. }
  110. //上拉加载具体业务实现
  111. function pullupRefresh() {
  112. console.log(type + "------------------")
  113. if(type == 1){
  114. upaddData(type); //不限时间上拉刷新
  115. }else if(type == 2){
  116. upaddData2(); //时间限制上拉刷新
  117. }
  118. }
  119. function upaddData2(){
  120. var url = API.API_URL();
  121. var serviceId = "hr_2018V01GetMyQDQtAttendance";
  122. var state = app.getState(); //获取登陆信息
  123. var staffId = state.user.useId;
  124. var ks_att_time=document.getElementById("ks_riqi").innerHTML;
  125. var js_att_time=document.getElementById("js_riqi").innerHTML;
  126. var obj = {
  127. type : 2,
  128. universalid:staffId,
  129. ks_att_time: ks_att_time,
  130. js_att_time: js_att_time,
  131. pSize: APP.PageSize,
  132. p: pageNo
  133. };
  134. app.ajax(serviceId,obj, function(data) {
  135. //服务器返回响应
  136. //console.log(JSON.stringify(data))
  137. var result = data.returnParams;
  138. var totalRow = data.total;
  139. var totalPage = Math.ceil(totalRow / APP.PageSize);
  140. var list = data.list;
  141. //console.log(list.length);
  142. if(list.length > 0) {
  143. vmA.items = vmA.items.concat(convert(list));
  144. }
  145. mui('#pullrefresh').pullRefresh().endPullupToRefresh(totalPage == pageNo); //参数为true代表没有更多数据了。
  146. if( pageNo == 1 && totalPage>1) {
  147. mui('#pullrefresh').pullRefresh().endPullup();
  148. mui('#pullrefresh').pullRefresh().refresh(true);
  149. }
  150. if(totalPage == 1 ){
  151. mui('#pullrefresh').pullRefresh().endPullup();
  152. }
  153. pageNo = pageNo + 1;
  154. type = 2;
  155. });
  156. }
  157. //时间搜索
  158. document.getElementById("save").addEventListener('click',function(){
  159. pageNo = 1;
  160. var ks_att_time=document.getElementById("ks_riqi").innerHTML;
  161. if(ks_att_time == "开始时间"){
  162. mui.toast("请选择开始时间");
  163. return;
  164. }
  165. var js_att_time=document.getElementById("js_riqi").innerHTML;
  166. if(js_att_time == "结束时间"){
  167. mui.toast("请选择结束时间");
  168. return;
  169. }
  170. document.getElementById('topPopover').style.display='none';
  171. vmA.items = [];
  172. upaddData2(2);
  173. });
  174. function upaddData(p) {
  175. var url = API.API_URL();
  176. var serviceId = "hr_2018V01GetMyQDQtAttendance";
  177. var state = app.getState(); //获取登陆信息
  178. var staffId = state.user.useId;
  179. var ks_att_time=null;
  180. var js_att_time=null;
  181. var obj = {
  182. type:p,
  183. ks_att_time: ks_att_time,
  184. js_att_time: js_att_time,
  185. universalid:staffId,
  186. pSize: APP.PageSize,
  187. p: pageNo
  188. };
  189. app.ajax(serviceId,obj, function(data) {
  190. //服务器返回响应
  191. //console.log('-----qiandao.html------'+JSON.stringify(data))
  192. var result = data.returnParams;
  193. var totalRow = data.total;
  194. var totalPage = Math.ceil(totalRow / APP.PageSize);
  195. if(data.list.length > 0) {
  196. vmA.items = vmA.items.concat(convert(data.list));
  197. }
  198. mui('#pullrefresh').pullRefresh().endPullupToRefresh(totalPage == pageNo); //参数为true代表没有更多数据了。
  199. if(pageNo == 1 && totalPage>1) {
  200. mui('#pullrefresh').pullRefresh().endPullup();
  201. mui('#pullrefresh').pullRefresh().refresh(true);
  202. }
  203. if(totalPage == 1 ){
  204. mui('#pullrefresh').pullRefresh().endPullup();
  205. }
  206. pageNo = pageNo + 1;
  207. });
  208. }
  209. function downaddData(p) {
  210. var url = API.API_URL();
  211. var serviceId = "hr_2018V01GetMyQDQtAttendance";
  212. var state = app.getState(); //获取登陆信息
  213. var staffId = state.user.useId;
  214. var obj = {
  215. type:p,
  216. ks_att_time: null,
  217. js_att_time: null,
  218. universalid:staffId,
  219. pSize: APP.PageSize,
  220. p: 1
  221. };
  222. app.ajax(serviceId,obj, function(data) {
  223. //服务器返回响应
  224. var result = data.returnParams;
  225. if(data.list.length > 0) {
  226. vmA.items = vmA.items.concat(convert(data.list));
  227. mui('#pullrefresh').pullRefresh().endPulldown();
  228. }
  229. });
  230. }
  231. /**
  232. * 1、将服务端返回数据,转换成前端需要的格式
  233. * 2、若服务端返回格式和前端所需格式相同,则不需要改功能
  234. */
  235. function convert(items) {
  236. var newItems = [];
  237. items.forEach(function(item) {
  238. var date=item.att_time.substring(0,11); // "att_time":"2018-10-21 18:13:00",
  239. //"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",
  240. //"type":"2,1, 2, 2, 1",
  241. var timearr = item.time.split(',');
  242. var typearr = item.type.split(',');
  243. var rem =item.remark;
  244. var remarkarr = ( rem != null ) ? item.remark.split(',') : null;
  245. var type1 = true;
  246. var type2 = true;
  247. var morningCheck = '没有该记录';
  248. var nightCheck = '没有该记录';
  249. var spcailText1 = '';
  250. var spcailText2 = '';
  251. for(var i=0; i<typearr.length; i++){
  252. //console.log(timearr[i]+"-------"+typearr[i]);
  253. //考勤类型(1上班,2下班,3外出,4外出返回,5加班签到,6加班签退)
  254. if(typearr[i] == '1'){
  255. if(type1){ // 第一次为morningCheck赋值
  256. morningCheck = timearr[i];
  257. type1 = false;
  258. }else{ // 第二次为morningCheck赋值
  259. //var st="2009-10-20 14:38:40"
  260. //var et="2009-10-20 15:38:40"
  261. var stdt=new Date(morningCheck.replace("-","/"));
  262. var etdt=new Date(timearr[i].replace("-","/"));
  263. if(stdt>etdt) morningCheck = timearr[i];
  264. }
  265. }
  266. if(typearr[i] == '2'){ // 第一次为nightCheck赋值
  267. if(type2){
  268. nightCheck = timearr[i];
  269. type2 = false;
  270. }else{ // 第二次为nightCheck赋值
  271. //var st="2009-10-20 14:38:40"
  272. //var et="2009-10-20 15:38:40"
  273. var stdt=new Date(nightCheck.replace("-","/"));
  274. var etdt=new Date(timearr[i].replace("-","/"));
  275. if(stdt<etdt) nightCheck = timearr[i];
  276. }
  277. }
  278. if(typearr[i] == '3'){
  279. spcailText1 = "特殊考勤: " + timearr[i] + ' ----- 外出 ----- '+remarkarr[i];
  280. }
  281. if(typearr[i] == '4'){
  282. spcailText2 = "特殊考勤: " + timearr[i] + ' ----- 外出返回 ----- '+remarkarr[i];
  283. }
  284. if(typearr[i] == '6'){
  285. nightCheck += '加班';
  286. }
  287. }
  288. //console.log(morningCheck+"-------"+nightCheck);
  289. newItems.push({
  290. record_id: item.record_id,
  291. universalid: item.universalid,
  292. att_user_name: item.att_user_name,
  293. remark: item.remark,
  294. att_time: item.att_time,
  295. att_date: item.att_date,
  296. morningCheck: morningCheck,
  297. nightCheck: nightCheck,
  298. date: date,
  299. spcailText1: spcailText1,
  300. spcailText2: spcailText2
  301. });
  302. });
  303. return newItems;
  304. }
  305. //点击右上角搜索显示隐藏层
  306. document.getElementById("menu").addEventListener('tap',function(){
  307. //vmA.items = [];
  308. //downaddData(1);
  309. var state=document.getElementById('topPopover').style.display;
  310. if(state == 'none'){
  311. document.getElementById('topPopover').style.display="";
  312. }else{
  313. document.getElementById('topPopover').style.display='none';
  314. }
  315. })
  316. //选取开始时间
  317. function searchkstime() {
  318. var dDate = new Date();
  319. dDate.setFullYear(2014, 7, 16);
  320. var minDate = new Date();
  321. minDate.setFullYear(2010, 0, 1);
  322. var maxDate = new Date();
  323. maxDate.setFullYear(2016, 11, 31);
  324. plus.nativeUI.pickDate(function(e) {
  325. var d = e.date;
  326. var month=d.getMonth() + 1;
  327. if(month < 10){
  328. month= "0"+ month;
  329. }
  330. var day=d.getDate();
  331. if(day < 10){
  332. day= "0"+ day;
  333. }
  334. var a = d.getFullYear() + "-" + month + "-" + day;
  335. document.getElementById("ks_riqi").innerHTML=a;
  336. }, {
  337. title: "请选择日期",
  338. date: dDate,
  339. minDate: minDate,
  340. maxDate: maxDate
  341. });
  342. }
  343. //选取结束时间
  344. function searchjstime() {
  345. var dDate = new Date();
  346. dDate.setFullYear(2014, 7, 16);
  347. var minDate = new Date();
  348. minDate.setFullYear(2010, 0, 1);
  349. var maxDate = new Date();
  350. maxDate.setFullYear(2016, 11, 31);
  351. plus.nativeUI.pickDate(function(e) {
  352. var d = e.date;
  353. var month=d.getMonth() + 1;
  354. if(month < 10){
  355. month= "0"+ month;
  356. }
  357. var day=d.getDate();
  358. if(day < 10){
  359. day= "0"+ day;
  360. }
  361. var a = d.getFullYear() + "-" + month + "-" + day;
  362. document.getElementById("js_riqi").innerHTML=a;
  363. }, {
  364. title: "请选择日期",
  365. date: dDate,
  366. minDate: minDate,
  367. maxDate: maxDate
  368. });
  369. }
  370. </script>
  371. </body>
  372. </html>