tpl_ying_daka.html 14 KB

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