SignController.php 39 KB

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