SignController.php 41 KB

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