SignController.php 42 KB

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