webmain-we-ying20231219175640@tpl_ying_daka.html 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433
  1. <!DOCTYPE html>
  2. <html lang="zh-CN">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  5. <meta name="viewport" content="width=device-width,initial-scale=1,user-scalable=0">
  6. <title><?=$da['title']?></title>
  7. <link rel="stylesheet" type="text/css" href="mode/weui/weui.min.css"/>
  8. <link rel="stylesheet" type="text/css" href="web/res/fontawesome/css/font-awesome.min.css">
  9. <link rel="stylesheet" type="text/css" href="webmain/css/rui.css">
  10. <script type="text/javascript" src="js/jquery.js"></script>
  11. <script type="text/javascript" src="js/js.js"></script>
  12. <script type="text/javascript" src="js/jswx.js"></script>
  13. <script type="text/javascript" src="js/base64-min.js"></script>
  14. <script charset="utf-8" src="https://map.qq.com/api/js?v=2.exp&libraries=convertor,geometry&key=<?=$da['qqmapkey']?>"></script>
  15. <script type="text/javascript" src="js/dingwei.js"></script>
  16. <style>
  17. <?php
  18. $maincolor = getconfig('apptheme','#1389D3');
  19. $maincolora= c('image')->colorTorgb($maincolor);
  20. $maincolors= ''.$maincolora[0].','.$maincolora[1].','.$maincolora[2].'';
  21. echo 'body{--main-color:'.$maincolor.'}';
  22. ?>
  23. .weui_tabbar_icon{text-align:center;color:#888888;font-size:20px;}
  24. .weui_tabbar_item{padding-top:2px;margin-bottom:5px;position:relative}
  25. .weui_bar_item_on .weui_tabbar_icon{color:<?=$maincolor?>}
  26. </style>
  27. <script>
  28. var kqrs = <?=json_encode($kqrs);?>,kqors = <?=json_encode($kqors);?>,kqallrs=[],isgzh = <?=$isgzh?>;
  29. js.servernow = '<?=$rock->now?>',openfrom='<?=$openfrom?>';
  30. var label='',accuracy=0,latitude='',longitude='',kqjuli=-1,addbo = true,explain='',dakaci=1;
  31. function initbody(){
  32. js.getsplit();
  33. showtimessabc();
  34. showkqrswz();
  35. initupload();
  36. kqallrs.push(kqrs);
  37. for(var i in kqors)kqallrs.push(kqors[i]);
  38. nowtimetime = js.now('time');
  39. addkqinfor(0);
  40. }
  41. function addkqinfor(bo){
  42. js.ajax('kaoqin','getshang',{},function(ret){
  43. var sbarr = ret.sbarr,s='',rs;
  44. s='<table width="100%" class="r-border-t">';
  45. for(var i=0;i<sbarr.length;i++){
  46. rs = sbarr[i];
  47. if(i>0)s+='<tr><td colspan="2"><div style="margin:0px 10px" class="r-border-t"></div></td></tr>';
  48. s+='<tr><td align="center" nowrap height="60px"><div style="padding:0px 20px"><b>'+rs.name+'</b></div></td><td width="99%"><div style="color:#888888;font-size:14px">'+rs.stime.substr(0,5)+'-'+rs.etime.substr(0,5)+'</div><div>'+rs.state+'</div></td></tr>';
  49. }
  50. s+='</table>';
  51. $('#shangbshow').html(s);
  52. var dkarr = ret.dkarr;
  53. var s = '',i,oi=1;
  54. for(i=0;i<dkarr.length;i++){
  55. s+=','+dkarr[i].dktime+'';
  56. oi++;
  57. }
  58. if(s!='')s=s.substr(1);
  59. $('#todyadak').html(s);
  60. dakaci = oi;
  61. if(bo==0){
  62. $('#dkbtn').html('第'+oi+'次打卡');
  63. js.dw.init(isgzh); //定位开始
  64. }
  65. },'mode', false,false, 'get');
  66. }
  67. function showtimessabc(){
  68. var dt = js.serverdt('Y年m月d日(星期W) H:i:s').split(' ');
  69. $('#dtstr').html(dt[0]);
  70. $('#timess').html(dt[1]);
  71. setTimeout('showtimessabc()',1000);
  72. }
  73. //显示考勤位置
  74. function showkqrswz(){
  75. var s = '';
  76. if(kqrs){
  77. s+=','+kqrs.name+'';
  78. if(kqrs.iswgd=='1')s=',无固定位置';
  79. if(kqors && kqrs.iswgd=='0')for(var i=0;i<kqors.length;i++){
  80. s+=','+kqors[i].name+'';
  81. if(kqors[i].iswgd=='1'){
  82. s=',无固定位置';
  83. break;
  84. }
  85. }
  86. }
  87. if(s=='')s='没设置考勤位置';
  88. if(s!='')s=s.substr(1);
  89. $('#weizhi').html(s);
  90. }
  91. js.dw.ondwwait=function(msg){
  92. latitude = '';
  93. $('#dwshow').html('<img src="images/loadings.gif" height="14px" align="absmiddle"> '+msg+'');
  94. return true;
  95. }
  96. js.dw.ondwerr=function(msg){
  97. latitude = '';
  98. $('#dwshow').html(''+msg+',<a href="javascript:;" onclick="js.dw.start()">[在定位]</a>');
  99. }
  100. //定位成功后回调
  101. js.dw.ondwcall = function(res){
  102. latitude = res.latitude;
  103. longitude = res.longitude;
  104. accuracy = res.accuracy;
  105. label = res.address;
  106. var center = res.center;
  107. $('#dwshow').html(''+res.addressinfo+',<a href="javascript:;" onclick="js.dw.start()">[更新]</a>');
  108. var i,kqrsa,enddt,juli;
  109. addbo = true;//可以添加记录
  110. for(i=0;i<kqallrs.length;i++){
  111. kqrsa = kqallrs[i];
  112. enddt = new qq.maps.LatLng(parseFloat(kqrsa.location_x), parseFloat(kqrsa.location_y));
  113. juli = parseInt(qq.maps.geometry.spherical.computeDistanceBetween(center, enddt));
  114. if(juli<0)juli = 0-juli;
  115. if(kqrsa['iswgd']=='1')juli=0; //无固定位置的
  116. kqallrs[i]['kqjuli'] = juli;
  117. kqjuli = juli;
  118. }
  119. if(!isfenwein()){
  120. $('#dkbtnto').addClass('btnwai');
  121. $('#dkbtn').html('外出定位');
  122. }else{
  123. $('#dkbtnto').removeClass('btnwai');
  124. $('#dkbtn').html('第'+dakaci+'次打卡');
  125. }
  126. nowtimetime = js.now('time');
  127. }
  128. //判断有没有在考勤地点上
  129. function isfenwein(){
  130. var i,kqrsa,slju,sljus,iskqbo=false;
  131. for(i=0;i<kqallrs.length;i++){
  132. kqrsa = kqallrs[i];
  133. slju = parseFloat(kqrsa.precision);
  134. sljus = parseFloat(kqrsa.kqjuli);
  135. if(sljus<=slju)iskqbo = true;
  136. }
  137. kqwucha = slju;
  138. return iskqbo;
  139. }
  140. var addkaoqinbool=false,upfileid='';
  141. function addkaoqin(o1, lbos){
  142. if((js.now('time') - nowtimetime)>60*1000){
  143. js.wx.alert('停留页面太久,请刷新页面再试',function(){
  144. js.reload();
  145. });
  146. return;
  147. }
  148. if(addkaoqinbool){
  149. js.wx.alert('已保存过了,请退出页面');
  150. return;
  151. }
  152. if(js.dw.dwbool){js.wx.alert('正在定位,稍后在添加');return;}
  153. if(latitude=='' || kqjuli==-1){js.wx.alert('定位没有成功,不能添加');return;}
  154. if(!addbo){js.wx.alert('请重新定位后在打卡');return;}
  155. if(!lbos && ispzs){
  156. js.wx.load('<span id="tisssa">处理中</span>...');
  157. if(!imagecont){
  158. upfaceobj.start();
  159. }else{
  160. upfaceobj.sendbase64(imagecont,{filename:'打卡图片.png'});
  161. }
  162. return;
  163. }
  164. if(isfenwein()){
  165. if(kqrs.ispz=='1' && !ispzs){js.wx.alert('请使用相机拍照才能打卡');return;}
  166. adddk('打卡',1);
  167. }else{
  168. adddk('保存',0);
  169. }
  170. }
  171. function adddk(ts, lx){
  172. var o1 = get('dkbtn');
  173. $(o1).html(''+ts+'中...');
  174. var ispz = (kqrs) ? kqrs.ispz : '0';
  175. var data = {location_x:latitude,type:lx,location_y:longitude,scale:12,fileid:upfileid,precision:accuracy,label:jm.base64encode(label),sm:jm.base64encode(explain),ispz:ispz};
  176. addkaoqinbool = true;
  177. js.ajax('weixin','addlocation',data,function(ret){
  178. js.wx.unload();
  179. js.wx.alert(''+ts+'成功:'+ret.now+'');
  180. $(o1).html(''+ts+'成功');
  181. addbo = false;
  182. addkqinfor(1);
  183. if(lx==1)get('notify_sound_audio').play();
  184. },'none');
  185. }
  186. function addbeizhu(o1){
  187. js.wx.prompt('加备注','请输入备注说明:',function(txt){
  188. explain = txt;
  189. if(txt){
  190. $(o1).html('备注:'+txt+'');
  191. }else{
  192. $(o1).html('加备注...');
  193. }
  194. });
  195. }
  196. function changetab(lx){
  197. var url='?d=we&m=ying&a=location';
  198. if(lx==2)url='?m=ying&d=we&num=kqtotal';
  199. if(lx==3)url='?m=ying&d=we&num=kqpai';
  200. js.location(url);
  201. }
  202. function paizhao33(){
  203. if(js.jssdkstate!=1){
  204. js.wx.alert('非微信下的jssdk无法使用拍照');
  205. return;
  206. }
  207. wx.chooseImage({
  208. count: 1,
  209. sizeType: ['compressed'],
  210. sourceType: ['camera'],
  211. defaultCameraMode: "normal",
  212. isSaveToAlbum: 0,
  213. success: function (res) {
  214. var localIds = res.localIds;
  215. }
  216. });
  217. }
  218. var imagecont = '';
  219. function paizhao(){
  220. if(!ispzs){
  221. if(apicloud){
  222. api.getPicture({
  223. sourceType: 'camera',
  224. encodingType: 'png',
  225. destinationType: 'base64',quality:80,
  226. targetWidth:1000,targetHeight:1000
  227. }, function(ret, err) {
  228. if (ret) {
  229. imagecont= ret.base64Data;
  230. $('#paizhaoimg').parent().show();
  231. get('paizhaoimg').src = imagecont;
  232. get('pzbtnicons').className='icon-remove';
  233. ispzs = true;
  234. }
  235. });
  236. }else{
  237. upfaceobj.click({uptype:'image'});
  238. }
  239. }else{
  240. upfaceobj.clear();
  241. imagecont = '';
  242. $('#paizhaoimg').parent().hide();
  243. get('paizhaoimg').src = 'images/noimg.jpg';
  244. get('pzbtnicons').className='icon-camera';
  245. ispzs = false;
  246. }
  247. }
  248. function showimgs(o1){
  249. $.imgview({'url':o1.src,'ismobile':true});
  250. }
  251. var ispzs = false;
  252. function initupload(){
  253. upfaceobj=$.rockupload({
  254. uptype:'image',
  255. inputfile:'cameraInput',
  256. fileview:'fileview',
  257. autoup:false,
  258. urlparams:{noasyn:'yes'},
  259. onsuccess:function(f,str){
  260. var a=js.decode(str);
  261. if(imagecont){
  262. imagecont= '';
  263. upfileid = a.id;
  264. addkaoqin(false,true);
  265. }
  266. },
  267. onchange:function(f){
  268. $('#paizhaoimg').parent().show();
  269. get('paizhaoimg').src = f.imgviewurl;
  270. get('pzbtnicons').className='icon-remove';
  271. ispzs = true;
  272. },
  273. onchangebefore:function(f){
  274. if(f.lastModified){
  275. var btune = js.now('time')-f.lastModified;
  276. if(btune>10*1000)return '请使用相机拍照';
  277. }
  278. },
  279. onprogress:function(f,bl){
  280. $('#tisssa').html('上传中('+bl+'%)');
  281. },
  282. allsuccess:function(far, ids){
  283. imagecont = '';
  284. upfileid = ids;
  285. addkaoqin(false,true);
  286. }
  287. });
  288. }
  289. function changfile(o1){
  290. upfaceobj.change(o1);
  291. }
  292. var yy={
  293. iscy:'<?=$iscy?>',
  294. clickadd:function(){
  295. var str = '应用首页显示';
  296. if(this.iscy==1)str='取消应用首页显示';
  297. if(apicloud){
  298. api.actionSheet({
  299. title: '选择菜单',
  300. cancelTitle: '取消',
  301. buttons: [str,'关闭应用']
  302. }, function(ret, err) {
  303. var index = ret.buttonIndex;
  304. if(index==1)yy.addchangying();
  305. if(index==2)js.back();
  306. });
  307. }else{
  308. js.showmenu({
  309. data:[{name:str,lx:1}],
  310. width:170,
  311. onclick:function(d){
  312. if(d.lx==1)yy.addchangying();
  313. }
  314. });
  315. }
  316. },
  317. addchangying:function(){
  318. js.ajax('indexreim','shecyy',{yynum:'kqdaka'},function(ret){
  319. yy.iscy = ret.iscy;
  320. js.wx.msgok(ret.msg, false, 1);
  321. },'mode', false,false, 'get');
  322. }
  323. }
  324. </script>
  325. <style>
  326. .addbtns{ background:#C5E0F7;padding:5px;margin-top:20px;width:100px;height:100px;border-radius:50%}
  327. .addbtnss{right:10px;bottom:10px;width:100px;height:100px; background:#4E9CE0;opacity:0.8;z-index:1;border-radius:50%;font-size:16px;color:white;text-align:center;line-height:98px;}
  328. .addbtnss:active{opacity:1}
  329. .btnwai{background:#FCD5BA}
  330. .btnwai .addbtnss{background:#ff6600}
  331. </style>
  332. </head>
  333. <body>
  334. <?php if($showheader==1){?>
  335. <div>
  336. <div class="r-header" style="padding-top:<?=$cenghei?>px" >
  337. <div class="r-header-text" onclick="location.reload()" id="header_title"><?=$da['title']?></div>
  338. <span onclick="js.back()" class="r-position-left r-header-btn"><i class="icon-chevron-left"></i></span>
  339. <span onclick="yy.clickadd()" class="r-position-right r-header-btn"><i class="icon-plus"></i></span>
  340. </div>
  341. <div class="blank50" id="header_line" style="height:<?=($cenghei+50)?>px"></div>
  342. </div>
  343. <?php }?>
  344. <div align="center" style="background:white;padding-bottom:10px">
  345. <div id="timess" onclick="location.reload()" style="font-size:40px">15:10:00</div>
  346. <div id="dtstr" style="font-size:14px"><?=date('Y年m月d日')?>(星期三)</div>
  347. <div class="blank5"></div>
  348. <div id="dwshow" style="font-size:14px;color:#aaaaaa;padding:0px 10px">等待定位</div>
  349. </div>
  350. <div style="display:none;position:fixed;z-index:2;left:1px;top:60px;width:120px;height:80px;overflow:hidden;"><img width="100%" onclick="showimgs(this)" id="paizhaoimg" src="images/noimg.jpg"></div>
  351. <div style="display:none">
  352. <form name="form_cameraInput">
  353. <input type="file" <?php if($rock->iswebbro())echo 'capture="camera"';?> onchange="changfile(this)" accept="image/*" id="cameraInput" /></form>
  354. </div>
  355. <div style="display:none" id="fileview"></div>
  356. <div class="r-padding10 r-border-t" style="background:white;padding:15px 10px; background-color:#f5f5f5">考勤范围:<font color="#888888" id="weizhi">没设置考勤位置</font></div>
  357. <div id="shangbshow" style="background:white">
  358. <table width="100%" class="r-border-t">
  359. <tr><td align="center" nowrap height="60px"><div style="padding:0px 20px"><b>上班</b></div></td><td width="99%"><div style="color:#888888;font-size:14px">09:00-12:00</div><div><font color=#888888>加载中</font></div></td></tr>
  360. <tr><td colspan="2"><div style="margin:0px 10px" class="r-border-t"></div></td></tr><tr><td align="center" nowrap height="60px"><div style="padding:0px 20px"><b>下班</b></div></td><td width="99%"><div style="color:#888888;font-size:14px">13:00-18:00</div><div><font color=#888888>加载中</font></div></td></tr>
  361. </table>
  362. </div>
  363. <div class="r-border-t"></div>
  364. <div align="center">
  365. <div id="dkbtnto" class="addbtns">
  366. <div class="addbtnss" id="dkbtn" onclick="addkaoqin(this)">第1次打卡</div>
  367. </div>
  368. </div>
  369. <div class="r-padding10" align="center"><a id="beshuomdiv" onclick="addbeizhu(this)" href="javascript:;">加备注...</a>&nbsp;&nbsp;<a href="javascript:;" onclick="paizhao()"><i id="pzbtnicons" class="icon-camera"></i></a></div>
  370. <div class="r-padding10 r-wrap" align="center" style="font-size:14px;color:#888888;">今日打卡:<span id="todyadak">无</span></div>
  371. <audio id="notify_sound_audio" hidden="true" style="display:none" src="web/res/sound/dkcg.mp3"></audio>
  372. <div style="height:55px; overflow:hidden"></div>
  373. <div style="height:55px;overflow:hidden;z-index:2;position:fixed" class="weui_tabbar">
  374. <a href="javascript:;" class="weui_tabbar_item weui_bar_item_on">
  375. <div class="weui_tabbar_icon">
  376. <i class="icon-time"></i>
  377. </div>
  378. <p class="weui_tabbar_label"><?=$da['title']?></p>
  379. </a>
  380. <a href="javascript:;" onclick="changetab(1)" class="weui_tabbar_item">
  381. <div class="weui_tabbar_icon">
  382. <i class="icon-fighter-jet"></i>
  383. </div>
  384. <p class="weui_tabbar_label">外勤定位</p>
  385. </a>
  386. <a href="javascript:;" onclick="changetab(2)" class="weui_tabbar_item">
  387. <div class="weui_tabbar_icon">
  388. <i class="icon-bar-chart"></i>
  389. </div>
  390. <p class="weui_tabbar_label">考勤统计</p>
  391. </a>
  392. <a href="javascript:;" onclick="changetab(3)" class="weui_tabbar_item">
  393. <div class="weui_tabbar_icon">
  394. <i class="icon-list-alt"></i>
  395. </div>
  396. <p class="weui_tabbar_label">我的排班</p>
  397. </a>
  398. </div>
  399. <script type="text/javascript" src="web/res/js/jquery-rockupload.js"></script>
  400. <script type="text/javascript" src="web/res/js/jquery-imgview.js"></script>
  401. </body>
  402. </html>