SignController.php 49 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105
  1. <?php
  2. //ini_set('display_errors', on);
  3. Doo::loadClass('auth');
  4. Doo::loadClass('attfile');
  5. Doo::loadClass('profile');
  6. Doo::loadClass('project');
  7. Doo::loadClass('contractact');
  8. Doo::loadClass('actmeasure');
  9. Doo::loadClass('numofperact');
  10. Doo::loadClass('measureauditact');
  11. Doo::loadClass('sign');
  12. Doo::loadClass('sms');
  13. Doo::loadModelAt('aconfig', 'admin');
  14. //define('FPDF_FONTPATH','protected/class/fpdf1.5/font/');
  15. //Doo::loadClass('fpdf');
  16. /* * proDetail
  17. * MainController
  18. * Feel free to delete the methods and replace them with your own code.
  19. *
  20. * @author darkredz
  21. */
  22. class SignController extends DooController
  23. {
  24. private $aconfig, $data, $sms, $sign, $auth, $attfile, $profile, $project, $contractact, $actmeasure, $measureauditact, $numofperact, $statusArray = array('uncheck' => '<span class = "colGray">未审批</span>', 'checking' => '<span class = "colOrange">审批中</span>', 'checked' => '<span class = "colGreen">审批通过</span>', 'checkno' => '<span class = "colRed">审批不通过</span>');
  25. public function beforeRun($resource, $action)
  26. {
  27. if ($this->auth->getUid()) {
  28. $uGroups = $this->profile->getProWithUid($this->auth->getUid());
  29. $falg = Doo::acl()->isAllowed($uGroups['groups'], $resource, $action);
  30. if (!$falg)
  31. return Doo::acl()->defaultFailedRoute;
  32. } else {
  33. return Doo::acl()->defaultFailedRoute;
  34. }
  35. }
  36. public function __construct()
  37. {
  38. $this->aconfig = new AConfig();
  39. $this->auth = new Auth();
  40. $this->attfile = new attFile();
  41. $this->profile = new Profile();
  42. $this->project = new Project();
  43. $this->contractact = new Contractact();
  44. $this->actmeasure = new actMeasure();
  45. $this->numofperact = new NumofperAct();
  46. $this->measureauditact = new MeasureauditAct();
  47. $this->sign = new Signn();
  48. $this->sms = new Sms(Doo::conf()->SMS_URL, Doo::conf()->SMS_AUTHKEY);
  49. // $this->pdf = new FPDF('P','mm','A4');
  50. $this->data['rootUrl'] = Doo::conf()->APP_URL;
  51. $this->data['currChannle'] = 'sign';
  52. $this->data['user'] = $this->profile->getProWithUid($this->auth->getUid());
  53. $mpidArray = $this->measureauditact->getAuditProject2($this->auth->getUid());
  54. $this->data['numofchecking'] = 0;
  55. if (isset($mpidArray[0]['pid'])) {
  56. foreach ($mpidArray as $key => $value) {
  57. // 审批操作按照时间排序多标段
  58. $this->data['numofchecking'] += $this->measureauditact->getCountMyChecking($value['pid'], $this->auth->getUid());
  59. }
  60. }
  61. if (!isset($this->data['numofchecking']) || $this->data['numofchecking'] == 0) {
  62. $this->data['numofchecking'] = null;
  63. }
  64. $signSwitch = $this->aconfig->getOne(array('select' => 'signswitch', 'asArray' => TRUE))['signswitch'];
  65. if ($signSwitch == 0)
  66. exit('未开启在线签名功能');
  67. $this->data['signSwitch'] = $signSwitch;
  68. //获取需要您签署的数目
  69. $this->data['needSignNum'] = $this->sign->getNeedSignNumbyUid($this->auth->getUid()) != 0 ? $this->sign->getNeedSignNumbyUid($this->auth->getUid()) : '';
  70. //获取桌面版本
  71. $this->getsoftware();
  72. }
  73. function getsoftware(){
  74. $StrJson = ($this->aconfig->getOne(array('select' => 'upgradeinfo', 'asArray' => TRUE))['upgradeinfo']);
  75. $upgradeinfo = json_decode($StrJson, true);
  76. if ($upgradeinfo) {
  77. $this->data['version'] = $upgradeinfo['version'];
  78. $this->data['download'] = $upgradeinfo['download'];
  79. }
  80. }
  81. /**
  82. *
  83. * @return type
  84. */
  85. public function index()
  86. {
  87. //获取我发起的签署数目
  88. $this->data['mySignNum'] = $this->sign->getMySignNumbyUid($this->auth->getUid());
  89. //获取关于我的正在签署数目
  90. $this->data['doingSignNum'] = $this->sign->getDoingSignNumbyUid($this->auth->getUid());
  91. //获取关于我的完成签署数目
  92. $this->data['doneSignNum'] = $this->sign->getDoneSignNumbyUid($this->auth->getUid());
  93. $this->data['launchsign'] = $this->aconfig->getOne(array('select' => 'launchsignswitch', 'asArray' => TRUE))['launchsignswitch'];
  94. $this->render('sign-index', $this->data, TRUE);
  95. }
  96. public function signNeedList(){
  97. $needlist = array();
  98. $searchsql = 'sid in(select `jl_sign_audit`.sid from `jl_sign_audit` where `jl_sign_audit`.status="checking" and `jl_sign_audit`.audituid='.$this->auth->getUid().')';
  99. $projectlist = $this->sign->getSignGroupByProject($searchsql);
  100. if(!empty($projectlist)){
  101. foreach($projectlist as $k => $v){
  102. $projectmsg = $this->project->getRowByPid($v['project']);
  103. $needlist[$k]['project'] = $projectmsg['pname'];
  104. $needlist[$k]['tlist'] = array();
  105. $tenderlist = $this->sign->getSignGroupByTender($v['project'],$searchsql);
  106. if(!empty($tenderlist)) {
  107. foreach ($tenderlist as $tk => $tv) {
  108. $tendermsg = $this->actmeasure->getRowByPmid($tv['tender']);
  109. $needlist[$k]['tlist'][$tk]['tender'] = $tendermsg['pmname'];
  110. $needlist[$k]['tlist'][$tk]['plist'] = array();
  111. $phasenolist = $this->sign->getSignGroupByPhaseno($tv['tender'],$searchsql);
  112. if(!empty($phasenolist)) {
  113. foreach ($phasenolist as $pk => $pv) {
  114. // $phasenomsg = $this->numofperact->getCurrStatus($pv['phaseno']);
  115. $needlist[$k]['tlist'][$tk]['plist'][$pk]['phaseno'] = $pv['phaseno'];
  116. $needlist[$k]['tlist'][$tk]['plist'][$pk]['signlist'] = array();
  117. $signlist = $this->sign->getSignList($searchsql.' and (status="checking" or status="back") and tender='.$tv['tender'].' and phaseno='.$pv['phaseno'], '0,1000');
  118. if(!empty($signlist)) {
  119. foreach ($signlist as $sk => $sv) {
  120. $needlist[$k]['tlist'][$tk]['plist'][$pk]['signlist'][$sk]['sid'] = $sv['sid'];
  121. $needlist[$k]['tlist'][$tk]['plist'][$pk]['signlist'][$sk]['name'] = $sv['name'];
  122. $needlist[$k]['tlist'][$tk]['plist'][$pk]['signlist'][$sk]['auditlist'] = $this->sign->getSignAuditlist($sv['sid']);
  123. }
  124. }
  125. }
  126. }
  127. }
  128. }
  129. }
  130. }
  131. $this->data['needlist'] = $needlist;
  132. $this->render('sign-list-need_sign',$this->data, TRUE);
  133. }
  134. public function signNeedView(){
  135. if(!isset($this->params['sid']) || !is_numeric($this->params['sid'])){
  136. exit('没有报表参数');
  137. }
  138. $issign = $this->sign->getisSignbySidUid($this->params['sid'],$this->auth->getUid());
  139. if(empty($issign)){
  140. exit('不是当前签署人无法访问本页');
  141. }
  142. if(isset($_POST['status'])){
  143. //终止签署
  144. if($_POST['status'] == 'stop'){
  145. $result = $this->sign->updateSignStatusAndTime($this->params['sid'],'stop',time());
  146. $signAudit = $this->sign->getOneSignAudit($this->params['sid'],$this->auth->getUid());
  147. $result2 = $this->sign->updateSignAudit($signAudit['satid'],'stop',time());
  148. if($result && $result2){
  149. // SMS Start
  150. $signArray = $this->sign->getOneSignbysid($this->params['sid']);
  151. $pmname = $this->actmeasure->getRowByPmid($signArray['tender']);
  152. $userProArray = $this->profile->getProWithUid($signArray['audituid']);
  153. if (isset($userProArray) && !empty($userProArray['mobile'])) {
  154. $sendarr1 = '“' .$pmname['pmname'].'”的“'. $signArray["name"] .'”';
  155. $sendarr2 = str_replace('【','',$sendarr1);
  156. $sendmsg = str_replace('】','',$sendarr2);
  157. $retval = $this->__auditNotice($userProArray['mobile'], Doo::conf()->SMS_TIPS_PRE . $sendmsg .Doo::conf()->SMS_TIPS["AUDIT_NOTICE_AUDITOR6"]);
  158. }
  159. // SMS End
  160. echo json_encode(array('code' => 200, 'url' => '/sign/list'));
  161. exit;
  162. }
  163. echo json_encode(array('code' => 400, 'msg' => '终止签署失败'));
  164. exit;
  165. }elseif($_POST['status'] == 'back'){
  166. $signauditlist = $this->sign->getSignAuditList($this->params['sid']);
  167. $change = -1;
  168. foreach($signauditlist as $k => $v){
  169. if($v['status'] == 'checking' && $k != 0) {
  170. $change = $k-1;
  171. break;
  172. }
  173. }
  174. if($change != -1){
  175. $result = $this->sign->updateSignStatusAndTime($this->params['sid'],'back',time());
  176. $signAudit = $this->sign->getOneSignAudit($this->params['sid'],$this->auth->getUid());
  177. $result3 = $this->sign->updateSignAudit($signAudit['satid'],'uncheck',0);
  178. $result2 = $this->sign->updateSignAudit($signauditlist[$change]['satid'],'checking',0);
  179. if($result && $result2 && $result3){
  180. //删除上一个签名者的所有签名
  181. $signattlist = $this->sign->getSignAttList($this->params['sid']);
  182. foreach($signattlist as $key => $value){
  183. $sign2 = new SignAuditAtt();
  184. $sign2->audituid = $signauditlist[$change]['audituid'];
  185. $sign2->said = $value['said'];
  186. $sign2->delete();
  187. }
  188. // SMS Start
  189. $signArray = $this->sign->getOneSignbysid($this->params['sid']);
  190. $pmname = $this->actmeasure->getRowByPmid($signArray['tender']);
  191. $userProArray = $this->profile->getProWithUid($signauditlist[$change]['audituid']);
  192. if (isset($userProArray) && !empty($userProArray['mobile'])) {
  193. $sendarr1 = '“' .$pmname['pmname'].'”的“'. $signArray["name"] .'”';
  194. $sendarr2 = str_replace('【','',$sendarr1);
  195. $sendmsg = str_replace('】','',$sendarr2);
  196. $retval = $this->__auditNotice($userProArray['mobile'], Doo::conf()->SMS_TIPS_PRE . $sendmsg .Doo::conf()->SMS_TIPS["AUDIT_NOTICE_AUDITOR7"]);
  197. }
  198. // SMS End
  199. echo json_encode(array('code' => 200, 'url' => '/sign/onlist'));
  200. exit;
  201. }
  202. }
  203. echo json_encode(array('code' => 400, 'msg' => '退回签署失败'));
  204. exit;
  205. }
  206. }
  207. //获取报表信息
  208. $signmsg = $this->sign->getOneSignbysid($this->params['sid']);
  209. //获取项目名,标段名,标段期数
  210. $project = $this->project->getRowByPid($signmsg['project']);
  211. $tender = $this->actmeasure->getRowByPmid($signmsg['tender']);
  212. // $phaseno = $this->numofperact->getCurrStatus($signmsg['phaseno']);
  213. $signmsg['project'] = $project['pname'];
  214. $signmsg['tender'] = $tender['pmname'];
  215. // $signmsg['phaseno'] = $phaseno['numpname'];
  216. //获取签署人列表
  217. $firstsign = 0;
  218. $signauditlist = $this->sign->getSignAuditList($this->params['sid']);
  219. if(!empty($signauditlist)){
  220. foreach($signauditlist as $k => $v){
  221. //获取签署人头像
  222. $signauditlist[$k]['index'] = $k+1;
  223. $signauditlist[$k]['avatar'] = $this->auth->getAvatar($v['audituid']);
  224. if($this->auth->getUid() == $v['audituid'] && $k == 0){
  225. $firstsign = 1;
  226. }
  227. }
  228. }
  229. //获取报表图片
  230. $maxwidth = 794; //默认图片最大宽度 a4
  231. $maxheight = 1123; //默认图片最大高度 a4
  232. if(!empty($signmsg['widhei'])){
  233. $widhei = explode('_', $signmsg['widhei']);
  234. $style = $widhei[0].'mm '.$widhei[1].'mm';
  235. }else{
  236. $style = '210mm 297mm';
  237. }
  238. $signattlist = $this->sign->getSignAttList($this->params['sid']);
  239. if(!empty($signattlist)){
  240. foreach($signattlist as $sak => $sav){
  241. $signattlist[$sak]['auditatt'] = $this->sign->getSignAuditAttList($sav['said']);
  242. if($sak == 0){
  243. $imgmsg = getimagesize(Doo::conf()->APP_URL.$sav['filepath']);
  244. $maxwidth = $imgmsg[0];
  245. $maxheight = $imgmsg[1];
  246. }
  247. }
  248. }
  249. $this->data['signmsg'] = $signmsg;
  250. $this->data['auditlist'] = $signauditlist;
  251. $this->data['attlist'] = $signattlist;
  252. $this->data['picpath'] = $this->auth->getSignpath($this->auth->getUid());
  253. $this->data['signsid'] = $this->params['sid'];
  254. $this->data['maxwidth'] = $maxwidth;
  255. $this->data['maxheight'] = $maxheight;
  256. $this->data['style'] = $style;
  257. $this->data['firstsign'] = $firstsign;
  258. $this->render('sign-view-signer_sign',$this->data, TRUE);
  259. }
  260. public function signDone(){
  261. if(!isset($_POST['sid']) || !is_numeric($_POST['sid'])){
  262. echo json_encode(array('code' => 400, 'msg' => '没有报表参数'));
  263. exit;
  264. }
  265. if(!isset($_POST['path']) || empty($_POST['path'])){
  266. echo json_encode(array('code' => 400, 'msg' => '没有签名图片'));
  267. exit;
  268. }
  269. //改变签署状态并判断报表是否签署完成或传到下一个签署人签署
  270. $signAudit = $this->sign->getOneSignAudit($_POST['sid'],$this->auth->getUid());
  271. $result = $this->sign->updateSignAudit($signAudit['satid'],'checked');
  272. foreach($_POST['said'] as $satk => $satv){
  273. $sign3 = new Signn();
  274. $sign3->insertSignAuditAtt($this->auth->getUid(),$satv,$_POST['path'],$_POST['position'][$satk]);
  275. }
  276. if($result){
  277. $sign2 = new Signn();
  278. $signAuditList = $sign2->getSignAuditList($_POST['sid']);
  279. $flag = true;
  280. foreach($signAuditList as $k => $v){
  281. if($v['status'] == 'uncheck'){
  282. $sign2->updateSignAudit($v['satid'],'checking');
  283. $flag = false;
  284. //发送签署短信
  285. // SMS Start
  286. $signArray = $this->sign->getOneSignbysid($_POST['sid']);
  287. $pmname = $this->actmeasure->getRowByPmid($signArray['tender']);
  288. $userProArray = $this->profile->getProWithUid($v['audituid']);
  289. if (isset($userProArray) && !empty($userProArray['mobile'])) {
  290. $sendarr1 = '“' .$pmname['pmname'].'”的“'. $signArray["name"] .'”';
  291. $sendarr2 = str_replace('【','',$sendarr1);
  292. $sendmsg = str_replace('】','',$sendarr2);
  293. $retval = $this->__auditNotice($userProArray['mobile'], Doo::conf()->SMS_TIPS_PRE . $sendmsg .Doo::conf()->SMS_TIPS["AUDIT_NOTICE_AUDITOR5"]);
  294. }
  295. // SMS End
  296. break;
  297. }
  298. }
  299. if($flag){
  300. $this->sign->updateSignStatus($_POST['sid']);
  301. echo json_encode(array('code' => 200, 'url' => '/sign/view/'.$_POST['sid'].'?status=done'));
  302. exit;
  303. }else{
  304. $this->sign->updateSignStatusAndTime($_POST['sid'],'checking',0);
  305. echo json_encode(array('code' => 200, 'url' => '/sign/view/'.$_POST['sid'].'?status=doing'));
  306. exit;
  307. }
  308. }else{
  309. echo json_encode(array('code' => 400, 'msg' => '签署失败'));
  310. exit;
  311. }
  312. }
  313. public function signMyList(){
  314. Doo::loadHelper('DooPager');
  315. $pagestr = '';
  316. $sqlstr = ' 1';
  317. $this->data['project'] = '';
  318. $this->data['tender'] = '';
  319. $this->data['phaseno'] = '';
  320. //获取项目信息
  321. $searchsql = 'audituid='.$this->auth->getUid();
  322. $itemlist = $this->sign->getSignGroupByProject($searchsql);
  323. if(!empty($itemlist)){
  324. foreach($itemlist as $ik => $iv){
  325. $itemmsg = $this->project->getRowByPid($iv['project']);
  326. $itemlist[$ik]['pname'] = $itemmsg['pname'];
  327. }
  328. }
  329. if(isset($this->params['pid']) && is_numeric($this->params['pid'])){
  330. $this->data['project'] = $this->params['pid'];
  331. $pagestr .= '/project/'.$this->params['pid'];
  332. $sqlstr .= ' and project='.$this->params['pid'];
  333. //获取标段信息
  334. $tenderlist = $this->sign->getSignGroupByTender($this->params['pid'],$searchsql);
  335. if(!empty($tenderlist)){
  336. foreach($tenderlist as $tk => $tv){
  337. $tendermsg = $this->actmeasure->getRowByPmid($tv['tender']);
  338. $tenderlist[$tk]['pmname'] = $tendermsg['pmname'];
  339. }
  340. }
  341. if(isset($this->params['pmid']) && is_numeric($this->params['pmid'])){
  342. $this->data['tender'] = $this->params['pmid'];
  343. $pagestr .= '/tender/'.$this->params['pmid'];
  344. $sqlstr .= ' and tender='.$this->params['pmid'];
  345. //获取期数信息
  346. $phasenolist = $this->sign->getSignGroupByPhaseno($this->params['pmid'],$searchsql);
  347. if(!empty($phasenolist)){
  348. foreach($phasenolist as $pk => $pv){
  349. // $phasenomsg = $this->numofperact->getCurrStatus($pv['phaseno']);
  350. $phasenolist[$pk]['numpname'] = $pv['phaseno'];
  351. }
  352. }
  353. if(isset($this->params['mpid']) && is_numeric($this->params['mpid'])){
  354. $this->data['phaseno'] = $this->params['mpid'];
  355. $pagestr .= '/phaseno/'.$this->params['mpid'];
  356. $sqlstr .= ' and phaseno='.$this->params['mpid'];
  357. }
  358. }
  359. }
  360. $totalArchive = $this->sign->getMySignNumbyUid($this->auth->getUid(),$sqlstr);
  361. $pager = new DooPager(Doo::conf()->APP_URL . 'sign/mylist'.$pagestr.'/page', $totalArchive, 10, 100);
  362. $pager->setCss('', 'disabled', 'active');
  363. if (isset($this->params['pindex']))
  364. $pager->paginate(intval($this->params['pindex']));
  365. else
  366. $pager->paginate(1);
  367. if ($pager->limit != ' -10,10')
  368. $mylist = $this->sign->getMySignListbyUid($this->auth->getUid(), $sqlstr, $pager->limit);
  369. if(isset($mylist) && !empty($mylist)){
  370. foreach($mylist as $k => $v){
  371. //获取项目名,标段名,标段期数
  372. $project = $this->project->getRowByPid($v['project']);
  373. $tender = $this->actmeasure->getRowByPmid($v['tender']);
  374. // $phaseno = $this->numofperact->getCurrStatus($v['phaseno']);
  375. $mylist[$k]['project'] = $project['pname'];
  376. $mylist[$k]['tender'] = $tender['pmname'];
  377. // $mylist[$k]['phaseno'] = $phaseno['numpname'];
  378. }
  379. }
  380. $this->data['mylist'] = isset($mylist) ? $mylist : '';
  381. $this->data['itemlist'] = $itemlist;
  382. $this->data['tenderlist'] = isset($tenderlist) ? $tenderlist : '';
  383. $this->data['phasenolist'] = isset($phasenolist) ? $phasenolist : '';
  384. $this->data['pager'] = $pager->output;
  385. $this->render('sign-list-my_create',$this->data, TRUE);
  386. }
  387. public function signChangeShare(){
  388. if(!isset($_GET['status']) || !isset($_GET['sid'])){
  389. echo json_encode(array('code' => '400', 'msg' => '请传递正确的参数'));
  390. exit;
  391. }
  392. $status = $_GET['status'] == "true" ? 1 : 0;
  393. $result = $this->sign->updateSignShareStatus($status,$_GET['sid']);
  394. if($result){
  395. echo json_encode(array('code' => '200', 'status' => $status));
  396. exit;
  397. }else{
  398. echo json_encode(array('code' => '400', 'msg' => '无法分享'));
  399. exit;
  400. }
  401. exit;
  402. }
  403. public function signOnList(){
  404. Doo::loadHelper('DooPager');
  405. $pagestr = '';
  406. $sqlstr = ' 1';
  407. $this->data['project'] = '';
  408. $this->data['tender'] = '';
  409. $this->data['phaseno'] = '';
  410. //获取项目信息
  411. $searchsql = '(status="checking" or status="back") and sid in(select `jl_sign_audit`.sid from `jl_sign_audit` where `jl_sign_audit`.audituid='.$this->auth->getUid().')';
  412. $itemlist = $this->sign->getSignGroupByProject($searchsql);
  413. if(!empty($itemlist)){
  414. foreach($itemlist as $ik => $iv){
  415. $itemmsg = $this->project->getRowByPid($iv['project']);
  416. $itemlist[$ik]['pname'] = $itemmsg['pname'];
  417. }
  418. }
  419. if(isset($this->params['pid']) && is_numeric($this->params['pid'])){
  420. $this->data['project'] = $this->params['pid'];
  421. $pagestr .= '/project/'.$this->params['pid'];
  422. $sqlstr .= ' and project='.$this->params['pid'];
  423. //获取标段信息
  424. $tenderlist = $this->sign->getSignGroupByTender($this->params['pid'],$searchsql);
  425. if(!empty($tenderlist)){
  426. foreach($tenderlist as $tk => $tv){
  427. $tendermsg = $this->actmeasure->getRowByPmid($tv['tender']);
  428. $tenderlist[$tk]['pmname'] = $tendermsg['pmname'];
  429. }
  430. }
  431. if(isset($this->params['pmid']) && is_numeric($this->params['pmid'])){
  432. $this->data['tender'] = $this->params['pmid'];
  433. $pagestr .= '/tender/'.$this->params['pmid'];
  434. $sqlstr .= ' and tender='.$this->params['pmid'];
  435. //获取期数信息
  436. $phasenolist = $this->sign->getSignGroupByPhaseno($this->params['pmid'],$searchsql);
  437. if(!empty($phasenolist)){
  438. foreach($phasenolist as $pk => $pv){
  439. // $phasenomsg = $this->numofperact->getCurrStatus($pv['phaseno']);
  440. $phasenolist[$pk]['numpname'] = $pv['phaseno'];
  441. }
  442. }
  443. if(isset($this->params['mpid']) && is_numeric($this->params['mpid'])){
  444. $this->data['phaseno'] = $this->params['mpid'];
  445. $pagestr .= '/phaseno/'.$this->params['mpid'];
  446. $sqlstr .= ' and phaseno='.$this->params['mpid'];
  447. }
  448. }
  449. }
  450. $totalArchive = $this->sign->getDoingSignNumbyUid($this->auth->getUid(),$sqlstr);
  451. $pager = new DooPager(Doo::conf()->APP_URL . 'sign/onlist'.$pagestr.'/page', $totalArchive, 10, 100);
  452. $pager->setCss('', 'disabled', 'active');
  453. if (isset($this->params['pindex']))
  454. $pager->paginate(intval($this->params['pindex']));
  455. else
  456. $pager->paginate(1);
  457. if ($pager->limit != ' -10,10')
  458. $onlist = $this->sign->getDoingSignListbyUid($this->auth->getUid(), $sqlstr, $pager->limit);
  459. if(isset($onlist) && !empty($onlist)){
  460. foreach($onlist as $k => $v){
  461. //获取项目名,标段名,标段期数
  462. $project = $this->project->getRowByPid($v['project']);
  463. $tender = $this->actmeasure->getRowByPmid($v['tender']);
  464. // $phaseno = $this->numofperact->getCurrStatus($v['phaseno']);
  465. $onlist[$k]['project'] = $project['pname'];
  466. $onlist[$k]['tender'] = $tender['pmname'];
  467. // $onlist[$k]['phaseno'] = $phaseno['numpname'];
  468. $onlist[$k]['auditlist'] = $this->sign->getSignAuditList($v['sid']);
  469. }
  470. }
  471. $this->data['onlist'] = isset($onlist) ? $onlist : '';
  472. $this->data['itemlist'] = $itemlist;
  473. $this->data['tenderlist'] = isset($tenderlist) ? $tenderlist : '';
  474. $this->data['phasenolist'] = isset($phasenolist) ? $phasenolist : '';
  475. $this->data['pager'] = $pager->output;
  476. $this->render('sign-list-on_sign',$this->data, TRUE);
  477. }
  478. public function signDoneList(){
  479. Doo::loadHelper('DooPager');
  480. $pagestr = '';
  481. $sqlstr = ' 1';
  482. $this->data['project'] = '';
  483. $this->data['tender'] = '';
  484. $this->data['phaseno'] = '';
  485. //获取项目信息
  486. $searchsql = 'status="checked" and sid in(select `jl_sign_audit`.sid from `jl_sign_audit` where `jl_sign_audit`.audituid='.$this->auth->getUid().')';
  487. $itemlist = $this->sign->getSignGroupByProject($searchsql);
  488. if(!empty($itemlist)){
  489. foreach($itemlist as $ik => $iv){
  490. $itemmsg = $this->project->getRowByPid($iv['project']);
  491. $itemlist[$ik]['pname'] = $itemmsg['pname'];
  492. }
  493. }
  494. if(isset($this->params['pid']) && is_numeric($this->params['pid'])){
  495. $this->data['project'] = $this->params['pid'];
  496. $pagestr .= '/project/'.$this->params['pid'];
  497. $sqlstr .= ' and project='.$this->params['pid'];
  498. //获取标段信息
  499. $tenderlist = $this->sign->getSignGroupByTender($this->params['pid'],$searchsql);
  500. if(!empty($tenderlist)){
  501. foreach($tenderlist as $tk => $tv){
  502. $tendermsg = $this->actmeasure->getRowByPmid($tv['tender']);
  503. $tenderlist[$tk]['pmname'] = $tendermsg['pmname'];
  504. }
  505. }
  506. if(isset($this->params['pmid']) && is_numeric($this->params['pmid'])){
  507. $this->data['tender'] = $this->params['pmid'];
  508. $pagestr .= '/tender/'.$this->params['pmid'];
  509. $sqlstr .= ' and tender='.$this->params['pmid'];
  510. //获取期数信息
  511. $phasenolist = $this->sign->getSignGroupByPhaseno($this->params['pmid'],$searchsql);
  512. if(!empty($phasenolist)){
  513. foreach($phasenolist as $pk => $pv){
  514. // $phasenomsg = $this->numofperact->getCurrStatus($pv['phaseno']);
  515. $phasenolist[$pk]['numpname'] = $pv['phaseno'];
  516. }
  517. }
  518. if(isset($this->params['mpid']) && is_numeric($this->params['mpid'])){
  519. $this->data['phaseno'] = $this->params['mpid'];
  520. $pagestr .= '/phaseno/'.$this->params['mpid'];
  521. $sqlstr .= ' and phaseno='.$this->params['mpid'];
  522. }
  523. }
  524. }
  525. $totalArchive = $this->sign->getDoneSignNumbyUid($this->auth->getUid(),$sqlstr);
  526. $pager = new DooPager(Doo::conf()->APP_URL . 'sign/donelist'.$pagestr.'/page', $totalArchive, 10, 100);
  527. $pager->setCss('', 'disabled', 'active');
  528. if (isset($this->params['pindex']))
  529. $pager->paginate(intval($this->params['pindex']));
  530. else
  531. $pager->paginate(1);
  532. if ($pager->limit != ' -10,10')
  533. $donelist = $this->sign->getDoneSignListbyUid($this->auth->getUid(), $sqlstr, $pager->limit);
  534. if(isset($donelist) && !empty($donelist)){
  535. foreach($donelist as $k => $v){
  536. //获取项目名,标段名,标段期数
  537. $project = $this->project->getRowByPid($v['project']);
  538. $tender = $this->actmeasure->getRowByPmid($v['tender']);
  539. // $phaseno = $this->numofperact->getCurrStatus($v['phaseno']);
  540. $donelist[$k]['project'] = $project['pname'];
  541. $donelist[$k]['tender'] = $tender['pmname'];
  542. // $donelist[$k]['phaseno'] = $phaseno['numpname'];
  543. }
  544. }
  545. $this->data['donelist'] = isset($donelist) ? $donelist : '';
  546. $this->data['itemlist'] = $itemlist;
  547. $this->data['tenderlist'] = isset($tenderlist) ? $tenderlist : '';
  548. $this->data['phasenolist'] = isset($phasenolist) ? $phasenolist : '';
  549. $this->data['pager'] = $pager->output;
  550. $this->render('sign-list-done_sign',$this->data, TRUE);
  551. }
  552. /**
  553. *
  554. * @return type
  555. */
  556. public function signCreate()
  557. {
  558. $launchsignSwitch = $this->aconfig->getOne(array('select' => 'launchsignswitch', 'asArray' => TRUE))['launchsignswitch'];
  559. if($launchsignSwitch == 0)
  560. exit('未开启发起签署功能');
  561. Doo::loadHelper('DooPager');
  562. $pagestr = '';
  563. $sqlstr = ' 1';
  564. $this->data['project'] = '';
  565. $this->data['tender'] = '';
  566. $this->data['phaseno'] = '';
  567. //获取项目信息
  568. $searchsql = 'status="uncheck" AND (`isinter`=0 OR `isinter`=3) AND (`ownuid`='.$this->auth->getUid().' OR tender IN (SELECT pmid FROM jl_measure_audit WHERE auditoruid='.$this->auth->getUid().') OR project IN (SELECT pid FROM jl_project_measure WHERE uid='.$this->auth->getUid().'))';
  569. $itemlist = $this->sign->getSignGroupByProject($searchsql);
  570. if(!empty($itemlist)){
  571. foreach($itemlist as $ik => $iv){
  572. $itemmsg = $this->project->getRowByPid($iv['project']);
  573. $itemlist[$ik]['pname'] = $itemmsg['pname'];
  574. }
  575. }
  576. if(isset($this->params['pid']) && is_numeric($this->params['pid'])){
  577. $this->data['project'] = $this->params['pid'];
  578. $pagestr .= '/project/'.$this->params['pid'];
  579. $sqlstr .= ' and project='.$this->params['pid'];
  580. //获取标段信息
  581. $tenderlist = $this->sign->getSignGroupByTender($this->params['pid'], $searchsql);
  582. if(!empty($tenderlist)){
  583. foreach($tenderlist as $tk => $tv){
  584. $tendermsg = $this->actmeasure->getRowByPmid($tv['tender']);
  585. $tenderlist[$tk]['pmname'] = $tendermsg['pmname'];
  586. }
  587. }
  588. if(isset($this->params['pmid']) && is_numeric($this->params['pmid'])){
  589. $this->data['tender'] = $this->params['pmid'];
  590. $pagestr .= '/tender/'.$this->params['pmid'];
  591. $sqlstr .= ' and tender='.$this->params['pmid'];
  592. //获取期数信息
  593. $phasenolist = $this->sign->getSignGroupByPhaseno($this->params['pmid'], $searchsql);
  594. if(!empty($phasenolist)){
  595. foreach($phasenolist as $pk => $pv){
  596. // $phasenomsg = $this->numofperact->getCurrStatus($pv['phaseno']);
  597. $phasenolist[$pk]['numpname'] = $pv['phaseno'];
  598. }
  599. }
  600. if(isset($this->params['mpid']) && is_numeric($this->params['mpid'])){
  601. $this->data['phaseno'] = $this->params['mpid'];
  602. $pagestr .= '/phaseno/'.$this->params['mpid'];
  603. $sqlstr .= ' and phaseno='.$this->params['mpid'];
  604. }
  605. }
  606. }
  607. $totalArchive = $this->sign->getUnSignNum($sqlstr,$this->auth->getUid());
  608. $pager = new DooPager(Doo::conf()->APP_URL . 'sign/create'.$pagestr.'/page', $totalArchive, 10, 100);
  609. $pager->setCss('', 'disabled', 'active');
  610. if (isset($this->params['pindex']))
  611. $pager->paginate(intval($this->params['pindex']));
  612. else
  613. $pager->paginate(1);
  614. if ($pager->limit != ' -10,10')
  615. $unlist = $this->sign->getUnSignList($sqlstr, $this->auth->getUid(), $pager->limit);
  616. if(isset($unlist) && !empty($unlist)){
  617. foreach($unlist as $k => $v){
  618. //获取项目名,标段名,标段期数
  619. $project = $this->project->getRowByPid($v['project']);
  620. $tender = $this->actmeasure->getRowByPmid($v['tender']);
  621. // $phaseno = $this->numofperact->getCurrStatus($v['phaseno']);
  622. $unlist[$k]['project'] = $project['pname'];
  623. $unlist[$k]['tender'] = $tender['pmname'];
  624. // $unlist[$k]['phaseno'] = $phaseno['numpname'];
  625. $unlist[$k]['ownname'] = $this->auth->getName($v['ownuid']);
  626. }
  627. }
  628. $this->data['unlist'] = isset($unlist) ? $unlist : '';
  629. $this->data['itemlist'] = $itemlist;
  630. $this->data['tenderlist'] = isset($tenderlist) ? $tenderlist : '';
  631. $this->data['phasenolist'] = isset($phasenolist) ? $phasenolist : '';
  632. $this->data['pager'] = $pager->output;
  633. $this->render('sign-create_sign', $this->data, TRUE);
  634. }
  635. /**
  636. *
  637. * @return type
  638. */
  639. public function signList()
  640. {
  641. if(isset($_POST['delid']) && is_numeric($_POST['delid'])){
  642. //删除未签署报表数据和文件
  643. $signmsg = $this->sign->getOneSignbysid($_POST['delid']);
  644. if(empty($signmsg) && $signmsg['status'] == "checked" && $signmsg['ownuid'] != $this->auth->getUid()){
  645. exit(json_encode(array('code' => 400),JSON_UNESCAPED_UNICODE));
  646. }
  647. $this->sign->delSignbysid($_POST['delid'],$signmsg['status']);
  648. include (DOO::conf()->SITE_PATH . 'protected/plugin/io.han.php');
  649. $this->IoHandler = new IoHandler();
  650. $path = DOO::conf()->SITE_PATH."signs/".$_POST['delid'];
  651. $this->IoHandler->RemoveDir($path);
  652. exit(json_encode(array('code' => 200),JSON_UNESCAPED_UNICODE));
  653. }
  654. Doo::loadHelper('DooPager');
  655. $pagestr = '';
  656. $sqlstr = ' 1';
  657. $this->data['project'] = '';
  658. $this->data['tender'] = '';
  659. $this->data['phaseno'] = '';
  660. $this->data['nosign'] = '';
  661. //获取项目信息
  662. $searchsql = '(`isinter`=0 OR `isinter`=3) AND (`ownuid`='.$this->auth->getUid().' OR `audituid`='.$this->auth->getUid().' OR sid IN (SELECT sid FROM jl_sign_audit WHERE jl_sign_audit.audituid='.$this->auth->getUid().'))';
  663. $itemlist = $this->sign->getSignGroupByProject($searchsql);
  664. if(!empty($itemlist)){
  665. foreach($itemlist as $ik => $iv){
  666. $itemmsg = $this->project->getRowByPid($iv['project']);
  667. $itemlist[$ik]['pname'] = $itemmsg['pname'];
  668. }
  669. }
  670. if(isset($this->params['pid']) && is_numeric($this->params['pid'])){
  671. $this->data['project'] = $this->params['pid'];
  672. $pagestr .= '/project/'.$this->params['pid'];
  673. $sqlstr .= ' and project='.$this->params['pid'];
  674. //获取标段信息
  675. $tenderlist = $this->sign->getSignGroupByTender($this->params['pid'],$searchsql);
  676. if(!empty($tenderlist)){
  677. foreach($tenderlist as $tk => $tv){
  678. $tendermsg = $this->actmeasure->getRowByPmid($tv['tender']);
  679. $tenderlist[$tk]['pmname'] = $tendermsg['pmname'];
  680. }
  681. }
  682. if(isset($this->params['pmid']) && is_numeric($this->params['pmid'])){
  683. $this->data['tender'] = $this->params['pmid'];
  684. $pagestr .= '/tender/'.$this->params['pmid'];
  685. $sqlstr .= ' and tender='.$this->params['pmid'];
  686. //获取期数信息
  687. $phasenolist = $this->sign->getSignGroupByPhaseno($this->params['pmid'],$searchsql);
  688. if(!empty($phasenolist)){
  689. foreach($phasenolist as $pk => $pv){
  690. // $phasenomsg = $this->numofperact->getCurrStatus($pv['phaseno']);
  691. $phasenolist[$pk]['numpname'] = $pv['phaseno'];
  692. }
  693. }
  694. if(isset($this->params['mpid']) && is_numeric($this->params['mpid'])){
  695. $this->data['phaseno'] = $this->params['mpid'];
  696. $pagestr .= '/phaseno/'.$this->params['mpid'];
  697. $sqlstr .= ' and phaseno='.$this->params['mpid'];
  698. }
  699. }
  700. }
  701. if((isset($this->params['nosign']) && ($this->params['nosign'] == 'nosign')) || isset($_GET['nosign'])){
  702. $this->data['nosign'] = 1;
  703. $pagestr .= '/nosign';
  704. $searchsql = '(`isinter`=0 OR `isinter`=3) AND (`ownuid`='.$this->auth->getUid().' AND `status`="uncheck")';
  705. }
  706. $totalArchive = $this->sign->getSignNum($sqlstr.' and '.$searchsql);
  707. $pager = new DooPager(Doo::conf()->APP_URL . 'sign/list'.$pagestr.'/page', $totalArchive, 10, 100);
  708. $pager->setCss('', 'disabled', 'active');
  709. if (isset($this->params['pindex']))
  710. $pager->paginate(intval($this->params['pindex']));
  711. else
  712. $pager->paginate(1);
  713. if ($pager->limit != ' -10,10')
  714. $list = $this->sign->getSignList($sqlstr.' and '.$searchsql,$pager->limit);
  715. if(isset($list) && !empty($list)){
  716. foreach($list as $k => $v){
  717. //获取项目名,标段名,标段期数
  718. $project = $this->project->getRowByPid($v['project']);
  719. $tender = $this->actmeasure->getRowByPmid($v['tender']);
  720. // $phaseno = $this->numofperact->getCurrStatus($v['phaseno']);
  721. $list[$k]['project'] = $project['pname'];
  722. $list[$k]['tender'] = $tender['pmname'];
  723. // $list[$k]['phaseno'] = $phaseno['numpname'];
  724. $list[$k]['ownname'] = $this->auth->getName($v['ownuid']);
  725. $list[$k]['auditname'] = $this->auth->getName($v['audituid']);
  726. $list[$k]['delstatus'] = $this->auth->getUid() == $v['ownuid'] && $v['status'] != 'checked' && $v['isinter'] != 3 ? 1 : 0;
  727. }
  728. }
  729. $this->data['list'] = isset($list) ? $list : '';
  730. $this->data['itemlist'] = $itemlist;
  731. $this->data['tenderlist'] = isset($tenderlist) ? $tenderlist : '';
  732. $this->data['phasenolist'] = isset($phasenolist) ? $phasenolist : '';
  733. $this->data['pager'] = $pager->output;
  734. $this->render('sign-list-all', $this->data, TRUE);
  735. }
  736. /**
  737. *
  738. * @return type
  739. */
  740. public function signSignSet()
  741. {
  742. $launchsignSwitch = $this->aconfig->getOne(array('select' => 'launchsignswitch', 'asArray' => TRUE))['launchsignswitch'];
  743. if($launchsignSwitch == 0)
  744. exit('未开启发起签署功能');
  745. if(!isset($this->params['sid']) || !is_numeric($this->params['sid'])){
  746. exit('没有报表参数');
  747. }
  748. //获取报表信息
  749. $signmsg = $this->sign->getOneSignbysid($this->params['sid']);
  750. //获取标段审批人列表
  751. $auditactlist = $this->measureauditact->getUserAuditLast($signmsg['tender'],$signmsg['phaseno']);
  752. $userlist = array();
  753. if(!empty($auditactlist)){
  754. foreach($auditactlist as $k => $v){
  755. $usermsg = $this->auth->getRowByUid($v['auditoruid']);
  756. $userlist[$k]['userid'] = $usermsg['userid'];
  757. $userlist[$k]['name'] = $usermsg['name'];
  758. $userlist[$k]['jobs'] = $usermsg['jobs'];
  759. $userlist[$k]['avatar'] = $usermsg['avatar'];
  760. }
  761. }
  762. //获取原报人
  763. $measureArray = $this->actmeasure->getRowByPmid($signmsg['tender']);
  764. // $lastRowArray = $this->numofperact->getLastNew2($signmsg['tender']);
  765. $usermsg2 = $this->auth->getRowByUid($measureArray['uid']);
  766. $orginArray['userid'] = $measureArray['uid'];
  767. $orginArray['avatar'] = $usermsg2['avatar'];
  768. $orginArray['name'] = $usermsg2['name'];
  769. $orginArray['jobs'] = $usermsg2['jobs'];
  770. // $attfileArray = $this->attfile->getFirstFile($lastRowArray['pmid'], $lastRowArray['numpname'], $lastRowArray['times']);
  771. // $orginArray['time'] = date('Y-m-d', $attfileArray['intime']);
  772. //获取项目名,标段名,标段期数
  773. $project = $this->project->getRowByPid($signmsg['project']);
  774. $tender = $this->actmeasure->getRowByPmid($signmsg['tender']);
  775. // $phaseno = $this->numofperact->getCurrStatus($signmsg['phaseno']);
  776. $signmsg['project'] = $project['pname'];
  777. $signmsg['tender'] = $tender['pmname'];
  778. // $signmsg['phaseno'] = $phaseno['numpname'];
  779. //获取报表图片
  780. $maxwidth = 794; //默认图片最大宽度 a4
  781. $maxheight = 1123; //默认图片最大高度 a4
  782. if(!empty($signmsg['widhei'])){
  783. $widhei = explode('_', $signmsg['widhei']);
  784. $style = $widhei[0].'mm '.$widhei[1].'mm';
  785. }else{
  786. $style = '210mm 297mm';
  787. }
  788. $signattlist = $this->sign->getSignAttList($this->params['sid']);
  789. if(!empty($signattlist)){
  790. foreach($signattlist as $sak => $sav){
  791. if($sak == 0){
  792. $imgmsg = getimagesize(Doo::conf()->APP_URL.$sav['filepath']);
  793. $maxwidth = $imgmsg[0];
  794. $maxheight = $imgmsg[1];
  795. break;
  796. }
  797. }
  798. }
  799. $this->data['signmsg'] = $signmsg;
  800. $this->data['userlist'] = $userlist;
  801. $this->data['attlist'] = $signattlist;
  802. $this->data['reportlist'] = $orginArray;
  803. $this->data['maxwidth'] = $maxwidth;
  804. $this->data['maxheight'] = $maxheight;
  805. $this->data['style'] = $style;
  806. $this->render('sign-view-set_signer', $this->data, TRUE);
  807. }
  808. public function signSearchUser(){
  809. if(!isset($_GET['email']) || empty($_GET['email'])){
  810. echo json_encode(array('code' => 400, 'msg' => '请输入邮箱地址'));
  811. exit;
  812. }
  813. $usermsg = $this->auth->checkUserEmail($_GET['email']);
  814. if(!empty($usermsg)){
  815. echo json_encode(array('code' => 200, 'user' => $usermsg));
  816. exit;
  817. }else{
  818. echo json_encode(array('code' => 400, 'msg' => '没有此邮箱用户'));
  819. exit;
  820. }
  821. }
  822. public function signUpSigner(){
  823. if(!isset($_POST['ids']) || !isset($_POST['names']) || !isset($_POST['sid']) || !is_numeric($_POST['sid'])){
  824. echo json_encode(array('code' => 400, 'msg' => '上传参数有误'));
  825. exit;
  826. }
  827. $useridarr = $_POST['ids'];
  828. $usernamearr = $_POST['names'];
  829. foreach($useridarr as $k => $v){
  830. $signs = new Signn();
  831. $status = $k != 0 ? 'uncheck' : 'checking';
  832. $result = $signs->insertSignAudit($_POST['sid'],$status,$v,$usernamearr[$k]);
  833. if(empty($result)){
  834. echo json_encode(array('code' => 400, 'msg' => '添加签署人出错'));
  835. exit;
  836. }
  837. //发送签署短信
  838. if($k == 0){
  839. // SMS Start
  840. $signArray = $this->sign->getOneSignbysid($_POST['sid']);
  841. $pmname = $this->actmeasure->getRowByPmid($signArray['tender']);
  842. $userProArray = $this->profile->getProWithUid($v);
  843. if (isset($userProArray) && !empty($userProArray['mobile'])) {
  844. $sendarr1 = '“' .$pmname['pmname'].'”的“'. $signArray["name"] .'”';
  845. $sendarr2 = str_replace('【','',$sendarr1);
  846. $sendmsg = str_replace('】','',$sendarr2);
  847. $retval = $this->__auditNotice($userProArray['mobile'], Doo::conf()->SMS_TIPS_PRE . $sendmsg .Doo::conf()->SMS_TIPS["AUDIT_NOTICE_AUDITOR5"]);
  848. }
  849. // SMS End
  850. }
  851. }
  852. //更新报表信息
  853. $result2 = $this->sign->updateSignMsg($_POST['sid'],$this->auth->getUid());
  854. if(!empty($result2)){
  855. echo json_encode(array('code' => 200, 'msg' => '添加成功'));
  856. exit;
  857. }else{
  858. echo json_encode(array('code' => 400, 'msg' => '添加签署人出错'));
  859. exit;
  860. }
  861. }
  862. /**
  863. *
  864. * @return type
  865. */
  866. public function signView()
  867. {
  868. if(!isset($this->params['sid']) || !is_numeric($this->params['sid'])){
  869. exit('没有报表参数');
  870. }
  871. //获取报表信息
  872. $signmsg = $this->sign->getOneSignbysid($this->params['sid']);
  873. //获取项目名,标段名,标段期数
  874. $project = $this->project->getRowByPid($signmsg['project']);
  875. $tender = $this->actmeasure->getRowByPmid($signmsg['tender']);
  876. // $phaseno = $this->numofperact->getCurrStatus($signmsg['phaseno']);
  877. $signmsg['project'] = $project['pname'];
  878. $signmsg['tender'] = $tender['pmname'];
  879. // $signmsg['phaseno'] = $phaseno['numpname'];
  880. //获取签署人列表
  881. $signauditlist = $this->sign->getSignAuditList($this->params['sid']);
  882. if(!empty($signauditlist)){
  883. foreach($signauditlist as $k => $v){
  884. //获取签署人头像
  885. $signauditlist[$k]['index'] = $k+1;
  886. $signauditlist[$k]['avatar'] = $this->auth->getAvatar($v['audituid']);
  887. }
  888. }
  889. //获取报表图片
  890. $maxwidth = 794; //默认图片最大宽度 a4
  891. $maxheight = 1123; //默认图片最大高度 a4
  892. if(!empty($signmsg['widhei'])){
  893. $widhei = explode('_', $signmsg['widhei']);
  894. $style = $widhei[0].'mm '.$widhei[1].'mm';
  895. }else{
  896. $style = '210mm 297mm';
  897. }
  898. $signattlist = $this->sign->getSignAttList($this->params['sid']);
  899. if(!empty($signattlist)){
  900. foreach($signattlist as $sak => $sav){
  901. $signattlist[$sak]['auditatt'] = $this->sign->getSignAuditAttList($sav['said']);
  902. if($sak == 0){
  903. $imgmsg = getimagesize(Doo::conf()->APP_URL.$sav['filepath']);
  904. $maxwidth = $imgmsg[0];
  905. $maxheight = $imgmsg[1];
  906. }
  907. }
  908. }
  909. $backurl = '/sign/list';
  910. if(isset($_GET['status'])){
  911. switch($_GET['status']){
  912. case 'done' : $backurl = '/sign/donelist';break;
  913. case 'doing' : $backurl = '/sign/onlist';break;
  914. case 'mylist' : $backurl = '/sign/mylist';break;
  915. case 'onlist' : $backurl = '/sign/onlist';break;
  916. case 'donelist' : $backurl = '/sign/donelist';break;
  917. default: $backurl = '/sign/list';break;
  918. }
  919. }
  920. $this->data['signmsg'] = $signmsg;
  921. $this->data['auditlist'] = $signauditlist;
  922. $this->data['attlist'] = $signattlist;
  923. $this->data['backurl'] = $backurl;
  924. $this->data['maxwidth'] = $maxwidth;
  925. $this->data['maxheight'] = $maxheight;
  926. $this->data['style'] = $style;
  927. $this->render('sign-view-page', $this->data, TRUE);
  928. }
  929. public function substr_replace_cn($string, $repalce = '*', $start = 0, $len = 0)
  930. {
  931. $count = mb_strlen($string, 'UTF-8'); //此处传入编码,建议使用utf-8。此处编码要与下面mb_substr()所使用的一致
  932. if (!$count) {
  933. return $string;
  934. }
  935. if ($len == 0) {
  936. $end = $count; //传入0则替换到最后
  937. } else {
  938. $end = $start + $len; //传入指定长度则为开始长度+指定长度
  939. }
  940. $i = 0;
  941. $returnString = '';
  942. while ($i < $count) { //循环该字符串
  943. $tmpString = mb_substr($string, $i, 1, 'UTF-8'); // 与mb_strlen编码一致
  944. if ($start <= $i && $i < $end) {
  945. $returnString .= $repalce;
  946. } else {
  947. $returnString .= $tmpString;
  948. }
  949. $i++;
  950. }
  951. return $returnString;
  952. }
  953. function unicode_encode($name)
  954. {//to Unicode
  955. $name = iconv('UTF-8', 'UCS-2', $name);
  956. $len = strlen($name);
  957. $str = '';
  958. for ($i = 0; $i < $len - 1; $i = $i + 2) {
  959. $c = $name[$i];
  960. $c2 = $name[$i + 1];
  961. if (ord($c) > 0) {// 两个字节的字
  962. $str .= '\\' . base_convert(ord($c), 10, 16) . base_convert(ord($c2), 10, 16);
  963. } else {
  964. $str .= $c2;
  965. }
  966. }
  967. $str = strtoupper($str);
  968. return $str;
  969. }
  970. function unicode_decode($name)
  971. {//Unicode to
  972. $pattern = '/([\w]+)|(\\\u([\w]{4}))/i';
  973. preg_match_all($pattern, $name, $matches);
  974. if (!empty($matches)) {
  975. $name = '';
  976. for ($j = 0; $j < count($matches[0]); $j++) {
  977. $str = $matches[0][$j];
  978. if (strpos($str, '\\u') === 0) {
  979. $code = base_convert(substr($str, 2, 2), 16, 10);
  980. $code2 = base_convert(substr($str, 4), 16, 10);
  981. $c = chr($code) . chr($code2);
  982. $c = iconv('UCS-2', 'UTF-8', $c);
  983. $name .= $c;
  984. } else {
  985. $name .= $str;
  986. }
  987. }
  988. }
  989. return $name;
  990. }
  991. private function __auditNotice($mobile, $text)
  992. {
  993. $smsSignSwitch = $this->aconfig->getOne(array('select' => 'smssignswitch', 'asArray' => TRUE))['smssignswitch'];
  994. if ($smsSignSwitch > 0)
  995. return $this->sms->sendSms($mobile, $text);
  996. }
  997. }
  998. ?>