SignController.php 49 KB

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