ChangeController.php 95 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873
  1. <?php
  2. //ini_set('display_errors', on);
  3. Doo::loadClass('auth');
  4. Doo::loadClass('attfile');
  5. Doo::loadClass('profile');
  6. Doo::loadClass('project');
  7. Doo::loadClass('contractact');
  8. Doo::loadClass('actmeasure');
  9. Doo::loadClass('numofperact');
  10. Doo::loadClass('measureauditact');
  11. Doo::loadClass('sign');
  12. Doo::loadClass('sms');
  13. Doo::loadClass('change');
  14. Doo::loadModelAt('aconfig', 'admin');
  15. Doo::loadClass('Hashids/Hashids');
  16. /* * proDetail
  17. * MainController
  18. * Feel free to delete the methods and replace them with your own code.
  19. *
  20. * @author darkredz
  21. */
  22. class ChangeController extends DooController
  23. {
  24. private $aconfig, $data, $sms, $sign, $change, $auth, $attfile, $profile, $project, $contractact, $actmeasure, $measureauditact, $numofperact, $__hashids, $statusArray = array('uncheck' => '<span class = "colGray">未审批</span>', 'checking' => '<span class = "colOrange">审批中</span>', 'checked' => '<span class = "colGreen">审批通过</span>', 'checkno' => '<span class = "colRed">审批不通过</span>');
  25. private $changeType = array('2' => 'A.数量', '1' => 'B.位置', '3' => 'C.结构', '4' => 'D.新增', '5' => 'E.取消', '6' => 'F.纠错');
  26. private $changeCategory = array('1' => 'A类变更', '2' => 'B类变更', '3' => 'C类变更', '4' => 'D类变更', '5' => 'E类变更');
  27. private $changeNature = array('1' => '一般设计变更', '2' => '较大设计变更', '3' => '重大设计变更');
  28. private $changeStatus = array('2' => 'uncheck', '3' => 'checking', '4' => 'checked', '5' => 'checkno');
  29. private $changeUnit = array('m','km','m2','m3','kg','t','m3·km','总额','月','项','处','个','根','棵','块','每一试桩','桥长米','公路公里','株','组','座','元','工日','套','台班','艘班','m/处','m/道','m/座','m2/m','m3/m','m3/处','根/米','亩','m3/m2');
  30. public function beforeRun($resource, $action)
  31. {
  32. if(isset($_POST['sessionid'])){
  33. session_id($_POST['sessionid']);
  34. setcookie('PHPSESSID',$_POST['sessionid']);
  35. session_start();
  36. }
  37. if ($this->auth->getUid()) {
  38. $uGroups = $this->profile->getProWithUid($this->auth->getUid());
  39. $falg = Doo::acl()->isAllowed($uGroups['groups'], $resource, $action);
  40. if (!$falg)
  41. return Doo::acl()->defaultFailedRoute;
  42. } else {
  43. return Doo::acl()->defaultFailedRoute;
  44. }
  45. }
  46. public function __construct()
  47. {
  48. $this->aconfig = new AConfig();
  49. $this->auth = new Auth();
  50. $this->attfile = new attFile();
  51. $this->profile = new Profile();
  52. $this->project = new Project();
  53. $this->contractact = new Contractact();
  54. $this->actmeasure = new actMeasure();
  55. $this->numofperact = new NumofperAct();
  56. $this->measureauditact = new MeasureauditAct();
  57. $this->sign = new Signn();
  58. $this->change = new Changes();
  59. $this->sms = new Sms(Doo::conf()->SMS_URL, Doo::conf()->SMS_ACCOUNT, DOO::conf()->SMS_PASSWORD, DOO::conf()->SMS_EXTNO);
  60. $this->__hashids = new Hashids\Hashids('jlzffileid', 8);
  61. $this->data['rootUrl'] = Doo::conf()->APP_URL;
  62. $this->data['currChannle'] = 'change';
  63. $this->data['user'] = $this->profile->getProWithUid($this->auth->getUid());
  64. $mpidArray = $this->measureauditact->getAuditProject2($this->auth->getUid());
  65. $this->data['numofchecking'] = 0;
  66. if (isset($mpidArray[0]['pid'])) {
  67. foreach ($mpidArray as $key => $value) {
  68. // 审批操作按照时间排序多标段
  69. $this->data['numofchecking'] += $this->measureauditact->getCountMyChecking($value['pid'], $this->auth->getUid());
  70. }
  71. }
  72. if (!isset($this->data['numofchecking']) || $this->data['numofchecking'] == 0) {
  73. $this->data['numofchecking'] = null;
  74. }
  75. $this->data['signSwitch'] = $this->aconfig->getOne(array('select' => 'signswitch', 'asArray' => TRUE))['signswitch'];
  76. //获取需要您签署的数目
  77. if($this->data['signSwitch'] > 0)
  78. $this->data['needSignNum'] = $this->sign->getNeedSignNumbyUid($this->auth->getUid()) != 0 ? $this->sign->getNeedSignNumbyUid($this->auth->getUid()) : '';
  79. //获取桌面版本
  80. $this->getsoftware();
  81. //草图入口
  82. $this->data['imediateSwitch'] = $this->aconfig->getOne(array('select' => 'imediateswitch', 'asArray' => TRUE))['imediateswitch'];
  83. //获取需要你审批的变更令数目
  84. $this->data['needChangeNum'] = $this->change->getNeedChangeNumbyUid($this->auth->getUid()) != 0 ? $this->change->getNeedChangeNumbyUid($this->auth->getUid()) : '';
  85. }
  86. function getsoftware(){
  87. $StrJson = ($this->aconfig->getOne(array('select' => 'upgradeinfo', 'asArray' => TRUE))['upgradeinfo']);
  88. $upgradeinfo = json_decode($StrJson, true);
  89. if ($upgradeinfo) {
  90. $this->data['version'] = $upgradeinfo['version'];
  91. $this->data['download'] = $upgradeinfo['download'];
  92. }
  93. }
  94. /**
  95. *
  96. * @return type
  97. */
  98. public function index()
  99. {
  100. //获取 项目-标段类型-标段 的树结构, 包含个人对应的原报,审批和变更令审批人专属树结构
  101. $sectionlist = array();
  102. $hashArray = array();
  103. //先取原报人标段
  104. $mpidArray = $this->actmeasure->getRowUser($this->auth->getUid());
  105. if(!empty($mpidArray)){
  106. foreach($mpidArray as $k => $v){
  107. $sectionlist[] = array('pid' => $v['pid'], 'stid' => $v['stid'], 'pmid' => $v['pmid']);
  108. $hashArray[] = md5($v['pmid']);
  109. }
  110. }
  111. //再取审批表标段
  112. // $mpidArray2 = $this->measureauditact->getPmidGroup($this->auth->getUid());
  113. // if(!empty($mpidArray2)){
  114. // foreach($mpidArray2 as $k2 => $v2){
  115. // $hashstr = md5($v2['pmid']);
  116. // if(!in_array($hashstr,$hashArray)){
  117. // $sectionlist[] = array('pid' => $v2['pid'], 'stid' => $v2['stid'], 'pmid' => $v2['pmid']);
  118. // $hashArray[] = md5($v2['pmid']);
  119. // }
  120. // }
  121. // }
  122. //最后取变更令审批人所属的标段
  123. $mpidArray3 = $this->change->getPmidGroup($this->auth->getUid());
  124. if(!empty($mpidArray3)){
  125. foreach($mpidArray3 as $k3 => $v3){
  126. $hashstr = md5($v3['pmid']);
  127. if(!in_array($hashstr,$hashArray)){
  128. $sectionlist[] = array('pid' => $v3['pid'], 'stid' => $v3['stid'], 'pmid' => $v3['pmid']);
  129. $hashArray[] = md5($v3['pmid']);
  130. }
  131. }
  132. }
  133. //算法 ---> 把一个二维数组按内容转换成一个三维数组
  134. $prolist = array();
  135. $pmidlistArray = array();
  136. if(!empty($sectionlist)){
  137. $newlist = array();
  138. $i = 0;
  139. foreach($sectionlist as $key => $value){
  140. $j = 0;
  141. $newkey = $value['pid'];
  142. $newst = $value['stid'];
  143. $newpm = $value['pmid'];
  144. array_push($pmidlistArray,$newpm);
  145. if(!isset($newlist[$newkey])){
  146. $newlist[$newkey]['i'] = $i;
  147. $prolist[$i]['open'] = 0;
  148. $prolist[$i]['pid'] = $newkey;
  149. $prolist[$i]['pname'] = $this->project->getRowByPid($newkey)['pname'];
  150. $prolist[$i]['stlist'] = array();
  151. $newlist[$newkey]['st'][$newst]['j'] = $j;
  152. $newlist[$newkey]['stnum'] = $j;
  153. $prolist[$i]['stlist'][$j]['open'] = 0;
  154. $prolist[$i]['stlist'][$j]['stid'] = $newst;
  155. $prolist[$i]['stlist'][$j]['stname'] = $this->contractact->getRowByStid($newst)['stname'];
  156. $prolist[$i]['stlist'][$j]['pmlist'] = array();
  157. array_push($prolist[$i]['stlist'][$j]['pmlist'],array('open' => 0, 'pmid' => $newpm, 'pmname' => $this->actmeasure->getRowByPmid($newpm)['pmname']));
  158. $i++;
  159. }else{
  160. $i2 = $newlist[$newkey]['i'];
  161. if(!isset($newlist[$newkey]['st'][$newst])){
  162. $newlist[$newkey]['st'][$newst]['j'] = $newlist[$newkey]['stnum']+1;
  163. $j = $newlist[$newkey]['st'][$newst]['j'];
  164. $newlist[$newkey]['stnum']++;
  165. $prolist[$i2]['stlist'][$j]['stid'] = $newst;
  166. $prolist[$i2]['stlist'][$j]['stname'] = $this->contractact->getRowByStid($newst)['stname'];
  167. $prolist[$i2]['stlist'][$j]['pmlist'] = array();
  168. array_push($prolist[$i2]['stlist'][$j]['pmlist'],array('open' => 0, 'pmid' => $newpm, 'pmname' => $this->actmeasure->getRowByPmid($newpm)['pmname']));
  169. }else{
  170. $j2 = $newlist[$newkey]['st'][$newst]['j'];
  171. array_push($prolist[$i2]['stlist'][$j2]['pmlist'],array('open' => 0, 'pmid' => $newpm, 'pmname' => $this->actmeasure->getRowByPmid($newpm)['pmname']));
  172. }
  173. }
  174. }
  175. }
  176. //获取需要您审批的签署表cid,pid,stid,pmid信息,并默认open所有节点
  177. $cListmsg = $this->change->getNeedChangeNumbyUid($this->auth->getUid()) != 0 ? $this->change->getNeedChangeAllList($this->auth->getUid()) : '';
  178. $pidArray = $stidArray = $pmidArray = array();
  179. if(!empty($cListmsg)){
  180. foreach($cListmsg as $clk => $clv){
  181. array_push($pidArray,$clv['pid']);
  182. array_push($stidArray,$clv['stid']);
  183. array_push($pmidArray,$clv['pmid']);
  184. }
  185. }
  186. $sql = '';
  187. $pmid = isset($this->params['pmid']) ? $this->params['pmid'] : '';
  188. $userchangepower = 1;
  189. if(!empty($prolist)){
  190. foreach($prolist as $pk => $pv){
  191. if(in_array($pv['pid'], $pidArray)){
  192. $prolist[$pk]['open'] = 2;
  193. foreach($prolist[$pk]['stlist'] as $sk => $sv){
  194. if(in_array($sv['stid'], $stidArray)){
  195. $prolist[$pk]['stlist'][$sk]['open'] = 2;
  196. foreach($prolist[$pk]['stlist'][$sk]['pmlist'] as $mk => $mv){
  197. if(in_array($mv['pmid'], $pmidArray)){
  198. $prolist[$pk]['stlist'][$sk]['pmlist'][$mk]['open'] = 2;
  199. }
  200. }
  201. }
  202. }
  203. }
  204. }
  205. //存在标段则该标段加粗
  206. if(!empty($pmid)){
  207. $pmArray = $this->actmeasure->getRowByPmid($pmid);
  208. foreach($prolist as $pk => $pv){
  209. if($pmArray['pid'] == $pv['pid']){
  210. $prolist[$pk]['open'] = 1;
  211. foreach($prolist[$pk]['stlist'] as $sk => $sv){
  212. if($pmArray['stid'] == $sv['stid']){
  213. $prolist[$pk]['stlist'][$sk]['open'] = 1;
  214. foreach($prolist[$pk]['stlist'][$sk]['pmlist'] as $mk => $mv){
  215. if($pmArray['pmid'] == $mv['pmid']){
  216. $prolist[$pk]['stlist'][$sk]['pmlist'][$mk]['open'] = 1;
  217. break;
  218. }
  219. }
  220. break;
  221. }
  222. }
  223. break;
  224. }
  225. }
  226. $userchangepower = $this->auth->getUid() == $pmArray['uid'] ? 1 : 0;
  227. $this->data['pmArray'] = $pmArray;
  228. }else{
  229. $sql .= ' and pmid in ('.implode(',',$pmidlistArray).')';
  230. }
  231. }
  232. //只有原报人才可以创建变更令和上报变更令
  233. $this->data['userchangepower'] = $userchangepower;
  234. $changelist = $this->change->getChangeListbyPmid($pmid,' 1'.$sql);
  235. $this->data['firstuse'] = empty($changelist) ? 1 : 0;
  236. $status = isset($this->params['status']) && is_numeric($this->params['status']) ? $this->params['status'] : 1;
  237. $this->data['status'] = $status;
  238. $this->data['prolist'] = $prolist;
  239. $sql .= ' and cid in (SELECT `jl_change_audit`.cid FROM `jl_change_audit` WHERE `jl_change_audit`.uid='.$this->auth->getUid().' GROUP BY `jl_change_audit`.cid)';
  240. $this->data['num1'] = $this->change->getNumbyMydetail($pmid,$this->auth->getUid());
  241. $this->data['num2'] = $this->change->getNumbystatus($pmid,'uncheck','back',$sql);
  242. $this->data['num3'] = $this->change->getNumbystatus($pmid,'checking','',$sql);
  243. $this->data['num4'] = $this->change->getNumbystatus($pmid,'checked','',$sql);
  244. $this->data['num5'] = $this->change->getNumbystatus($pmid,'checkno','',$sql);
  245. //获取列表内容
  246. Doo::loadHelper('DooPager');
  247. $pagestr = !empty($pmid) ? '/tender/'.$pmid.'/status/'.$status : '/status/'.$status;
  248. $totalArchive = $status != 1 ? ($status ==2 ? $this->change->getNumbystatus($pmid,'uncheck','back',$sql) : $this->change->getNumbystatus($pmid,$this->changeStatus[$status],'',$sql)) : $this->change->getNumbyMydetail($pmid,$this->auth->getUid());
  249. $pager = new DooPager(Doo::conf()->APP_URL . 'change/index'.$pagestr.'/page', $totalArchive, 10, 100);
  250. $pager->setCss('', 'disabled', 'active');
  251. if (isset($this->params['pindex']))
  252. $pager->paginate(intval($this->params['pindex']));
  253. else
  254. $pager->paginate(1);
  255. if ($pager->limit != ' -10,10')
  256. $list = $status != 1 ? ($status ==2 ? $this->change->getListbyStatus($pmid,$this->changeStatus[$status], $pager->limit,'back',$sql) : $this->change->getListbyStatus($pmid,$this->changeStatus[$status], $pager->limit,'',$sql)) : $this->change->getListbyMydetail($pmid,$this->auth->getUid(), $pager->limit);
  257. if(isset($list) && !empty($list)){
  258. foreach($list as $lk => $lv){
  259. if($status == 3){
  260. $checkman = $this->change->getOneAuditbystatus($lv['cid'],'checking');
  261. $list[$lk]['checkman'] = $checkman['name'];
  262. // $list[$lk]['checkstatus'] = $this->statusArray[$checkman['status']];
  263. }
  264. $list[$lk]['pmname'] = $this->actmeasure->getRowByPmid($lv['pmid'])['pmname'];
  265. $list[$lk]['username'] = $this->auth->getRowByUid($lv['uid'])['name'];
  266. $list[$lk]['changeCategory'] = $this->changeCategory[$lv['category']];
  267. }
  268. }
  269. //uid
  270. $this->data['uid'] = $this->auth->getUid();
  271. $this->data['list'] = isset($list) ? $list : '';
  272. $this->data['pmid'] = $pmid;
  273. $this->data['pager'] = $pager->output;
  274. $this->render('biangeng-poj', $this->data, TRUE);
  275. }
  276. //签约清单
  277. public function dealBills(){
  278. if(isset($this->params['pmid']) && is_numeric($this->params['pmid'])){
  279. $pmid = $this->params['pmid'];
  280. $pmArray = $this->actmeasure->getRowByPmid($pmid);
  281. if(empty($pmArray)){
  282. exit('不存在此标段');
  283. }
  284. include (DOO::conf()->SITE_PATH . 'protected/plugin/TemplateTag.php');
  285. $this->data['pmArray'] = $pmArray;
  286. $list = $this->change->getChangeListbyPmid($pmid);
  287. if(!empty($list)){
  288. foreach($list as $k => $v){
  289. $totalamount = floatval($v['unitprice'])*floatval($v['amount']);
  290. $list[$k]['totalamount'] = todecimal($totalamount,2);
  291. }
  292. }
  293. $this->data['list'] = $list;
  294. $this->render('biangeng-dealbills', $this->data, TRUE);
  295. }else{
  296. exit('不存在此标段');
  297. }
  298. }
  299. public function changeDetail(){
  300. //获取变更令信息
  301. if(isset($this->params['cid']) && is_numeric($this->params['cid'])) {
  302. $cid = $this->params['cid'];
  303. $changeArray = $this->change->getChangebyid($cid);
  304. if(!empty($changeArray)){
  305. $pmArray = $this->actmeasure->getRowByPmid($changeArray['pmid']);
  306. if(empty($pmArray)){
  307. exit('不存在此标段');
  308. }
  309. include (DOO::conf()->SITE_PATH . 'protected/plugin/TemplateTag.php');
  310. $decimalnum = $this->getdecimal($changeArray['decimalnum']);
  311. if(isset($_POST['table']) && $_POST['table'] == '_all'){
  312. //获取所有清单列表数据,包括所有审批人
  313. //获取用户审批变更清单的列表
  314. $auditlist = $this->change->getChangeAuditbylastlist($cid,$changeArray['times']);
  315. //获取清单,按清单编号排序
  316. $clist = $this->change->getChangeAuditListbycid($cid);
  317. $ototalnum = 0;
  318. $ctotalnum = 0;
  319. $stotalnum = 0;
  320. $listtablehtml = '<table class="table table-striped table-bordered nowrap qd-table" id="tablelist" cellspacing="0" width="100%">
  321. <thead>
  322. <tr><th rowspan="2" class="text-center" width="100">清单编号</th><th rowspan="2" class="text-center">名称</th><th rowspan="2" class="text-center">单位</th><th rowspan="2" class="text-center">单价</th><th colspan="2" class="text-center">原设计</th><th colspan="2" class="text-center">申报变更增(+)减(-)</th>';
  323. $thhtml = '<th class="text-center">数量</th>
  324. <th class="text-center">金额</th>
  325. <th class="text-center">数量</th>
  326. <th class="text-center">金额</th>';
  327. $utotalarr = array();
  328. foreach ($auditlist as $ak => $av) {
  329. $listtablehtml .= '<th colspan="2" class="text-center">'.$av['name'].' 审批</th>';
  330. $thhtml .= '<th class="text-center">数量</th><th class="text-center">金额</th>';
  331. $utotalarr[$ak]['uid'] = $av['uid'];
  332. $utotalarr[$ak]['status'] = $av['status'];
  333. $utotalarr[$ak]['usum'] = 0;
  334. }
  335. $listtablehtml .= '</tr><tr>'. $thhtml .'</tr>
  336. </thead>
  337. <tbody id="list">';
  338. if (!empty($clist)) {
  339. foreach ($clist as $ck => $cv) {
  340. $osum = floatval($cv['unitprice']) * floatval($cv['oamount']);
  341. $osum = $cv['lid'] != 0 ? todecimal($osum,$decimalnum['costdnum']) : $osum;
  342. $clist[$ck]['osum'] = $osum;
  343. $ototalnum += $osum;
  344. $csum = todecimal(floatval($cv['unitprice']) * floatval($cv['camount']),$decimalnum['costdnum']);
  345. $clist[$ck]['csum'] = $csum;
  346. $ctotalnum += $csum;
  347. $listtablehtml .= '<tr class="clist"><td>' . $cv['lnum'] . '</td><td>' . $cv['lname'] . '</td><td>' . $cv['unit'] . '</td><td>' . tofloat($cv['unitprice']) . '</td><td>' . $cv['oamount'] . '</td><td>' . $osum . '</td><td>' . $cv['camount'] . '</td><td>' . $csum . '</td>';
  348. $userjson = json_decode($cv['auditjson'], true);
  349. $tdhtml = '';
  350. foreach ($userjson as $uk => $uv) {
  351. if($uv['ucamount'] != ''){
  352. //update utotalarr value=>usum
  353. foreach($utotalarr as $tk => $tv){
  354. if($tv['uid'] == $uv['uid'] && $tv['status'] == 'checked'){
  355. $usum = todecimal(floatval($cv['unitprice'])*floatval($uv['ucamount']),$decimalnum['costdnum']);
  356. $tdhtml .= '<td>'.$uv['ucamount'].'</td><td>'.$usum.'</td>';
  357. $utotalarr[$tk]['usum'] = todecimal(floatval($utotalarr[$tk]['usum'])+$usum,$decimalnum['costdnum']);
  358. break;
  359. }elseif($tv['uid'] == $uv['uid']){
  360. $tdhtml .= '<td></td><td></td>';
  361. break;
  362. }
  363. }
  364. }else{
  365. $tdhtml .= '<td></td><td></td>';
  366. }
  367. }
  368. $listtablehtml = $listtablehtml.$tdhtml.'</tr>';
  369. }
  370. }
  371. $listtablehtml .= '</tbody><tfoot><tr class="info"><td>合计</td><td></td><td></td><td></td><td></td><td>'.$ototalnum.'</td><td></td><td>'.todecimal($ctotalnum,$decimalnum['costdnum']).'</td>';
  372. foreach($utotalarr as $tk => $tv){
  373. $addtd = $tv['usum'] != 0 ? todecimal($tv['usum'],$decimalnum['costdnum']) : '';
  374. $listtablehtml .= '<td></td><td>'.$addtd.'</td>';
  375. }
  376. $listtablehtml .= '</tr>
  377. </tfoot>
  378. </table>';
  379. echo json_encode(array('code' => 200, 'html' => $listtablehtml));
  380. die;
  381. }
  382. $this->data['pmArray'] = $pmArray;
  383. $ctypelist = array();
  384. if(!empty($changeArray['ctype'])){
  385. $ctype = explode(',',$changeArray['ctype']);
  386. foreach($ctype as $tk => $tv){
  387. $ctypelist[$tk]['typename'] = $this->changeType[$tv];
  388. }
  389. }
  390. $changeArray['ctypelist'] = $ctypelist;
  391. $changeArray['categoryname'] = $this->changeCategory[$changeArray['category']];
  392. $changeArray['naturename'] = $this->changeNature[$changeArray['cnature']];
  393. $changeArray['companyname'] = $this->change->getCompanybyid($changeArray['companyid'])['name'];
  394. $this->data['changeArray'] = $changeArray;
  395. //获取清单,按清单编号排序
  396. $clist = $this->change->getChangeAuditListbycid($cid);
  397. $ototalnum = 0;
  398. $ctotalnum = 0;
  399. $stotalnum = 0;
  400. if(!empty($clist)){
  401. foreach($clist as $ck => $cv){
  402. $osum = floatval($cv['unitprice'])*floatval($cv['oamount']);
  403. $osum = $cv['lid'] != 0 ? todecimal($osum,$decimalnum['costdnum']) : $osum;
  404. $clist[$ck]['osum'] = $osum;
  405. $ototalnum += $osum;
  406. $csum = todecimal(floatval($cv['unitprice'])*floatval($cv['camount']),$decimalnum['costdnum']);
  407. $clist[$ck]['csum'] = $csum;
  408. $ctotalnum += $csum;
  409. if($cv['samount'] != ''){
  410. $ssum = todecimal(floatval($cv['unitprice'])*floatval($cv['samount']),$decimalnum['costdnum']);
  411. $clist[$ck]['ssum'] = $ssum;
  412. $stotalnum += $ssum;
  413. }else{
  414. $clist[$ck]['ssum'] = '';
  415. $clist[$ck]['samount'] = '';
  416. }
  417. }
  418. }
  419. $this->data['ototalnum'] = $ototalnum;
  420. $this->data['ctotalnum'] = todecimal($ctotalnum,$decimalnum['costdnum']);
  421. $this->data['stotalnum'] = $stotalnum != 0 ? todecimal($stotalnum,$decimalnum['costdnum']) : '';
  422. $this->data['clist'] = $clist;
  423. //获取附件
  424. $attlist = $this->change->getChangeAttListbycid($cid);
  425. $showattlist = array();
  426. if(!empty($attlist)){
  427. foreach($attlist as $k => $v){
  428. //加密下载的id
  429. $fid = $this->__hashids->encode($v['id']);
  430. $showattlist[$k]['sort'] = $k+1;
  431. $showattlist[$k]['downurl'] = '/change/file/download/'.$fid;
  432. $showattlist[$k]['filename'] = $v['filename'].'.'.$v['fileext'];
  433. $showattlist[$k]['time'] = date('Y-m-d H:i',$v['intime']);
  434. $showattlist[$k]['size'] = $this->changefilesize($v['filesize']);
  435. }
  436. }
  437. $this->data['attlist'] = $showattlist;
  438. //获取审批流程列表
  439. $auditlist = $this->change->getChangeAuditsbySort($cid);
  440. if(!empty($auditlist)){
  441. foreach($auditlist as $ak => $av){
  442. $auditlist[$ak]['email'] = $this->auth->getEmail($av['uid']);
  443. $auditlist[$ak]['lastusite'] = $this->change->getChangeAuditsMaxUsite($cid,$av['times'])['maxsite'];
  444. }
  445. }
  446. $this->data['auditlist'] = $auditlist;
  447. $this->render('biangeng-detail', $this->data, TRUE);
  448. }
  449. }
  450. exit('参数有误');
  451. }
  452. public function changeNew(){
  453. if(isset($this->params['pmid']) && is_numeric($this->params['pmid'])){
  454. $pmid = $this->params['pmid'];
  455. $pmArray = $this->actmeasure->getRowByPmid($pmid);
  456. if(empty($pmArray)){
  457. exit('不存在此标段');
  458. }
  459. if($this->auth->getUid() != $pmArray['uid']){
  460. exit('不是原报人无法创建变更令');
  461. }
  462. //取标段位数设置
  463. $decimalnum = $this->getdecimal($pmArray['cdecimalnum']);
  464. $this->data['costdnum'] = $decimalnum['costdnum'];
  465. $this->data['numberdnum'] = $decimalnum['numberdnum'];
  466. include (DOO::conf()->SITE_PATH . 'protected/plugin/TemplateTag.php');
  467. //表单提交
  468. if(isset($_POST['pnum'])){
  469. if(isset($_POST['checking'])){
  470. if(empty($_POST['pnum']) || !isset($_POST['pname']) || empty($_POST['pname']) || !isset($_POST['description']) || empty($_POST['description']) || !isset($_POST['changeaudit']) || empty($_POST['changeaudit']) || !isset($_POST['changelist']) || !isset($_POST['changewhitelist'])){
  471. exit('参数缺失或为空');
  472. }
  473. if(empty($_POST['changelist']) && empty($_POST['changewhitelist'])){
  474. exit('变更清单缺失');
  475. }
  476. }elseif(isset($_POST['uncheck'])){
  477. if(empty($_POST['pnum']) || !isset($_POST['pname']) || empty($_POST['pname'])){
  478. exit('参数缺失或为空');
  479. }
  480. }
  481. //先添加生成变更令
  482. $cid = $this->change->insertChangeMsg($pmArray,$this->auth->getUid(),$_POST);
  483. if($cid){
  484. //附件添加cid
  485. if(!empty($_POST['changeatt'])){
  486. Doo::loadModel('changeatt');
  487. $attlist = explode(',', $_POST['changeatt']);
  488. foreach($attlist as $ak => $av){
  489. $changeAtt = new ChangeAtt();
  490. $changeAtt->id = $av;
  491. $changeAtt->cid = $cid;
  492. $changeAtt->update();
  493. }
  494. }
  495. //审批人添加
  496. //先添加提交人到audit中
  497. $site = 0;
  498. Doo::loadModel('changeaudit');
  499. $changeaudit2 = new ChangeAudit();
  500. $userArray2 = $this->auth->getRowByUid($this->auth->getUid());
  501. $changeaudit2->pid = $pmArray['pid'];
  502. $changeaudit2->stid = $pmArray['stid'];
  503. $changeaudit2->pmid = $pmArray['pmid'];
  504. $changeaudit2->cid = $cid;
  505. $changeaudit2->times = 0;
  506. $changeaudit2->usite = $site;
  507. $changeaudit2->usort = $site;
  508. $changeaudit2->uid = $this->auth->getUid();
  509. $changeaudit2->company = $userArray2['company'];
  510. $changeaudit2->jobs = $userArray2['jobs'];
  511. $changeaudit2->name = $userArray2['name'];
  512. $changeaudit2->status = isset($_POST['checking']) ? 'checked' : 'checking';
  513. $changeaudit2->sintime = isset($_POST['checking']) ? time() : '';
  514. $changeaudit2->insert();
  515. $site++;
  516. $auditArr = array();
  517. if(!empty($_POST['changeaudit'])){
  518. $auditlist = explode(',', $_POST['changeaudit']);
  519. foreach($auditlist as $uk => $uv){
  520. $userArray = $this->auth->getRowByUid($uv);
  521. $changeaudit = new ChangeAudit();
  522. $changeaudit->pid = $pmArray['pid'];
  523. $changeaudit->stid = $pmArray['stid'];
  524. $changeaudit->pmid = $pmArray['pmid'];
  525. $changeaudit->cid = $cid;
  526. $changeaudit->times = 0;
  527. $changeaudit->usite = $site;
  528. $changeaudit->usort = $site;
  529. $changeaudit->uid = $uv;
  530. $changeaudit->company = $userArray['company'];
  531. $changeaudit->jobs = $userArray['jobs'];
  532. $changeaudit->name = $userArray['name'];
  533. $changeaudit->status = (isset($_POST['checking']) && $uk == 0) ? 'checking' : 'uncheck';
  534. $changeaudit->insert();
  535. $site++;
  536. array_push($auditArr,array('uid' => $uv, 'ucamount' => ''));
  537. }
  538. }
  539. //清单添加,不分顺序,最终展示按清单编号排序
  540. Doo::loadModel('changeauditlist');
  541. $total = 0;
  542. if(!empty($_POST['changelist'])){
  543. $clist = explode(',',$_POST['changelist']);
  544. foreach($clist as $ck => $cv){
  545. $clistid = explode('->',$cv)[0];
  546. $clistarr = explode(';',explode('->',$cv)[1]);
  547. if(!empty($clistarr[0]) && !empty($clistarr[1]) && is_numeric($clistarr[3]) && is_numeric($clistarr[4]) && is_numeric($clistarr[5])){
  548. $changelistArr = $this->change->getChangeListbyid($clistid);
  549. if(!empty($changelistArr)){
  550. $total += todecimal(floatval($changelistArr['unitprice'])*floatval($clistarr[5]),$decimalnum['costdnum']);
  551. $cauditlist = new ChangeAuditList();
  552. $cauditlist->pid = $pmArray['pid'];
  553. $cauditlist->stid = $pmArray['stid'];
  554. $cauditlist->pmid = $pmArray['pmid'];
  555. $cauditlist->cid = $cid;
  556. $cauditlist->lid = $clistid;
  557. $cauditlist->lnum = $changelistArr['lnum'];
  558. $cauditlist->lname = $changelistArr['lname'];
  559. $cauditlist->unit = $changelistArr['unit'];
  560. $cauditlist->unitprice = $changelistArr['unitprice'];
  561. $cauditlist->oamount = $changelistArr['amount'];
  562. $cauditlist->camount = $clistarr[5];
  563. $cauditlist->auditjson = json_encode($auditArr);
  564. $cauditlist->insert();
  565. }else{
  566. $total += todecimal(floatval($clistarr[3])*floatval($clistarr[5]),$decimalnum['costdnum']);
  567. $cauditlist = new ChangeAuditList();
  568. $cauditlist->pid = $pmArray['pid'];
  569. $cauditlist->stid = $pmArray['stid'];
  570. $cauditlist->pmid = $pmArray['pmid'];
  571. $cauditlist->cid = $cid;
  572. $cauditlist->lid = 0;
  573. $cauditlist->lnum = $clistarr[0];
  574. $cauditlist->lname = $clistarr[1];
  575. $cauditlist->unit = $clistarr[2];
  576. $cauditlist->unitprice = $clistarr[3];
  577. $cauditlist->oamount = $clistarr[4];
  578. $cauditlist->camount = $clistarr[5];
  579. $cauditlist->auditjson = json_encode($auditArr);
  580. $cauditlist->insert();
  581. }
  582. }
  583. }
  584. }
  585. if(!empty($_POST['changewhitelist'])){
  586. $wlist = explode(',',$_POST['changewhitelist']);
  587. foreach($wlist as $wk => $wv){
  588. $wlistarr = explode(';',explode('->',$wv)[1]);
  589. if(!empty($wlistarr[0]) && !empty($wlistarr[1]) && is_numeric($wlistarr[3]) && is_numeric($wlistarr[4]) && is_numeric($wlistarr[5])){
  590. $total += todecimal(floatval($wlistarr[3])*floatval($wlistarr[5]),$decimalnum['costdnum']);
  591. $cauditlist = new ChangeAuditList();
  592. $cauditlist->pid = $pmArray['pid'];
  593. $cauditlist->stid = $pmArray['stid'];
  594. $cauditlist->pmid = $pmArray['pmid'];
  595. $cauditlist->cid = $cid;
  596. $cauditlist->lid = 0;
  597. $cauditlist->lnum = $wlistarr[0];
  598. $cauditlist->lname = $wlistarr[1];
  599. $cauditlist->unit = $wlistarr[2];
  600. $cauditlist->unitprice = $wlistarr[3];
  601. $cauditlist->oamount = $wlistarr[4];
  602. $cauditlist->camount = $wlistarr[5];
  603. $cauditlist->auditjson = json_encode($auditArr);
  604. $cauditlist->insert();
  605. }
  606. }
  607. }
  608. //变更令添加变更总金额
  609. $this->change->updateChangeTotalamount($cid,todecimal($total,$decimalnum['costdnum']));
  610. $status = isset($_POST['uncheck']) ? 2 : 3;
  611. return '/change/index/tender/'.$pmArray['pmid'].'/status/'.$status;
  612. }else{
  613. exit('添加到变更令失败');
  614. }
  615. }
  616. $this->data['companylist'] = $this->change->getCompanyList($pmid);
  617. $list = $this->change->getChangeListbyPmid($pmid);
  618. if(!empty($list)){
  619. foreach($list as $k => $v){
  620. $totalamount = floatval($v['unitprice'])*floatval($v['amount']);
  621. $list[$k]['totalamount'] = todecimal($totalamount,2);
  622. $list[$k]['index'] = $k+1;
  623. }
  624. }
  625. //获取标段审批人列表
  626. $auditactlist = $this->measureauditact->getUserAuditID($this->params['pmid']);
  627. //获取原报人
  628. $measureArray = $this->actmeasure->getRowByPmid($this->params['pmid']);
  629. $inside = 1;
  630. $userlist = array();
  631. $useridlist = array();
  632. if(!empty($auditactlist)){
  633. foreach($auditactlist as $k => $v){
  634. if($measureArray['uid'] == $v['auditoruid']){
  635. $inside = 0;
  636. }
  637. $usermsg = $this->auth->getRowByUid($v['auditoruid']);
  638. $userlist[$k]['userid'] = $usermsg['userid'];
  639. $userlist[$k]['name'] = $usermsg['name'];
  640. $userlist[$k]['jobs'] = $usermsg['jobs'];
  641. $userlist[$k]['avatar'] = $usermsg['avatar'];
  642. $userlist[$k]['company'] = $usermsg['company'];
  643. $userlist[$k]['email'] = $this->auth->getEmail($v['auditoruid']);
  644. array_push($useridlist, $usermsg['userid']);
  645. }
  646. }
  647. if($inside){
  648. $usermsg2 = $this->auth->getRowByUid($measureArray['uid']);
  649. $orginArray['userid'] = $measureArray['uid'];
  650. $orginArray['avatar'] = $usermsg2['avatar'];
  651. $orginArray['name'] = $usermsg2['name'];
  652. $orginArray['jobs'] = $usermsg2['jobs'];
  653. $orginArray['company'] = $usermsg2['company'];
  654. $orginArray['email'] = $this->auth->getEmail($measureArray['uid']);
  655. array_push($userlist,$orginArray);
  656. array_push($useridlist, $usermsg2['userid']);
  657. }
  658. $this->data['pmArray'] = $pmArray;
  659. $this->data['userlist'] = $userlist;
  660. $this->data['useridlist'] = implode(',',$useridlist);
  661. $userArray = $this->auth->getRowByUid($this->auth->getUid());
  662. $userArray['email'] = $this->auth->getEmail($this->auth->getUid());
  663. $this->data['userArray'] = $userArray;
  664. $this->data['list'] = $list;
  665. $this->data['year'] = date('Y',time());
  666. //获取此标段的最新一个变更令申请编号,没有则赋值为 变更申请编号001
  667. $lastnum = $this->change->getLastChangePnum($this->params['pmid']);
  668. if(!empty($lastnum)){
  669. //正则获取申请编号
  670. $pattern = '/(?!\d{3,6})(\D|\d)|19\d{2}|20\d{2}|\d{3,6}/i';
  671. preg_match_all($pattern, $lastnum['pnum'],$str);
  672. $arr = $str[0];
  673. $pnum = '';
  674. for($i = 0; $i < count($arr); $i++){
  675. if(mb_strlen($arr[$i],'UTF8') > 1){
  676. if(preg_match('/19\d{2}|20\d{2}/i',$arr[$i])){
  677. $pnum .= $arr[$i];
  678. }else{
  679. $pnum .= $this->makenum($arr[$i]);
  680. }
  681. }else{
  682. $pnum .= $arr[$i];
  683. }
  684. }
  685. $this->data['pnum'] = $pnum;
  686. }else{
  687. $this->data['pnum'] = '变更申请编号001';
  688. }
  689. $cfuhashids = new Hashids\Hashids('cfileupload', 15);
  690. $this->data['uid'] = $this->auth->getUid();
  691. $verification = $cfuhashids->encode($pmArray['pmid'],$this->auth->getUid());
  692. $this->data['verification'] = $verification;
  693. $this->render('biangeng-new', $this->data, TRUE);
  694. }else{
  695. exit('不存在此标段');
  696. }
  697. }
  698. //生成和num相同位数的并加一 001 -》 002, 0023 -》 0024
  699. function makenum($num){
  700. $len = mb_strlen($num,'UTF8'); //获取原位数
  701. $intnum = intval($num)+1; //获取int
  702. $len2 = mb_strlen($intnum,'UTF8'); //获取int位数
  703. if($len > $len2){
  704. $arr = Array();
  705. for($i = 0; $i < $len-$len2; $i++){
  706. $arr[$i] = '0';
  707. }
  708. $intnum = implode('',$arr).$intnum;
  709. }
  710. return $intnum;
  711. }
  712. public function changeApproval(){
  713. if (isset($this->params['cid']) && is_numeric($this->params['cid'])) {
  714. $cid = $this->params['cid'];
  715. $changeArray = $this->change->getChangebyid($cid);
  716. if (!empty($changeArray)) {
  717. //判断当前变更令是否处于你审批状态,否 则显示详情页
  718. $userchange = $this->change->getOneChangeAudit($this->auth->getUid(), $cid, $changeArray['times']);
  719. if ($changeArray['status'] != 'checking' || empty($userchange) || $userchange['status'] != 'checking') {
  720. return '/change/detail/' . $cid;
  721. die;
  722. }
  723. $pmArray = $this->actmeasure->getRowByPmid($changeArray['pmid']);
  724. if (empty($pmArray)) {
  725. exit('不存在此标段');
  726. }
  727. include (DOO::conf()->SITE_PATH . 'protected/plugin/TemplateTag.php');
  728. $decimalnum = $this->getdecimal($changeArray['decimalnum']);
  729. // $step = $this->makestep($decimalnum['numberdnum']);
  730. //审批结果
  731. if(isset($_POST['approval']) && is_numeric($_POST['approval'])){
  732. $status = $_POST['status'];
  733. Doo::loadModel('change');
  734. Doo::loadModel('changeaudit');
  735. Doo::loadModel('changeauditlist');
  736. $sintime = time();
  737. if($status == 'checked'){
  738. //通过
  739. $this->change->updateChangeAudit($this->auth->getUid(),$cid, $changeArray['times'], 'checked',$_POST['desc'],$sintime,$_POST['clist']);
  740. //更新audit_list
  741. $clist = explode(',',$_POST['clist']);
  742. $totalamount = 0;
  743. foreach($clist as $k => $v){
  744. $lid = explode('_',$v)[0];
  745. $ucamount = explode('_',$v)[1] != '' ? explode('_',$v)[1] : 0;
  746. $oneauditlist = $this->change->getOneChangeAuditList($lid);
  747. $totalamount += todecimal(floatval($oneauditlist['unitprice'])*floatval($ucamount),$decimalnum['costdnum']);
  748. $auditjson = json_decode($oneauditlist['auditjson'],true);
  749. foreach($auditjson as $ak => $av){
  750. if($av['uid'] == $this->auth->getUid()){
  751. $auditjson[$ak]['ucamount'] = $ucamount;
  752. }
  753. }
  754. $cauditlist = new ChangeAuditList();
  755. $cauditlist->id = $lid;
  756. $cauditlist->samount = $ucamount;
  757. $cauditlist->auditjson = json_encode($auditjson);
  758. $cauditlist->update();
  759. }
  760. //更新change总金额
  761. $this->change->updateChangeTotalamount($cid,todecimal($totalamount,$decimalnum['costdnum']));
  762. //更改下一个审批状态或结束审批
  763. $audit = new ChangeAudit();
  764. $auditlist = $audit->getChangeAuditbylastlist($cid,$changeArray['times']);
  765. $flag = true;
  766. foreach($auditlist as $uk => $uv){
  767. if($uv['status'] == 'uncheck'){
  768. $changeaudit = new ChangeAudit();
  769. $changeaudit->id = $uv['id'];
  770. $changeaudit->status = 'checking';
  771. $changeaudit->update();
  772. $flag = false;
  773. break;
  774. }
  775. }
  776. //审批完成,更改change状态
  777. if($flag){
  778. $changes = new Change();
  779. $changes->cid = $cid;
  780. $changes->bnum = isset($_POST['bnum']) ? $_POST['bnum'] : $changeArray['pnum'];
  781. $changes->status = 'checked';
  782. $changes->sintime = $sintime;
  783. $changes->update();
  784. }
  785. }elseif($status == 'back'){
  786. if(isset($_POST['back']) && $_POST['back'] == 1 && !empty($_POST['lastuid'])){
  787. //退回到上一个审批人
  788. $lastuid = $_POST['lastuid'];
  789. //新增本次审批人,设为未审批并排序加2;
  790. $auditArray2 = $this->change->getOneChangeAudit($this->auth->getUid(),$cid,$changeArray['times']);
  791. //改变当前状态
  792. $this->change->updateChangeAudit($this->auth->getUid(),$cid, $changeArray['times'], 'back',$_POST['desc'],$sintime);
  793. $changeaudit2 = new ChangeAudit();
  794. $changeaudit2->insertChangeAudit($auditArray2,'uncheck',$auditArray2['usort']+2);
  795. //新增上一个审批人,设为审批中并排序加1;
  796. $changeaudit = new ChangeAudit();
  797. $auditArray = $changeaudit->getOneChangeAudit($lastuid,$cid,$changeArray['times']);
  798. $changeaudit->insertChangeAudit($auditArray,'checking',$auditArray2['usort']+1);
  799. //把接下未审批的审批人排序都加2
  800. $changeaudit3 = new ChangeAudit();
  801. $auditlist = $changeaudit3->getChangeAuditsbycidtimeWithout($cid,$changeArray['times'],$lastuid,$this->auth->getUid());
  802. if(!empty($auditlist)){
  803. foreach($auditlist as $ak => $av){
  804. $changeaudit4 = new ChangeAudit();
  805. $changeaudit4->id = $av['id'];
  806. $changeaudit4->usort = $av['usort']+2;
  807. $changeaudit4->update();
  808. }
  809. }
  810. //获取上上个审批通过人uid
  811. if($auditArray2['usite'] > 2){
  812. $lastlastuid = $changeaudit3->getChangeAuditbycidsitetime($cid,$changeArray['times'],$auditArray2['usite']-2)['uid'];
  813. }else{
  814. $lastlastuid = '';
  815. }
  816. //更新audit_list
  817. $clist = $this->change->getChangeAuditListbycid($cid);
  818. $totalamount = 0;
  819. foreach($clist as $ck => $cv){
  820. $auditjson = json_decode($cv['auditjson'],true);
  821. $samount = '';
  822. if(empty($lastlastuid)){
  823. $totalamount += todecimal(floatval($cv['unitprice'])*floatval($cv['camount']),$decimalnum['costdnum']);
  824. }
  825. foreach($auditjson as $jk => $jv){
  826. if(!empty($lastlastuid) && $jv['uid'] == $lastlastuid){
  827. $totalamount += todecimal(floatval($cv['unitprice'])*floatval($jv['ucamount']),$decimalnum['costdnum']);
  828. $samount = $jv['ucamount'];
  829. }
  830. // if($jv['uid'] == $lastuid){
  831. // $auditjson[$jk]['ucamount'] = '';
  832. // }
  833. }
  834. $cauditlist = new ChangeAuditList();
  835. $cauditlist->id = $cv['id'];
  836. $cauditlist->samount = $samount;
  837. // $cauditlist->auditjson = json_encode($auditjson);
  838. $cauditlist->update();
  839. }
  840. //更新change总金额
  841. $this->change->updateChangeTotalamount($cid,todecimal($totalamount,$decimalnum['costdnum']));
  842. }elseif(isset($_POST['back']) && $_POST['back'] == 2){
  843. //退回到提交人,重新上报
  844. $this->change->updateChangeAudit($this->auth->getUid(),$cid, $changeArray['times'], 'backnew',$_POST['desc'],$sintime);
  845. $changeaudit = new ChangeAudit();
  846. //获取最后一次上报的上报人信息
  847. $auditArray = $changeaudit->getChangeAuditLastUser($cid,0);
  848. //获取uid最新上报人信息
  849. $userArray = $this->auth->getRowByUid($auditArray['uid']);
  850. $auditArray['company'] = $userArray['company'];
  851. $auditArray['jobs'] = $userArray['jobs'];
  852. $auditArray['name'] = $userArray['name'];
  853. //获取最后一个审批人的usort
  854. $auditArray2 = $changeaudit->getChangeAuditLastUser($cid);
  855. //新建新的提交人,并把time+1
  856. $changeaudit->insertChangeAudit($auditArray,'checking',$auditArray2['usort']+1,$auditArray['times']+1);
  857. //更新audit_list
  858. $clist = $this->change->getChangeAuditListbycid($cid);
  859. $totalamount = 0;
  860. foreach($clist as $ck => $cv){
  861. $totalamount += todecimal(floatval($cv['unitprice'])*floatval($cv['camount']),$decimalnum['costdnum']);
  862. $cauditlist = new ChangeAuditList();
  863. $cauditlist->id = $cv['id'];
  864. $cauditlist->samount = '';
  865. $cauditlist->auditjson = '';
  866. $cauditlist->update();
  867. }
  868. //更新change
  869. $changes = new Change();
  870. $changes->cid = $cid;
  871. $changes->status = 'back';
  872. $changes->totalamount = todecimal($totalamount,$decimalnum['costdnum']);
  873. $changes->update();
  874. }
  875. }elseif($status == 'checkno'){
  876. //不通过
  877. $this->change->updateChangeAudit($this->auth->getUid(),$cid, $changeArray['times'], 'checkno',$_POST['desc'],$sintime);
  878. $changes = new Change();
  879. $changes->cid = $cid;
  880. $changes->status = 'checkno';
  881. $changes->sintime = time();
  882. $changes->update();
  883. }
  884. return '/change/detail/'. $cid;
  885. }
  886. $this->data['pmArray'] = $pmArray;
  887. $ctypelist = array();
  888. if (!empty($changeArray['ctype'])) {
  889. $ctype = explode(',', $changeArray['ctype']);
  890. foreach ($ctype as $tk => $tv) {
  891. $ctypelist[$tk]['typename'] = $this->changeType[$tv];
  892. }
  893. }
  894. $changeArray['ctypelist'] = $ctypelist;
  895. $changeArray['categoryname'] = $this->changeCategory[$changeArray['category']];
  896. $changeArray['naturename'] = $this->changeNature[$changeArray['cnature']];
  897. $changeArray['companyname'] = $this->change->getCompanybyid($changeArray['companyid'])['name'];
  898. $this->data['changeArray'] = $changeArray;
  899. //获取用户审批变更清单的列表
  900. $auditlist = $this->change->getChangeAuditbylastlist($cid,$changeArray['times']);
  901. //获取清单,按清单编号排序
  902. $clist = $this->change->getChangeAuditListbycid($cid);
  903. $ototalnum = 0;
  904. $ctotalnum = 0;
  905. $stotalnum = 0;
  906. $listtablehtml = '<table class="table table-striped table-bordered nowrap qd-table" id="tablelist" cellspacing="0" style="width:100%">
  907. <thead>
  908. <tr><th rowspan="2" class="text-center" width="100">清单编号</th><th rowspan="2" class="text-center">名称</th><th rowspan="2" class="text-center">单位</th><th rowspan="2" class="text-center">单价</th><th colspan="2" class="text-center">原设计</th><th colspan="2" class="text-center">申报变更增(+)减(-)</th>';
  909. $thhtml = '<th class="text-center">数量</th>
  910. <th class="text-center">金额</th>
  911. <th class="text-center">数量</th>
  912. <th class="text-center">金额</th>';
  913. $utotalarr = array();
  914. $checkinguid = 0;
  915. $firstcheck = 0;
  916. $lastid = 0;
  917. foreach ($auditlist as $ak => $av) {
  918. $listtablehtml .= '<th colspan="2" class="text-center">'.$av['name'].' 审批</th>';
  919. $thhtml .= '<th class="text-center">数量</th><th class="text-center">金额</th>';
  920. $utotalarr[$ak]['uid'] = $av['uid'];
  921. $utotalarr[$ak]['status'] = $av['status'];
  922. $utotalarr[$ak]['usum'] = 0;
  923. if($av['status'] == 'checking'){
  924. $checkinguid = $av['uid'];
  925. if($ak == 0){
  926. $firstcheck = 1;
  927. }else{
  928. $lastid = $auditlist[$ak-1]['uid'];
  929. }
  930. }
  931. }
  932. $this->data['lastuid'] = $lastid;
  933. //获取上一个审批人名称和提交人名称
  934. if($lastid != ''){
  935. $this->data['lastusername'] = $this->auth->getRowByUid($lastid)['name'];
  936. }
  937. $this->data['createusername'] = $this->auth->getRowByUid($changeArray['uid'])['name'];
  938. $this->data['firstcheck'] = $firstcheck;
  939. $listtablehtml .= '</tr><tr>'. $thhtml .'</tr>
  940. </thead>
  941. <tbody id="list">';
  942. if (!empty($clist)) {
  943. foreach ($clist as $ck => $cv) {
  944. $osum = floatval($cv['unitprice']) * floatval($cv['oamount']);
  945. $osum = $cv['lid'] != 0 ? todecimal($osum,$decimalnum['costdnum']) : $osum;
  946. $clist[$ck]['osum'] = $osum;
  947. $ototalnum += $osum;
  948. $csum = todecimal(floatval($cv['unitprice']) * floatval($cv['camount']),$decimalnum['costdnum']);
  949. $clist[$ck]['csum'] = $csum;
  950. $ctotalnum += $csum;
  951. $listtablehtml .= '<tr class="clist"><td>' . $cv['lnum'] . '</td><td>' . $cv['lname'] . '</td><td>' . $cv['unit'] . '</td><td>' . tofloat($cv['unitprice']) . '</td><td>' . $cv['oamount'] . '</td><td>' . $osum . '</td><td>' . $cv['camount'] . '</td><td>' . $csum . '</td>';
  952. $userjson = json_decode($cv['auditjson'], true);
  953. $tdhtml = '';
  954. foreach ($userjson as $uk => $uv) {
  955. if ($uv['uid'] == $checkinguid) {
  956. if($uv['ucamount'] != '') {
  957. $ssum = todecimal(floatval($cv['unitprice'])*floatval($uv['ucamount']),$decimalnum['costdnum']);
  958. $samount = $uv['ucamount'];
  959. $stotalnum += $ssum;
  960. }else if ($cv['samount'] != ''){
  961. $ssum = todecimal(floatval($cv['unitprice'])*floatval($cv['samount']),$decimalnum['costdnum']);
  962. $samount = $cv['samount'];
  963. $stotalnum += $ssum;
  964. }else{
  965. $ssum = $csum;
  966. $samount = $cv['camount'];
  967. $stotalnum += $ssum;
  968. }
  969. $tdhtml .= '<td><input class="form-control input-sm" type="text" onkeyup="RegNum(this,event,'.$decimalnum['numberdnum'].')" listid="'.$cv['id'].'" value="'.$samount.'" placeholder="请输入变更数量"></td><td class="cnum">'.$ssum.'</td>';
  970. }else{
  971. if($uv['ucamount'] != ''){
  972. $usum = todecimal(floatval($cv['unitprice'])*floatval($uv['ucamount']),$decimalnum['costdnum']);
  973. $tdhtml .= '<td>'.$uv['ucamount'].'</td><td>'.$usum.'</td>';
  974. //update utotalarr value=>usum
  975. foreach($utotalarr as $tk => $tv){
  976. if($tv['uid'] == $uv['uid']){
  977. $utotalarr[$tk]['usum'] = todecimal(floatval($utotalarr[$tk]['usum'])+$usum,$decimalnum['costdnum']);
  978. break;
  979. }
  980. }
  981. }else{
  982. $tdhtml .= '<td></td><td></td>';
  983. }
  984. }
  985. }
  986. $listtablehtml = $listtablehtml.$tdhtml.'</tr>';
  987. }
  988. }
  989. $listtablehtml .= '</tbody><tfoot><tr class="info"><td>合计</td><td></td><td></td><td></td><td></td><td>'.$ototalnum.'</td><td></td><td>'.todecimal($ctotalnum,$decimalnum['costdnum']).'</td>';
  990. foreach($utotalarr as $tk => $tv){
  991. $addtd = $tv['status'] == 'checking' ? todecimal($stotalnum,$decimalnum['costdnum']) : ($tv['usum'] != 0 ? todecimal($tv['usum'],$decimalnum['costdnum']) : '');
  992. $checkinghtml = $tv['status'] == 'checking' ? ' class="utotalnum"': '';
  993. $listtablehtml .= '<td></td><td'. $checkinghtml .'>'.$addtd.'</td>';
  994. }
  995. $listtablehtml .= '</tr>
  996. </tfoot>
  997. </table>';
  998. $this->data['listtablehtml'] = $listtablehtml;
  999. //uid
  1000. $this->data['userid'] = $this->auth->getUid();
  1001. //cid
  1002. $this->data['cid'] = $cid;
  1003. //获取附件
  1004. $attlist = $this->change->getChangeAttListbycid($cid);
  1005. $showattlist = array();
  1006. if (!empty($attlist)) {
  1007. foreach ($attlist as $k => $v) {
  1008. //加密下载的id
  1009. $fid = $this->__hashids->encode($v['id']);
  1010. $showattlist[$k]['fid'] = $v['id'];
  1011. $showattlist[$k]['uid'] = $v['uid'];
  1012. $showattlist[$k]['sort'] = $k + 1;
  1013. $showattlist[$k]['downurl'] = '/change/file/download/' . $fid;
  1014. $showattlist[$k]['filename'] = $v['filename'] . '.' . $v['fileext'];
  1015. $showattlist[$k]['time'] = date('Y-m-d H:i', $v['intime']);
  1016. $showattlist[$k]['size'] = $this->changefilesize($v['filesize']);
  1017. }
  1018. }
  1019. $this->data['attlist'] = $showattlist;
  1020. $auditlist2 = $this->change->getChangeAuditsbySort($cid);
  1021. if(!empty($auditlist2)){
  1022. foreach($auditlist2 as $ak => $av){
  1023. $auditlist2[$ak]['email'] = $this->auth->getEmail($av['uid']);
  1024. $auditlist2[$ak]['lastusite'] = $this->change->getChangeAuditsMaxUsite($cid,$av['times'])['maxsite'];
  1025. }
  1026. }
  1027. $this->data['auditlist'] = $auditlist2;
  1028. //判断是否为本标段终审人
  1029. $auditArray = $this->change->getChangeAuditLastUser($cid);
  1030. $this->data['isenduser'] = $auditArray['uid'] == $this->auth->getUid() ? 1 : 0;
  1031. $cfuhashids = new Hashids\Hashids('cfileupload', 15);
  1032. $this->data['uid'] = $this->auth->getUid();
  1033. $verification = $cfuhashids->encode($pmArray['pmid'],$this->auth->getUid());
  1034. $this->data['verification'] = $verification;
  1035. $this->render('biangeng-approval', $this->data, TRUE);exit;
  1036. }
  1037. }
  1038. exit('参数有误');
  1039. }
  1040. //重新上报、修改变更内容
  1041. public function changeReport(){
  1042. if(isset($this->params['cid']) && is_numeric($this->params['cid'])){
  1043. $cid = $this->params['cid'];
  1044. $changeArray = $this->change->getChangebyid($cid);
  1045. //判断当前变更令是否处于上报或重新上报状态,否 则显示详情页
  1046. if (!empty($changeArray) && ($changeArray['status'] == 'back' || $changeArray['status'] == 'uncheck') && $changeArray['uid'] == $this->auth->getUid() ) {
  1047. $pmArray = $this->actmeasure->getRowByPmid($changeArray['pmid']);
  1048. if (empty($pmArray)) {
  1049. exit('不存在此标段');
  1050. }
  1051. if($this->auth->getUid() != $pmArray['uid']){
  1052. exit('不是原报人无法修改或重新上报变更令');
  1053. }
  1054. include (DOO::conf()->SITE_PATH . 'protected/plugin/TemplateTag.php');
  1055. //取标段位数设置
  1056. $decimalnum = $this->getdecimal($changeArray['decimalnum']);
  1057. $this->data['costdnum'] = $decimalnum['costdnum'];
  1058. $this->data['numberdnum'] = $decimalnum['numberdnum'];
  1059. //删除变更令
  1060. if(isset($_POST['delete']) && !empty($_POST['delete']) && $changeArray['status'] == 'uncheck'){
  1061. //需要删除变更令表,清单表,变更审批人表,附件表及附件
  1062. $this->change->delChangebyCid($cid);
  1063. $this->change->delChangeAuditListbyCid($cid);
  1064. $this->change->delChangeAuditbyCid($cid);
  1065. $changeAttList = $this->change->getChangeAttListbycid($cid);
  1066. if(!empty($changeAttList)){
  1067. Doo::loadModel('changeatt');
  1068. include (DOO::conf()->SITE_PATH . 'protected/plugin/io.han.php');
  1069. $pathf = DOO::conf()->SITE_PATH;
  1070. foreach($changeAttList as $k => $v){
  1071. $this->IoHandler = new IoHandler();
  1072. $this->IoHandler->DeleteFile($pathf.$v['filepath']);
  1073. $changeAtt = new ChangeAtt();
  1074. $changeAtt->delChangeAttbyFid($v['id']);
  1075. }
  1076. }
  1077. return '/change/index/tender/'.$pmArray['pmid'];
  1078. }
  1079. //表单提交
  1080. if(isset($_POST['pnum'])){
  1081. if(isset($_POST['status']) && $_POST['status'] == 'checking'){
  1082. if(empty($_POST['pnum']) || !isset($_POST['pname']) || empty($_POST['pname']) || !isset($_POST['description']) || empty($_POST['description']) || !isset($_POST['changeaudit']) || empty($_POST['changeaudit']) || !isset($_POST['changelist']) || !isset($_POST['changewhitelist'])){
  1083. exit('参数缺失或为空');
  1084. }
  1085. if(empty($_POST['changelist']) && empty($_POST['changewhitelist'])){
  1086. exit('变更清单缺失');
  1087. }
  1088. }elseif(isset($_POST['status']) && $_POST['status'] == 'save'){
  1089. if(empty($_POST['pnum']) || !isset($_POST['pname']) || empty($_POST['pname'])){
  1090. exit('参数缺失或为空');
  1091. }
  1092. }
  1093. Doo::loadModel('change');
  1094. Doo::loadModel('changeaudit');
  1095. Doo::loadModel('changeauditlist');
  1096. //获取提交人audit表信息
  1097. $creatorArray = $this->change->getChangeAuditLastUser($cid,0);
  1098. $sort = $creatorArray['usort']+1;
  1099. //先修改成变更令
  1100. $status = isset($_POST['status']) && $_POST['status'] == 'checking' ? 'checking' : '';
  1101. $this->change->updateChangeMsg($cid,$_POST,$creatorArray['times'],$status);
  1102. if($status){
  1103. //再修改提交人上报信息
  1104. $changeaudit2 = new ChangeAudit();
  1105. $changeaudit2->id = $creatorArray['id'];
  1106. $changeaudit2->status = 'checked';
  1107. $changeaudit2->sintime = time();
  1108. $changeaudit2->update();
  1109. }
  1110. //附件添加cid
  1111. if(!empty($_POST['changeatt'])){
  1112. Doo::loadModel('changeatt');
  1113. $attlist = explode(',', $_POST['changeatt']);
  1114. foreach($attlist as $ak => $av){
  1115. $changeAtt = new ChangeAtt();
  1116. $changeAtt->id = $av;
  1117. $changeAtt->cid = $cid;
  1118. $changeAtt->update();
  1119. }
  1120. }
  1121. //先删除所有审批人列,再重新添加
  1122. $caudit = new ChangeAudit();
  1123. $caudit->deleteChangeAuditthisTime($cid,$creatorArray['times']);
  1124. //审批人添加
  1125. $auditArr = array();
  1126. if(!empty($_POST['changeaudit'])){
  1127. $auditlist = explode(',', $_POST['changeaudit']);
  1128. $site = 1;
  1129. foreach($auditlist as $uk => $uv){
  1130. $userArray = $this->auth->getRowByUid($uv);
  1131. $changeaudit = new ChangeAudit();
  1132. $changeaudit->pid = $pmArray['pid'];
  1133. $changeaudit->stid = $pmArray['stid'];
  1134. $changeaudit->pmid = $pmArray['pmid'];
  1135. $changeaudit->cid = $cid;
  1136. $changeaudit->times = $creatorArray['times'];
  1137. $changeaudit->usite = $site;
  1138. $changeaudit->usort = $sort;
  1139. $changeaudit->uid = $uv;
  1140. $changeaudit->company = $userArray['company'];
  1141. $changeaudit->jobs = $userArray['jobs'];
  1142. $changeaudit->name = $userArray['name'];
  1143. $changeaudit->status = (isset($_POST['status']) && $_POST['status'] == 'checking' && $uk == 0) ? 'checking' : 'uncheck';
  1144. $changeaudit->insert();
  1145. $sort++;
  1146. $site++;
  1147. array_push($auditArr,array('uid' => $uv, 'ucamount' => ''));
  1148. }
  1149. }
  1150. //先删除变更令所有清单列,再重新添加
  1151. $cauditlist2 = new ChangeAuditList();
  1152. $cauditlist2->delChangeAuditListbyCid($cid);
  1153. //清单添加,不分顺序,最终展示按清单编号排序
  1154. $total = 0;
  1155. if(!empty($_POST['changelist'])){
  1156. $clist = explode(',',$_POST['changelist']);
  1157. foreach($clist as $ck => $cv){
  1158. $clistid = explode('->',$cv)[0];
  1159. $clistarr = explode(';',explode('->',$cv)[1]);
  1160. if(!empty($clistarr[0]) && !empty($clistarr[1]) && is_numeric($clistarr[3]) && is_numeric($clistarr[4]) && is_numeric($clistarr[5])){
  1161. $changelistArr = $this->change->getChangeListbyid($clistid);
  1162. if(!empty($changelistArr)){
  1163. $total += todecimal(floatval($changelistArr['unitprice'])*floatval($clistarr[5]),$decimalnum['costdnum']);
  1164. $cauditlist = new ChangeAuditList();
  1165. $cauditlist->pid = $pmArray['pid'];
  1166. $cauditlist->stid = $pmArray['stid'];
  1167. $cauditlist->pmid = $pmArray['pmid'];
  1168. $cauditlist->cid = $cid;
  1169. $cauditlist->lid = $clistid;
  1170. $cauditlist->lnum = $changelistArr['lnum'];
  1171. $cauditlist->lname = $changelistArr['lname'];
  1172. $cauditlist->unit = $changelistArr['unit'];
  1173. $cauditlist->unitprice = $changelistArr['unitprice'];
  1174. $cauditlist->oamount = $changelistArr['amount'];
  1175. $cauditlist->camount = $clistarr[5];
  1176. $cauditlist->auditjson = json_encode($auditArr);
  1177. $cauditlist->insert();
  1178. }else{
  1179. $total += todecimal(floatval($clistarr[3])*floatval($clistarr[5]),$decimalnum['costdnum']);
  1180. $cauditlist = new ChangeAuditList();
  1181. $cauditlist->pid = $pmArray['pid'];
  1182. $cauditlist->stid = $pmArray['stid'];
  1183. $cauditlist->pmid = $pmArray['pmid'];
  1184. $cauditlist->cid = $cid;
  1185. $cauditlist->lid = 0;
  1186. $cauditlist->lnum = $clistarr[0];
  1187. $cauditlist->lname = $clistarr[1];
  1188. $cauditlist->unit = $clistarr[2];
  1189. $cauditlist->unitprice = $clistarr[3];
  1190. $cauditlist->oamount = $clistarr[4];
  1191. $cauditlist->camount = $clistarr[5];
  1192. $cauditlist->auditjson = json_encode($auditArr);
  1193. $cauditlist->insert();
  1194. }
  1195. }
  1196. }
  1197. }
  1198. if(!empty($_POST['changewhitelist'])){
  1199. $wlist = explode(',',$_POST['changewhitelist']);
  1200. foreach($wlist as $wk => $wv){
  1201. $wlistarr = explode(';',explode('->',$wv)[1]);
  1202. if(!empty($wlistarr[0]) && !empty($wlistarr[1]) && is_numeric($wlistarr[3]) && is_numeric($wlistarr[4]) && is_numeric($wlistarr[5])){
  1203. $total += todecimal(floatval($wlistarr[3])*floatval($wlistarr[5]),$decimalnum['costdnum']);
  1204. $cauditlist = new ChangeAuditList();
  1205. $cauditlist->pid = $pmArray['pid'];
  1206. $cauditlist->stid = $pmArray['stid'];
  1207. $cauditlist->pmid = $pmArray['pmid'];
  1208. $cauditlist->cid = $cid;
  1209. $cauditlist->lid = 0;
  1210. $cauditlist->lnum = $wlistarr[0];
  1211. $cauditlist->lname = $wlistarr[1];
  1212. $cauditlist->unit = $wlistarr[2];
  1213. $cauditlist->unitprice = $wlistarr[3];
  1214. $cauditlist->oamount = $wlistarr[4];
  1215. $cauditlist->camount = $wlistarr[5];
  1216. $cauditlist->auditjson = json_encode($auditArr);
  1217. $cauditlist->insert();
  1218. }
  1219. }
  1220. }
  1221. //变更令添加变更总金额
  1222. $this->change->updateChangeTotalamount($cid,todecimal($total,$decimalnum['costdnum']));
  1223. $status = isset($_POST['status']) && $_POST['status'] == 'checking' ? 3 : 2;
  1224. return '/change/index/tender/'.$pmArray['pmid'].'/status/'.$status;
  1225. }
  1226. $this->data['companylist'] = $this->change->getCompanyList($pmArray['pmid']);
  1227. $list = $this->change->getChangeListbyPmid($pmArray['pmid']);
  1228. if(!empty($list)){
  1229. foreach($list as $k => $v){
  1230. $totalamount = floatval($v['unitprice'])*floatval($v['amount']);
  1231. $list[$k]['totalamount'] = todecimal($totalamount,2);
  1232. $list[$k]['index'] = $k+1;
  1233. }
  1234. }
  1235. //获取标段审批人列表
  1236. $auditactlist = $this->measureauditact->getUserAuditID($pmArray['pmid']);
  1237. //获取原报人
  1238. $measureArray = $this->actmeasure->getRowByPmid($pmArray['pmid']);
  1239. $inside = 1;
  1240. $userlist = array();
  1241. $useridlist = array();
  1242. if(!empty($auditactlist)){
  1243. foreach($auditactlist as $k => $v){
  1244. if($measureArray['uid'] == $v['auditoruid']){
  1245. $inside = 0;
  1246. }
  1247. $usermsg = $this->auth->getRowByUid($v['auditoruid']);
  1248. $userlist[$k]['userid'] = $usermsg['userid'];
  1249. $userlist[$k]['name'] = $usermsg['name'];
  1250. $userlist[$k]['jobs'] = $usermsg['jobs'];
  1251. $userlist[$k]['avatar'] = $usermsg['avatar'];
  1252. $userlist[$k]['company'] = $usermsg['company'];
  1253. $userlist[$k]['email'] = $this->auth->getEmail($v['auditoruid']);
  1254. array_push($useridlist, $usermsg['userid']);
  1255. }
  1256. }
  1257. if($inside){
  1258. $usermsg2 = $this->auth->getRowByUid($measureArray['uid']);
  1259. $orginArray['userid'] = $measureArray['uid'];
  1260. $orginArray['avatar'] = $usermsg2['avatar'];
  1261. $orginArray['name'] = $usermsg2['name'];
  1262. $orginArray['jobs'] = $usermsg2['jobs'];
  1263. $orginArray['company'] = $usermsg2['company'];
  1264. $orginArray['email'] = $this->auth->getEmail($measureArray['uid']);
  1265. array_push($userlist,$orginArray);
  1266. array_push($useridlist, $usermsg2['userid']);
  1267. }
  1268. //获取已选审批人列表,生成changeaudit和selectauditlist,并把未在常用审批人的uid找出来
  1269. $auditlist = $this->change->getChangeAuditsbycidtime($cid,$changeArray['times']);
  1270. $changeauditList = array();
  1271. $selectauditlist = array();
  1272. foreach($auditlist as $adk => $adv){
  1273. $email = $this->auth->getEmail($adv['uid']);
  1274. $auditlist[$adk]['email'] = $email;
  1275. $auditlist[$adk]['lastusite'] = count($auditlist);
  1276. array_push($changeauditList,$adv['uid']);
  1277. $addauditlist = $adv['uid'].'_'.$adv['name'].'_'.$adv['company'].'_'.$adv['jobs'].'_'.$email;
  1278. array_push($selectauditlist,$addauditlist);
  1279. // if(!in_array($adv['uid'],$useridlist)){
  1280. // $auditlist[$adk]['email'] = $this->auth->getEmail($adv['uid']);
  1281. // array_push($useridlist,$adv['uid']);
  1282. // }
  1283. $auditlist[$adk]['islast'] = $adk+1 == count($auditlist) ? 1 : 0;
  1284. }
  1285. $this->data['changeaudit'] = implode(',',$changeauditList);
  1286. $this->data['selectauditlist'] = implode('->',$selectauditlist);
  1287. $this->data['auditlist'] = $auditlist;
  1288. //获取已选清单列表,已选清单id列表,属于签约清单的changelist,和changewhitelist
  1289. $clist = $this->change->getChangeAuditListbycid($cid);
  1290. $ototalnum = 0;
  1291. $ctotalnum = 0;
  1292. $changeidlist = array();
  1293. $changelist = array();
  1294. $changewhitelist = array();
  1295. if(!empty($clist)){
  1296. $addnum = 1;
  1297. foreach($clist as $ck => $cv){
  1298. $osum = floatval($cv['unitprice'])*floatval($cv['oamount']);
  1299. $osum = todecimal($osum,2);
  1300. $csum = todecimal(floatval($cv['unitprice'])*floatval($cv['camount']),$decimalnum['costdnum']);
  1301. $clist[$ck]['csum'] = $csum;
  1302. $ctotalnum += $csum;
  1303. //判断这条清单是否已被替换或删除,有则变成空白清单显示
  1304. $oneclist = $this->change->getChangeListbyid($cv['lid']);
  1305. if($cv['lid'] != 0 && !empty($oneclist)){
  1306. array_push($changeidlist,$cv['lid']);
  1307. array_push($changelist,$cv['lid'].'->'.$cv['lnum'].';'.$cv['lname'].';'.$cv['unit'].';'.$cv['unitprice'].';'.$cv['oamount'].';'.$cv['camount']);
  1308. $clist[$ck]['iswhite'] = 0;
  1309. }else{
  1310. $clist[$ck]['add'] = $addnum;
  1311. array_push($changewhitelist,$addnum.'->'.$cv['lnum'].';'.$cv['lname'].';'.$cv['unit'].';'.$cv['unitprice'].';'.$cv['oamount'].';'.$cv['camount']);
  1312. $addnum++;
  1313. $clist[$ck]['changeunit'] = $this->changeUnit;
  1314. $clist[$ck]['iswhite'] = 1;
  1315. }
  1316. $clist[$ck]['osum'] = $osum;
  1317. $ototalnum += $osum;
  1318. }
  1319. }
  1320. $this->data['changelist'] = implode(',',$changelist);
  1321. $this->data['changewhitelist'] = implode(',',$changewhitelist);
  1322. $this->data['changeidlist'] = implode(',',$changeidlist);
  1323. $this->data['ototalnum'] = $ototalnum;
  1324. $this->data['ctotalnum'] = todecimal($ctotalnum,$decimalnum['costdnum']);
  1325. $this->data['clist'] = $clist;
  1326. //获取已添加的附件列表
  1327. $attlist = $this->change->getChangeAttListbycid($cid);
  1328. $showattlist = array();
  1329. if (!empty($attlist)) {
  1330. foreach ($attlist as $k => $v) {
  1331. //加密下载的id
  1332. $fid = $this->__hashids->encode($v['id']);
  1333. $showattlist[$k]['fid'] = $v['id'];
  1334. $showattlist[$k]['uid'] = $v['uid'];
  1335. $showattlist[$k]['sort'] = $k + 1;
  1336. $showattlist[$k]['downurl'] = '/change/file/download/' . $fid;
  1337. $showattlist[$k]['filename'] = $v['filename'] . '.' . $v['fileext'];
  1338. $showattlist[$k]['time'] = date('Y-m-d H:i', $v['intime']);
  1339. $showattlist[$k]['size'] = $this->changefilesize($v['filesize']);
  1340. }
  1341. }
  1342. $this->data['attlist'] = $showattlist;
  1343. $this->data['changeArray'] = $changeArray;
  1344. $this->data['pmArray'] = $pmArray;
  1345. $this->data['userlist'] = $userlist;
  1346. $this->data['useridlist'] = implode(',',$useridlist);
  1347. $userArray = $this->auth->getRowByUid($this->auth->getUid());
  1348. $userArray['email'] = $this->auth->getEmail($this->auth->getUid());
  1349. $this->data['userArray'] = $userArray;
  1350. $this->data['list'] = $list;
  1351. $this->data['year'] = date('Y',time());
  1352. //输出重新上报的审批列表信息
  1353. if($changeArray['status'] == 'back'){
  1354. $creatorArray = $this->change->getChangeAuditLastUser($cid,0);
  1355. $auditlist2 = $this->change->getChangeAuditsbySort($cid,$creatorArray['times']);
  1356. if(!empty($auditlist2)){
  1357. foreach($auditlist2 as $ak => $av){
  1358. $auditlist2[$ak]['email'] = $this->auth->getEmail($av['uid']);
  1359. $auditlist2[$ak]['lastusite'] = $this->change->getChangeAuditsMaxUsite($cid,$av['times'])['maxsite'];
  1360. }
  1361. }
  1362. $this->data['auditlist2'] = $auditlist2;
  1363. }
  1364. $cfuhashids = new Hashids\Hashids('cfileupload', 15);
  1365. $this->data['uid'] = $this->auth->getUid();
  1366. $verification = $cfuhashids->encode($pmArray['pmid'],$this->auth->getUid());
  1367. $this->data['verification'] = $verification;
  1368. // $this->data['stepnumdnum'] = $this->makestep(intval($decimalnum['numberdnum']));
  1369. $this->render('biangeng-update', $this->data, TRUE);
  1370. }else{
  1371. return '/change/detail/' . $cid;
  1372. die;
  1373. }
  1374. }else{
  1375. exit('不存在此变更令');
  1376. }
  1377. }
  1378. public function editCompany(){
  1379. if(isset($_POST['uci']) && isset($_POST['uc']) && isset($_POST['ac'])){
  1380. $addhtml = '';
  1381. $selecthtml = '';
  1382. Doo::loadModel('changecompany');
  1383. if(!empty($_POST['uci'])){
  1384. $idarr = $_POST['uci'];
  1385. $namearr = $_POST['uc'];
  1386. foreach($idarr as $k => $v){
  1387. $company = new ChangeCompany();
  1388. $company->id = $v;
  1389. $company->name = $namearr[$k];
  1390. $company->update();
  1391. $selecthtml .= '<option value="'.$v.'">'.$namearr[$k].'</option>';
  1392. }
  1393. }
  1394. if(!empty($_POST['ac'])){
  1395. $addarr = $_POST['ac'];
  1396. $pmArray = $this->actmeasure->getRowByPmid($_POST['pmid']);
  1397. foreach($addarr as $ak => $av){
  1398. if(!empty(trim($av))){
  1399. $company2 = new ChangeCompany();
  1400. $company2->pid = $pmArray['pid'];
  1401. $company2->stid = $pmArray['stid'];
  1402. $company2->pmid = $pmArray['pmid'];
  1403. $company2->name = $av;
  1404. $id = $company2->insert();
  1405. $selecthtml .= '<option value="'.$id.'">'.$av.'</option>';
  1406. $addhtml .= '<div class="form-group"><input type="text" id="'.$id.'" class="form-control" value="'.$av.'"></div>';
  1407. }
  1408. }
  1409. }
  1410. echo json_encode(array('code' => 200, 'addhtml' => $addhtml, 'selecthtml' => $selecthtml));
  1411. die;
  1412. }else{
  1413. echo json_encode(array('code' => 500));
  1414. die;
  1415. }
  1416. }
  1417. public function searchUser(){
  1418. if(!isset($_GET['name']) || empty($_GET['name'])){
  1419. echo json_encode(array('code' => 400, 'msg' => '请输入审批人名称'));
  1420. exit;
  1421. }
  1422. $usermsg = $this->profile->checkUserName($_GET['name']);
  1423. if(!empty($usermsg)){
  1424. $useridlist = $_POST['useridlist'];
  1425. $userlist = array();
  1426. foreach($usermsg as $k => $v){
  1427. if(!in_array($v['userid'], $useridlist)){
  1428. $usermsg[$k]['email'] = $this->auth->getEmail($v['userid']);
  1429. array_push($userlist,$usermsg[$k]);
  1430. }
  1431. }
  1432. if(!empty($userlist)){
  1433. echo json_encode(array('code' => 200, 'userlist' => $userlist));
  1434. exit;
  1435. }else{
  1436. echo json_encode(array('code' => 400, 'msg' => '常用中已存在当前审批人'));
  1437. exit;
  1438. }
  1439. }else{
  1440. echo json_encode(array('code' => 400, 'msg' => '不存在此审批人名称'));
  1441. exit;
  1442. }
  1443. }
  1444. public function fileUpload(){
  1445. // session_write_close();
  1446. // if(isset($_POST['sessionid'])){
  1447. // session_id($_POST['sessionid']);
  1448. // setcookie('PHPSESSID',$_POST['sessionid']);
  1449. // session_start();
  1450. // }
  1451. if(!isset($this->params['pmid']) && !is_numeric($this->params['pmid'])){
  1452. exit(json_encode(array('success' => false, 'msg' => '参数有误')));
  1453. }
  1454. $pmArray = $this->actmeasure->getRowByPmid($this->params['pmid']);
  1455. if(empty($pmArray)){
  1456. exit(json_encode(array('success' => false, 'msg' => '不存在此标段,无法上传')));
  1457. }
  1458. Doo::loadClass('extras/Uploader');
  1459. $files = array();
  1460. $upload_dir = Doo::conf()->SITE_PATH . 'cfiles/';
  1461. $uploader = new FileUpload('uploadfile');
  1462. $intime = time();
  1463. $extPathdir = $upload_dir.date('Y/md/',$intime);
  1464. if (!$this->dir_create2($extPathdir)) {
  1465. $status = array('success' => FALSE, 'msg' => '文件夹创建失败');
  1466. echo json_encode($status, JSON_UNESCAPED_UNICODE);
  1467. die();
  1468. }
  1469. $files['filename'] = $uploader->getFileNameWithoutExt();
  1470. $files['fileext'] = $uploader->getExtension();
  1471. $files['filesize'] = $uploader->getFileSize();
  1472. $filepath = date('Ymdhis',$intime) . rand(100, 999) . '.' . $files['fileext'];
  1473. $uploader->newFileName = $filepath;
  1474. $files['filepath'] = 'cfiles/'.date('Y/md/',$intime).$filepath;
  1475. $result = $uploader->handleUpload($extPathdir);
  1476. if (!$result) {
  1477. exit(json_encode(array('success' => false, 'msg' => $uploader->getErrorMsg())));
  1478. }
  1479. $files['pid'] = $pmArray['pid'];
  1480. $files['stid'] = $pmArray['stid'];
  1481. $files['pmid'] = $pmArray['pmid'];
  1482. $files['cid'] = isset($this->params['cid']) && is_numeric($this->params['cid']) ? $this->params['cid'] : 0;
  1483. $files['uid'] = $this->auth->getUid();
  1484. $files['intime'] = $intime;
  1485. $result2 = $this->change->insertChangeAtt($files);
  1486. if(empty($result2)){
  1487. exit(json_encode(array('success' => false, 'msg' => '添加到数据库发生错误')));
  1488. }
  1489. $files2 = array();
  1490. $files2['id'] = $result2;
  1491. //加密下载的id
  1492. $fid = $this->__hashids->encode($result2);
  1493. $files2['downurl'] = '/change/file/download/'.$fid;
  1494. $files2['filename'] = $files['filename'].'.'.$files['fileext'];
  1495. $files2['time'] = date('Y-m-d H:i',$intime);
  1496. $files2['size'] = $this->changefilesize($files['filesize']);
  1497. echo json_encode(array('success' => true, 'files' => $files2));
  1498. }
  1499. public function fileDownload(){
  1500. $fid = isset($this->params['fid'])?$this->params['fid']:null;
  1501. if($fid) {
  1502. //解密下载的id
  1503. $fid = $this->__hashids->decode($fid)[0];
  1504. $fileArray = $this->change->getChangeAttbyFid($fid);
  1505. if (!empty($fileArray)) {
  1506. $pathf = DOO::conf()->SITE_PATH;
  1507. $this->file_down($pathf.$fileArray['filepath'],$fileArray['filename'].'.'.$fileArray['fileext']);
  1508. }
  1509. }
  1510. }
  1511. public function fileDelete(){
  1512. $fid = isset($_POST['fid']) && is_numeric($_POST['fid']) ? $_POST['fid'] : null;
  1513. if($fid){
  1514. $fileArray = $this->change->getChangeAttbyFid($fid);
  1515. if (!empty($fileArray) && $fileArray['uid'] == $this->auth->getUid()) {
  1516. include (DOO::conf()->SITE_PATH . 'protected/plugin/io.han.php');
  1517. $pathf = DOO::conf()->SITE_PATH;
  1518. $this->IoHandler = new IoHandler();
  1519. $this->IoHandler->DeleteFile($pathf.$fileArray['filepath']);
  1520. $this->change->delChangeAttbyFid($fid);
  1521. exit(json_encode(array('code' => 200)));
  1522. }
  1523. }
  1524. exit(json_encode(array('code' => 400)));
  1525. }
  1526. public function pnumCheck(){
  1527. if(isset($_POST['pnum']) && !empty($_POST['pnum']) && isset($_POST['status']) && !empty($_POST['status']) && isset($_POST['pmid']) && is_numeric($_POST['pmid'])){
  1528. if($_POST['status'] == 'new'){
  1529. $changeArray = $this->change->getChangebyPnumPmid($_POST['pnum'],$_POST['pmid']);
  1530. if(!empty($changeArray)){
  1531. exit(json_encode(array('code' => 400,'msg' => '当前标段变更令已存在此申请编号,请重新输入或改变自增编号值')));
  1532. }else{
  1533. exit(json_encode(array('code' => 200,'msg' => '')));
  1534. }
  1535. }elseif($_POST['status'] == 'update'){
  1536. if(isset($_POST['cid']) && is_numeric($_POST['cid'])){
  1537. $changeArray = $this->change->getChangebyPnumPmid($_POST['pnum'],$_POST['pmid'],$_POST['cid']);
  1538. if(!empty($changeArray)){
  1539. exit(json_encode(array('code' => 400,'msg' => '当前标段变更令已存在此申请编号,请重新输入或改变自增编号值')));
  1540. }else{
  1541. exit(json_encode(array('code' => 200,'msg' => '')));
  1542. }
  1543. }
  1544. }
  1545. }
  1546. exit(json_encode(array('code' => 400,'msg' => '判断参数有误')));
  1547. }
  1548. //设置小数位数
  1549. public function setDecimalnum(){
  1550. $num = array(0,1,2,3,4,5,6);
  1551. if(isset($_POST['costdnum']) && isset($_POST['numberdnum']) && in_array(intval($_POST['costdnum']), $num) && in_array(intval($_POST['numberdnum']), $num)){
  1552. $dnum = intval($_POST['costdnum']).'_'.intval($_POST['numberdnum']);
  1553. //判断更改类型
  1554. if(isset($_POST['pmid']) && is_numeric($_POST['pmid'])){
  1555. $pmArray = $this->actmeasure->getRowByPmid($_POST['pmid']);
  1556. if(!empty($pmArray)){
  1557. $this->actmeasure->updateChangeDecimalNum($_POST['pmid'],$dnum);
  1558. exit(json_encode(array('code' => 200,'msg' => '更新小数位数成功')));
  1559. }else{
  1560. exit(json_encode(array('code' => 400,'msg' => '不存在此标段')));
  1561. }
  1562. }elseif(isset($_POST['cid']) && is_numeric($_POST['cid'])){
  1563. $changeArray = $this->change->getChangebyid($_POST['cid']);
  1564. if(!empty($changeArray)){
  1565. $this->change->updateChangeDecimalNum($_POST['cid'],$dnum);
  1566. exit(json_encode(array('code' => 200,'msg' => '更新小数位数成功')));
  1567. }else{
  1568. exit(json_encode(array('code' => 400,'msg' => '不存在此变更令')));
  1569. }
  1570. }
  1571. }
  1572. exit(json_encode(array('code' => 400,'msg' => '参数或小数位数有误')));
  1573. }
  1574. //根据位数生成几位小数,0位-》1,1位-》0.1 ,5位-》0.00001
  1575. function makestep($num){
  1576. if($num >= 1 && $num <= 6){
  1577. $arr = [];
  1578. for($i=0;$i< $num;$i++){
  1579. if($i != $num-1){
  1580. $arr[$i] = 0;
  1581. }else{
  1582. $arr[$i] = 1;
  1583. }
  1584. }
  1585. return '0.'.implode('',$arr);
  1586. }else{
  1587. return 1;
  1588. }
  1589. }
  1590. //获取costdnum和numberdnum
  1591. function getdecimal($arr){
  1592. //取变更令位数设置
  1593. $decimalnum = explode('_',$arr);
  1594. $decimal = array();
  1595. $decimal['costdnum'] = $decimalnum[0];
  1596. $decimal['numberdnum'] = $decimalnum[1];
  1597. return $decimal;
  1598. }
  1599. public function substr_replace_cn($string, $repalce = '*', $start = 0, $len = 0)
  1600. {
  1601. $count = mb_strlen($string, 'UTF-8'); //此处传入编码,建议使用utf-8。此处编码要与下面mb_substr()所使用的一致
  1602. if (!$count) {
  1603. return $string;
  1604. }
  1605. if ($len == 0) {
  1606. $end = $count; //传入0则替换到最后
  1607. } else {
  1608. $end = $start + $len; //传入指定长度则为开始长度+指定长度
  1609. }
  1610. $i = 0;
  1611. $returnString = '';
  1612. while ($i < $count) { //循环该字符串
  1613. $tmpString = mb_substr($string, $i, 1, 'UTF-8'); // 与mb_strlen编码一致
  1614. if ($start <= $i && $i < $end) {
  1615. $returnString .= $repalce;
  1616. } else {
  1617. $returnString .= $tmpString;
  1618. }
  1619. $i++;
  1620. }
  1621. return $returnString;
  1622. }
  1623. function unicode_encode($name)
  1624. {//to Unicode
  1625. $name = iconv('UTF-8', 'UCS-2', $name);
  1626. $len = strlen($name);
  1627. $str = '';
  1628. for ($i = 0; $i < $len - 1; $i = $i + 2) {
  1629. $c = $name[$i];
  1630. $c2 = $name[$i + 1];
  1631. if (ord($c) > 0) {// 两个字节的字
  1632. $str .= '\\' . base_convert(ord($c), 10, 16) . base_convert(ord($c2), 10, 16);
  1633. } else {
  1634. $str .= $c2;
  1635. }
  1636. }
  1637. $str = strtoupper($str);
  1638. return $str;
  1639. }
  1640. function unicode_decode($name)
  1641. {//Unicode to
  1642. $pattern = '/([\w]+)|(\\\u([\w]{4}))/i';
  1643. preg_match_all($pattern, $name, $matches);
  1644. if (!empty($matches)) {
  1645. $name = '';
  1646. for ($j = 0; $j < count($matches[0]); $j++) {
  1647. $str = $matches[0][$j];
  1648. if (strpos($str, '\\u') === 0) {
  1649. $code = base_convert(substr($str, 2, 2), 16, 10);
  1650. $code2 = base_convert(substr($str, 4), 16, 10);
  1651. $c = chr($code) . chr($code2);
  1652. $c = iconv('UCS-2', 'UTF-8', $c);
  1653. $name .= $c;
  1654. } else {
  1655. $name .= $str;
  1656. }
  1657. }
  1658. }
  1659. return $name;
  1660. }
  1661. function dir_create2($path, $mode = 0777)
  1662. {
  1663. if (is_dir($path))
  1664. return TRUE;
  1665. $path = $this->dir_path($path);
  1666. $parent = dirname($path);
  1667. if (!is_dir($parent)){
  1668. @mkdir($parent, 0777);
  1669. @chmod($parent, 0777);
  1670. }
  1671. @mkdir($path, 0777);
  1672. @chmod($path, 0777);
  1673. return is_dir($path);
  1674. }
  1675. function dir_path($path)
  1676. {
  1677. $path = str_replace('\\', '/', $path);
  1678. if (substr($path, -1) != '/')
  1679. $path = $path . '/';
  1680. return $path;
  1681. }
  1682. //字节转换
  1683. function changefilesize($value){
  1684. $units = array(' B', ' KB', ' MB', ' GB', ' TB');
  1685. for ($i = 0; $value >= 1024 && $i < 4; $i++) $value /= 1024;
  1686. return round($value, 2).$units[$i];
  1687. }
  1688. /**
  1689. * 文件下载
  1690. * @param $filepath 文件路径
  1691. * @param $filename 文件名称
  1692. */
  1693. public function file_down($filepath,$filename) {
  1694. if (ob_get_length() !== false)
  1695. @ob_end_clean();
  1696. header('Content-Description: File Download');
  1697. header('Content-Type: application/octet-stream');
  1698. header('Content-Disposition: attachment; filename='.basename($filename));
  1699. header('Content-Transfer-Encoding: binary');
  1700. header('Expires: 0');
  1701. header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
  1702. header('Pragma: public');
  1703. header('Content-Length: ' . filesize($filepath));
  1704. @readfile($filepath);
  1705. }
  1706. }
  1707. ?>