123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997 |
- <?php
- //ini_set('display_errors', on);
- Doo::loadClass('auth');
- Doo::loadClass('attfile');
- Doo::loadClass('profile');
- Doo::loadClass('project');
- Doo::loadClass('contractact');
- Doo::loadClass('actmeasure');
- Doo::loadClass('numofperact');
- Doo::loadClass('measureauditact');
- Doo::loadClass('sign');
- Doo::loadModelAt('aconfig', 'admin');
- //define('FPDF_FONTPATH','protected/class/fpdf1.5/font/');
- //Doo::loadClass('fpdf');
- /* * proDetail
- * MainController
- * Feel free to delete the methods and replace them with your own code.
- *
- * @author darkredz
- */
- class SignController extends DooController
- {
- 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>');
- public function beforeRun($resource, $action)
- {
- if ($this->auth->getUid()) {
- $uGroups = $this->profile->getProWithUid($this->auth->getUid());
- $falg = Doo::acl()->isAllowed($uGroups['groups'], $resource, $action);
- if (!$falg)
- return Doo::acl()->defaultFailedRoute;
- } else {
- return Doo::acl()->defaultFailedRoute;
- }
- }
- public function __construct()
- {
- $this->aconfig = new AConfig();
- $this->auth = new Auth();
- $this->attfile = new attFile();
- $this->profile = new Profile();
- $this->project = new Project();
- $this->contractact = new Contractact();
- $this->actmeasure = new actMeasure();
- $this->numofperact = new NumofperAct();
- $this->measureauditact = new MeasureauditAct();
- $this->sign = new Signn();
- // $this->pdf = new FPDF('P','mm','A4');
- $this->data['rootUrl'] = Doo::conf()->APP_URL;
- $this->data['currChannle'] = 'sign';
- $this->data['user'] = $this->profile->getProWithUid($this->auth->getUid());
- $mpidArray = $this->measureauditact->getAuditProject2($this->auth->getUid());
- $this->data['numofchecking'] = 0;
- if (isset($mpidArray[0]['pid'])) {
- foreach ($mpidArray as $key => $value) {
- // 审批操作按照时间排序多标段
- $this->data['numofchecking'] += $this->measureauditact->getCountMyChecking($value['pid'], $this->auth->getUid());
- }
- }
- if (!isset($this->data['numofchecking']) || $this->data['numofchecking'] == 0) {
- $this->data['numofchecking'] = null;
- }
- $signSwitch = $this->aconfig->getOne(array('select' => 'signswitch', 'asArray' => TRUE))['signswitch'];
- if ($signSwitch == 0)
- exit('未开启在线签名功能');
- $this->data['signSwitch'] = $signSwitch;
- //获取需要您签署的数目
- $this->data['needSignNum'] = $this->sign->getNeedSignNumbyUid($this->auth->getUid()) != 0 ? $this->sign->getNeedSignNumbyUid($this->auth->getUid()) : '';
- //获取桌面版本
- $this->getsoftware();
- }
- function getsoftware(){
- $StrJson = ($this->aconfig->getOne(array('select' => 'upgradeinfo', 'asArray' => TRUE))['upgradeinfo']);
- $upgradeinfo = json_decode($StrJson, true);
- if ($upgradeinfo) {
- $this->data['version'] = $upgradeinfo['version'];
- $this->data['download'] = $upgradeinfo['download'];
- }
- }
- /**
- *
- * @return type
- */
- public function index()
- {
- //获取我发起的签署数目
- $this->data['mySignNum'] = $this->sign->getMySignNumbyUid($this->auth->getUid());
- //获取关于我的正在签署数目
- $this->data['doingSignNum'] = $this->sign->getDoingSignNumbyUid($this->auth->getUid());
- //获取关于我的完成签署数目
- $this->data['doneSignNum'] = $this->sign->getDoneSignNumbyUid($this->auth->getUid());
- $this->data['launchsign'] = $this->aconfig->getOne(array('select' => 'launchsignswitch', 'asArray' => TRUE))['launchsignswitch'];
- $this->render('sign-index', $this->data, TRUE);
- }
- public function signNeedList(){
- $needlist = array();
- $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().')';
- $projectlist = $this->sign->getSignGroupByProject($searchsql);
- if(!empty($projectlist)){
- foreach($projectlist as $k => $v){
- $projectmsg = $this->project->getRowByPid($v['project']);
- $needlist[$k]['project'] = $projectmsg['pname'];
- $needlist[$k]['tlist'] = array();
- $tenderlist = $this->sign->getSignGroupByTender($v['project'],$searchsql);
- if(!empty($tenderlist)) {
- foreach ($tenderlist as $tk => $tv) {
- $tendermsg = $this->actmeasure->getRowByPmid($tv['tender']);
- $needlist[$k]['tlist'][$tk]['tender'] = $tendermsg['pmname'];
- $needlist[$k]['tlist'][$tk]['plist'] = array();
- $phasenolist = $this->sign->getSignGroupByPhaseno($tv['tender'],$searchsql);
- if(!empty($phasenolist)) {
- foreach ($phasenolist as $pk => $pv) {
- // $phasenomsg = $this->numofperact->getCurrStatus($pv['phaseno']);
- $needlist[$k]['tlist'][$tk]['plist'][$pk]['phaseno'] = $pv['phaseno'];
- $needlist[$k]['tlist'][$tk]['plist'][$pk]['signlist'] = array();
- $signlist = $this->sign->getSignList($searchsql.' and status="checking" and tender='.$tv['tender'].' and phaseno='.$pv['phaseno'], '0,1000');
- if(!empty($signlist)) {
- foreach ($signlist as $sk => $sv) {
- $needlist[$k]['tlist'][$tk]['plist'][$pk]['signlist'][$sk]['sid'] = $sv['sid'];
- $needlist[$k]['tlist'][$tk]['plist'][$pk]['signlist'][$sk]['name'] = $sv['name'];
- $needlist[$k]['tlist'][$tk]['plist'][$pk]['signlist'][$sk]['auditlist'] = $this->sign->getSignAuditlist($sv['sid']);
- }
- }
- }
- }
- }
- }
- }
- }
- $this->data['needlist'] = $needlist;
- $this->render('sign-list-need_sign',$this->data, TRUE);
- }
- public function signNeedView(){
- if(!isset($this->params['sid']) || !is_numeric($this->params['sid'])){
- exit('没有报表参数');
- }
- $issign = $this->sign->getisSignbySidUid($this->params['sid'],$this->auth->getUid());
- if(empty($issign)){
- exit('不是当前签署人无法访问本页');
- }
- //获取报表信息
- $signmsg = $this->sign->getOneSignbysid($this->params['sid']);
- //获取项目名,标段名,标段期数
- $project = $this->project->getRowByPid($signmsg['project']);
- $tender = $this->actmeasure->getRowByPmid($signmsg['tender']);
- // $phaseno = $this->numofperact->getCurrStatus($signmsg['phaseno']);
- $signmsg['project'] = $project['pname'];
- $signmsg['tender'] = $tender['pmname'];
- // $signmsg['phaseno'] = $phaseno['numpname'];
- //获取签署人列表
- $signauditlist = $this->sign->getSignAuditList($this->params['sid']);
- if(!empty($signauditlist)){
- foreach($signauditlist as $k => $v){
- //获取签署人头像
- $signauditlist[$k]['index'] = $k+1;
- $signauditlist[$k]['avatar'] = $this->auth->getAvatar($v['audituid']);
- }
- }
- //获取报表图片
- $maxwidth = 794; //默认图片最大宽度 a4
- $maxheight = 1123; //默认图片最大高度 a4
- if(!empty($signmsg['widhei'])){
- $widhei = explode('_', $signmsg['widhei']);
- $style = $widhei[0].'mm '.$widhei[1].'mm';
- }else{
- $style = '210mm 297mm';
- }
- $signattlist = $this->sign->getSignAttList($this->params['sid']);
- if(!empty($signattlist)){
- foreach($signattlist as $sak => $sav){
- $signattlist[$sak]['auditatt'] = $this->sign->getSignAuditAttList($sav['said']);
- if($sak == 0){
- $imgmsg = getimagesize(Doo::conf()->APP_URL.$sav['filepath']);
- $maxwidth = $imgmsg[0];
- $maxheight = $imgmsg[1];
- }
- }
- }
- $this->data['signmsg'] = $signmsg;
- $this->data['auditlist'] = $signauditlist;
- $this->data['attlist'] = $signattlist;
- $this->data['picpath'] = $this->auth->getSignpath($this->auth->getUid());
- $this->data['signsid'] = $this->params['sid'];
- $this->data['maxwidth'] = $maxwidth;
- $this->data['maxheight'] = $maxheight;
- $this->data['style'] = $style;
- $this->render('sign-view-signer_sign',$this->data, TRUE);
- }
- public function signDone(){
- if(!isset($_POST['sid']) || !is_numeric($_POST['sid'])){
- echo json_encode(array('code' => 400, 'msg' => '没有报表参数'));
- exit;
- }
- if(!isset($_POST['path']) || empty($_POST['path'])){
- echo json_encode(array('code' => 400, 'msg' => '没有签名图片'));
- exit;
- }
- //改变签署状态并判断报表是否签署完成或传到下一个签署人签署
- $signAudit = $this->sign->getOneSignAudit($_POST['sid'],$this->auth->getUid());
- $result = $this->sign->updateSignAudit($signAudit['satid'],'checked');
- foreach($_POST['said'] as $satk => $satv){
- $sign3 = new Signn();
- $sign3->insertSignAuditAtt($this->auth->getUid(),$satv,$_POST['path'],$_POST['position'][$satk]);
- }
- if($result){
- $sign2 = new Signn();
- $signAuditList = $sign2->getSignAuditList($_POST['sid']);
- $flag = true;
- foreach($signAuditList as $k => $v){
- if($v['status'] == 'uncheck'){
- $sign2->updateSignAudit($v['satid'],'checking');
- $flag = false;
- break;
- }
- }
- if($flag){
- $this->sign->updateSignStatus($_POST['sid']);
- echo json_encode(array('code' => 200, 'url' => '/sign/view/'.$_POST['sid'].'?status=done'));
- exit;
- }else{
- echo json_encode(array('code' => 200, 'url' => '/sign/view/'.$_POST['sid'].'?status=doing'));
- exit;
- }
- }else{
- echo json_encode(array('code' => 400, 'msg' => '签署失败'));
- exit;
- }
- }
- public function signMyList(){
- Doo::loadHelper('DooPager');
- $pagestr = '';
- $sqlstr = ' 1';
- $this->data['project'] = '';
- $this->data['tender'] = '';
- $this->data['phaseno'] = '';
- //获取项目信息
- $searchsql = 'audituid='.$this->auth->getUid();
- $itemlist = $this->sign->getSignGroupByProject($searchsql);
- if(!empty($itemlist)){
- foreach($itemlist as $ik => $iv){
- $itemmsg = $this->project->getRowByPid($iv['project']);
- $itemlist[$ik]['pname'] = $itemmsg['pname'];
- }
- }
- if(isset($this->params['pid']) && is_numeric($this->params['pid'])){
- $this->data['project'] = $this->params['pid'];
- $pagestr .= '/project/'.$this->params['pid'];
- $sqlstr .= ' and project='.$this->params['pid'];
- //获取标段信息
- $tenderlist = $this->sign->getSignGroupByTender($this->params['pid'],$searchsql);
- if(!empty($tenderlist)){
- foreach($tenderlist as $tk => $tv){
- $tendermsg = $this->actmeasure->getRowByPmid($tv['tender']);
- $tenderlist[$tk]['pmname'] = $tendermsg['pmname'];
- }
- }
- if(isset($this->params['pmid']) && is_numeric($this->params['pmid'])){
- $this->data['tender'] = $this->params['pmid'];
- $pagestr .= '/tender/'.$this->params['pmid'];
- $sqlstr .= ' and tender='.$this->params['pmid'];
- //获取期数信息
- $phasenolist = $this->sign->getSignGroupByPhaseno($this->params['pmid'],$searchsql);
- if(!empty($phasenolist)){
- foreach($phasenolist as $pk => $pv){
- // $phasenomsg = $this->numofperact->getCurrStatus($pv['phaseno']);
- $phasenolist[$pk]['numpname'] = $pv['phaseno'];
- }
- }
- if(isset($this->params['mpid']) && is_numeric($this->params['mpid'])){
- $this->data['phaseno'] = $this->params['mpid'];
- $pagestr .= '/phaseno/'.$this->params['mpid'];
- $sqlstr .= ' and phaseno='.$this->params['mpid'];
- }
- }
- }
- $totalArchive = $this->sign->getMySignNumbyUid($this->auth->getUid(),$sqlstr);
- $pager = new DooPager(Doo::conf()->APP_URL . 'sign/mylist'.$pagestr.'/page', $totalArchive, 10, 100);
- $pager->setCss('', 'disabled', 'active');
- if (isset($this->params['pindex']))
- $pager->paginate(intval($this->params['pindex']));
- else
- $pager->paginate(1);
- if ($pager->limit != ' -10,10')
- $mylist = $this->sign->getMySignListbyUid($this->auth->getUid(), $sqlstr, $pager->limit);
- if(isset($mylist) && !empty($mylist)){
- foreach($mylist as $k => $v){
- //获取项目名,标段名,标段期数
- $project = $this->project->getRowByPid($v['project']);
- $tender = $this->actmeasure->getRowByPmid($v['tender']);
- // $phaseno = $this->numofperact->getCurrStatus($v['phaseno']);
- $mylist[$k]['project'] = $project['pname'];
- $mylist[$k]['tender'] = $tender['pmname'];
- // $mylist[$k]['phaseno'] = $phaseno['numpname'];
- }
- }
- $this->data['mylist'] = isset($mylist) ? $mylist : '';
- $this->data['itemlist'] = $itemlist;
- $this->data['tenderlist'] = isset($tenderlist) ? $tenderlist : '';
- $this->data['phasenolist'] = isset($phasenolist) ? $phasenolist : '';
- $this->data['pager'] = $pager->output;
- $this->render('sign-list-my_create',$this->data, TRUE);
- }
- public function signChangeShare(){
- if(!isset($_GET['status']) || !isset($_GET['sid'])){
- echo json_encode(array('code' => '400', 'msg' => '请传递正确的参数'));
- exit;
- }
- $status = $_GET['status'] == "true" ? 1 : 0;
- $result = $this->sign->updateSignShareStatus($status,$_GET['sid']);
- if($result){
- echo json_encode(array('code' => '200', 'status' => $status));
- exit;
- }else{
- echo json_encode(array('code' => '400', 'msg' => '无法分享'));
- exit;
- }
- exit;
- }
- public function signOnList(){
- Doo::loadHelper('DooPager');
- $pagestr = '';
- $sqlstr = ' 1';
- $this->data['project'] = '';
- $this->data['tender'] = '';
- $this->data['phaseno'] = '';
- //获取项目信息
- $searchsql = 'status="checking" and sid in(select `jl_sign_audit`.sid from `jl_sign_audit` where `jl_sign_audit`.audituid='.$this->auth->getUid().')';
- $itemlist = $this->sign->getSignGroupByProject($searchsql);
- if(!empty($itemlist)){
- foreach($itemlist as $ik => $iv){
- $itemmsg = $this->project->getRowByPid($iv['project']);
- $itemlist[$ik]['pname'] = $itemmsg['pname'];
- }
- }
- if(isset($this->params['pid']) && is_numeric($this->params['pid'])){
- $this->data['project'] = $this->params['pid'];
- $pagestr .= '/project/'.$this->params['pid'];
- $sqlstr .= ' and project='.$this->params['pid'];
- //获取标段信息
- $tenderlist = $this->sign->getSignGroupByTender($this->params['pid'],$searchsql);
- if(!empty($tenderlist)){
- foreach($tenderlist as $tk => $tv){
- $tendermsg = $this->actmeasure->getRowByPmid($tv['tender']);
- $tenderlist[$tk]['pmname'] = $tendermsg['pmname'];
- }
- }
- if(isset($this->params['pmid']) && is_numeric($this->params['pmid'])){
- $this->data['tender'] = $this->params['pmid'];
- $pagestr .= '/tender/'.$this->params['pmid'];
- $sqlstr .= ' and tender='.$this->params['pmid'];
- //获取期数信息
- $phasenolist = $this->sign->getSignGroupByPhaseno($this->params['pmid'],$searchsql);
- if(!empty($phasenolist)){
- foreach($phasenolist as $pk => $pv){
- // $phasenomsg = $this->numofperact->getCurrStatus($pv['phaseno']);
- $phasenolist[$pk]['numpname'] = $pv['phaseno'];
- }
- }
- if(isset($this->params['mpid']) && is_numeric($this->params['mpid'])){
- $this->data['phaseno'] = $this->params['mpid'];
- $pagestr .= '/phaseno/'.$this->params['mpid'];
- $sqlstr .= ' and phaseno='.$this->params['mpid'];
- }
- }
- }
- $totalArchive = $this->sign->getDoingSignNumbyUid($this->auth->getUid(),$sqlstr);
- $pager = new DooPager(Doo::conf()->APP_URL . 'sign/onlist'.$pagestr.'/page', $totalArchive, 10, 100);
- $pager->setCss('', 'disabled', 'active');
- if (isset($this->params['pindex']))
- $pager->paginate(intval($this->params['pindex']));
- else
- $pager->paginate(1);
- if ($pager->limit != ' -10,10')
- $onlist = $this->sign->getDoingSignListbyUid($this->auth->getUid(), $sqlstr, $pager->limit);
- if(isset($onlist) && !empty($onlist)){
- foreach($onlist as $k => $v){
- //获取项目名,标段名,标段期数
- $project = $this->project->getRowByPid($v['project']);
- $tender = $this->actmeasure->getRowByPmid($v['tender']);
- // $phaseno = $this->numofperact->getCurrStatus($v['phaseno']);
- $onlist[$k]['project'] = $project['pname'];
- $onlist[$k]['tender'] = $tender['pmname'];
- // $onlist[$k]['phaseno'] = $phaseno['numpname'];
- $onlist[$k]['auditlist'] = $this->sign->getSignAuditList($v['sid']);
- }
- }
- $this->data['onlist'] = isset($onlist) ? $onlist : '';
- $this->data['itemlist'] = $itemlist;
- $this->data['tenderlist'] = isset($tenderlist) ? $tenderlist : '';
- $this->data['phasenolist'] = isset($phasenolist) ? $phasenolist : '';
- $this->data['pager'] = $pager->output;
- $this->render('sign-list-on_sign',$this->data, TRUE);
- }
- public function signDoneList(){
- Doo::loadHelper('DooPager');
- $pagestr = '';
- $sqlstr = ' 1';
- $this->data['project'] = '';
- $this->data['tender'] = '';
- $this->data['phaseno'] = '';
- //获取项目信息
- $searchsql = 'status="checked" and sid in(select `jl_sign_audit`.sid from `jl_sign_audit` where `jl_sign_audit`.audituid='.$this->auth->getUid().')';
- $itemlist = $this->sign->getSignGroupByProject($searchsql);
- if(!empty($itemlist)){
- foreach($itemlist as $ik => $iv){
- $itemmsg = $this->project->getRowByPid($iv['project']);
- $itemlist[$ik]['pname'] = $itemmsg['pname'];
- }
- }
- if(isset($this->params['pid']) && is_numeric($this->params['pid'])){
- $this->data['project'] = $this->params['pid'];
- $pagestr .= '/project/'.$this->params['pid'];
- $sqlstr .= ' and project='.$this->params['pid'];
- //获取标段信息
- $tenderlist = $this->sign->getSignGroupByTender($this->params['pid'],$searchsql);
- if(!empty($tenderlist)){
- foreach($tenderlist as $tk => $tv){
- $tendermsg = $this->actmeasure->getRowByPmid($tv['tender']);
- $tenderlist[$tk]['pmname'] = $tendermsg['pmname'];
- }
- }
- if(isset($this->params['pmid']) && is_numeric($this->params['pmid'])){
- $this->data['tender'] = $this->params['pmid'];
- $pagestr .= '/tender/'.$this->params['pmid'];
- $sqlstr .= ' and tender='.$this->params['pmid'];
- //获取期数信息
- $phasenolist = $this->sign->getSignGroupByPhaseno($this->params['pmid'],$searchsql);
- if(!empty($phasenolist)){
- foreach($phasenolist as $pk => $pv){
- // $phasenomsg = $this->numofperact->getCurrStatus($pv['phaseno']);
- $phasenolist[$pk]['numpname'] = $pv['phaseno'];
- }
- }
- if(isset($this->params['mpid']) && is_numeric($this->params['mpid'])){
- $this->data['phaseno'] = $this->params['mpid'];
- $pagestr .= '/phaseno/'.$this->params['mpid'];
- $sqlstr .= ' and phaseno='.$this->params['mpid'];
- }
- }
- }
- $totalArchive = $this->sign->getDoneSignNumbyUid($this->auth->getUid(),$sqlstr);
- $pager = new DooPager(Doo::conf()->APP_URL . 'sign/donelist'.$pagestr.'/page', $totalArchive, 10, 100);
- $pager->setCss('', 'disabled', 'active');
- if (isset($this->params['pindex']))
- $pager->paginate(intval($this->params['pindex']));
- else
- $pager->paginate(1);
- if ($pager->limit != ' -10,10')
- $donelist = $this->sign->getDoneSignListbyUid($this->auth->getUid(), $sqlstr, $pager->limit);
- if(isset($donelist) && !empty($donelist)){
- foreach($donelist as $k => $v){
- //获取项目名,标段名,标段期数
- $project = $this->project->getRowByPid($v['project']);
- $tender = $this->actmeasure->getRowByPmid($v['tender']);
- // $phaseno = $this->numofperact->getCurrStatus($v['phaseno']);
- $donelist[$k]['project'] = $project['pname'];
- $donelist[$k]['tender'] = $tender['pmname'];
- // $donelist[$k]['phaseno'] = $phaseno['numpname'];
- }
- }
- $this->data['donelist'] = isset($donelist) ? $donelist : '';
- $this->data['itemlist'] = $itemlist;
- $this->data['tenderlist'] = isset($tenderlist) ? $tenderlist : '';
- $this->data['phasenolist'] = isset($phasenolist) ? $phasenolist : '';
- $this->data['pager'] = $pager->output;
- $this->render('sign-list-done_sign',$this->data, TRUE);
- }
- /**
- *
- * @return type
- */
- public function signCreate()
- {
- $launchsignSwitch = $this->aconfig->getOne(array('select' => 'launchsignswitch', 'asArray' => TRUE))['launchsignswitch'];
- if($launchsignSwitch == 0)
- exit('未开启发起签署功能');
- Doo::loadHelper('DooPager');
- $pagestr = '';
- $sqlstr = ' 1';
- $this->data['project'] = '';
- $this->data['tender'] = '';
- $this->data['phaseno'] = '';
- //获取项目信息
- $searchsql = 'status="uncheck" AND (`ownuid`='.$this->auth->getUid().' OR tender IN (SELECT pmid FROM jl_measure_audit WHERE auditoruid='.$this->auth->getUid().'))';
- $itemlist = $this->sign->getSignGroupByProject($searchsql);
- if(!empty($itemlist)){
- foreach($itemlist as $ik => $iv){
- $itemmsg = $this->project->getRowByPid($iv['project']);
- $itemlist[$ik]['pname'] = $itemmsg['pname'];
- }
- }
- if(isset($this->params['pid']) && is_numeric($this->params['pid'])){
- $this->data['project'] = $this->params['pid'];
- $pagestr .= '/project/'.$this->params['pid'];
- $sqlstr .= ' and project='.$this->params['pid'];
- //获取标段信息
- $tenderlist = $this->sign->getSignGroupByTender($this->params['pid'], $searchsql);
- if(!empty($tenderlist)){
- foreach($tenderlist as $tk => $tv){
- $tendermsg = $this->actmeasure->getRowByPmid($tv['tender']);
- $tenderlist[$tk]['pmname'] = $tendermsg['pmname'];
- }
- }
- if(isset($this->params['pmid']) && is_numeric($this->params['pmid'])){
- $this->data['tender'] = $this->params['pmid'];
- $pagestr .= '/tender/'.$this->params['pmid'];
- $sqlstr .= ' and tender='.$this->params['pmid'];
- //获取期数信息
- $phasenolist = $this->sign->getSignGroupByPhaseno($this->params['pmid'], $searchsql);
- if(!empty($phasenolist)){
- foreach($phasenolist as $pk => $pv){
- // $phasenomsg = $this->numofperact->getCurrStatus($pv['phaseno']);
- $phasenolist[$pk]['numpname'] = $pv['phaseno'];
- }
- }
- if(isset($this->params['mpid']) && is_numeric($this->params['mpid'])){
- $this->data['phaseno'] = $this->params['mpid'];
- $pagestr .= '/phaseno/'.$this->params['mpid'];
- $sqlstr .= ' and phaseno='.$this->params['mpid'];
- }
- }
- }
- $totalArchive = $this->sign->getUnSignNum($sqlstr,$this->auth->getUid());
- $pager = new DooPager(Doo::conf()->APP_URL . 'sign/create'.$pagestr.'/page', $totalArchive, 10, 100);
- $pager->setCss('', 'disabled', 'active');
- if (isset($this->params['pindex']))
- $pager->paginate(intval($this->params['pindex']));
- else
- $pager->paginate(1);
- if ($pager->limit != ' -10,10')
- $unlist = $this->sign->getUnSignList($sqlstr, $this->auth->getUid(), $pager->limit);
- if(isset($unlist) && !empty($unlist)){
- foreach($unlist as $k => $v){
- //获取项目名,标段名,标段期数
- $project = $this->project->getRowByPid($v['project']);
- $tender = $this->actmeasure->getRowByPmid($v['tender']);
- // $phaseno = $this->numofperact->getCurrStatus($v['phaseno']);
- $unlist[$k]['project'] = $project['pname'];
- $unlist[$k]['tender'] = $tender['pmname'];
- // $unlist[$k]['phaseno'] = $phaseno['numpname'];
- $unlist[$k]['ownname'] = $this->auth->getName($v['ownuid']);
- }
- }
- $this->data['unlist'] = isset($unlist) ? $unlist : '';
- $this->data['itemlist'] = $itemlist;
- $this->data['tenderlist'] = isset($tenderlist) ? $tenderlist : '';
- $this->data['phasenolist'] = isset($phasenolist) ? $phasenolist : '';
- $this->data['pager'] = $pager->output;
- $this->render('sign-create_sign', $this->data, TRUE);
- }
- /**
- *
- * @return type
- */
- public function signList()
- {
- if(isset($_POST['delid']) && is_numeric($_POST['delid'])){
- //删除未签署报表数据和文件
- $signmsg = $this->sign->getOneSignbysid($_POST['delid']);
- if(empty($signmsg) && $signmsg['status'] == "checked" && ($signmsg['ownuid'] != $this->auth->getUid() || $signmsg['audituid'] != $this->auth->getUid())){
- exit(json_encode(array('code' => 400),JSON_UNESCAPED_UNICODE));
- }
- $this->sign->delSignbysid($_POST['delid'],$signmsg['status']);
- include (DOO::conf()->SITE_PATH . 'protected/plugin/io.han.php');
- $this->IoHandler = new IoHandler();
- $path = DOO::conf()->SITE_PATH."signs/".$_POST['delid'];
- $this->IoHandler->RemoveDir($path);
- exit(json_encode(array('code' => 200),JSON_UNESCAPED_UNICODE));
- }
- Doo::loadHelper('DooPager');
- $pagestr = '';
- $sqlstr = ' 1';
- $this->data['project'] = '';
- $this->data['tender'] = '';
- $this->data['phaseno'] = '';
- $this->data['nosign'] = '';
- //获取项目信息
- $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().'))';
- $itemlist = $this->sign->getSignGroupByProject($searchsql);
- if(!empty($itemlist)){
- foreach($itemlist as $ik => $iv){
- $itemmsg = $this->project->getRowByPid($iv['project']);
- $itemlist[$ik]['pname'] = $itemmsg['pname'];
- }
- }
- if(isset($this->params['pid']) && is_numeric($this->params['pid'])){
- $this->data['project'] = $this->params['pid'];
- $pagestr .= '/project/'.$this->params['pid'];
- $sqlstr .= ' and project='.$this->params['pid'];
- //获取标段信息
- $tenderlist = $this->sign->getSignGroupByTender($this->params['pid'],$searchsql);
- if(!empty($tenderlist)){
- foreach($tenderlist as $tk => $tv){
- $tendermsg = $this->actmeasure->getRowByPmid($tv['tender']);
- $tenderlist[$tk]['pmname'] = $tendermsg['pmname'];
- }
- }
- if(isset($this->params['pmid']) && is_numeric($this->params['pmid'])){
- $this->data['tender'] = $this->params['pmid'];
- $pagestr .= '/tender/'.$this->params['pmid'];
- $sqlstr .= ' and tender='.$this->params['pmid'];
- //获取期数信息
- $phasenolist = $this->sign->getSignGroupByPhaseno($this->params['pmid'],$searchsql);
- if(!empty($phasenolist)){
- foreach($phasenolist as $pk => $pv){
- // $phasenomsg = $this->numofperact->getCurrStatus($pv['phaseno']);
- $phasenolist[$pk]['numpname'] = $pv['phaseno'];
- }
- }
- if(isset($this->params['mpid']) && is_numeric($this->params['mpid'])){
- $this->data['phaseno'] = $this->params['mpid'];
- $pagestr .= '/phaseno/'.$this->params['mpid'];
- $sqlstr .= ' and phaseno='.$this->params['mpid'];
- }
- }
- }
- if((isset($this->params['nosign']) && ($this->params['nosign'] == 'nosign')) || isset($_GET['nosign'])){
- $this->data['nosign'] = 1;
- $pagestr .= '/nosign';
- $searchsql = '(`ownuid`='.$this->auth->getUid().' AND `status`="uncheck")';
- }
- $totalArchive = $this->sign->getSignNum($sqlstr.' and '.$searchsql);
- $pager = new DooPager(Doo::conf()->APP_URL . 'sign/list'.$pagestr.'/page', $totalArchive, 10, 100);
- $pager->setCss('', 'disabled', 'active');
- if (isset($this->params['pindex']))
- $pager->paginate(intval($this->params['pindex']));
- else
- $pager->paginate(1);
- if ($pager->limit != ' -10,10')
- $list = $this->sign->getSignList($sqlstr.' and '.$searchsql,$pager->limit);
- if(isset($list) && !empty($list)){
- foreach($list as $k => $v){
- //获取项目名,标段名,标段期数
- $project = $this->project->getRowByPid($v['project']);
- $tender = $this->actmeasure->getRowByPmid($v['tender']);
- // $phaseno = $this->numofperact->getCurrStatus($v['phaseno']);
- $list[$k]['project'] = $project['pname'];
- $list[$k]['tender'] = $tender['pmname'];
- // $list[$k]['phaseno'] = $phaseno['numpname'];
- $list[$k]['ownname'] = $this->auth->getName($v['ownuid']);
- $list[$k]['auditname'] = $this->auth->getName($v['audituid']);
- $list[$k]['delstatus'] = ($this->auth->getUid() == $v['ownuid'] || $this->auth->getUid() == $v['audituid']) && $v['status'] != 'checked' ? 1 : 0;
- }
- }
- $this->data['list'] = isset($list) ? $list : '';
- $this->data['itemlist'] = $itemlist;
- $this->data['tenderlist'] = isset($tenderlist) ? $tenderlist : '';
- $this->data['phasenolist'] = isset($phasenolist) ? $phasenolist : '';
- $this->data['pager'] = $pager->output;
- $this->render('sign-list-all', $this->data, TRUE);
- }
- /**
- *
- * @return type
- */
- public function signSignSet()
- {
- $launchsignSwitch = $this->aconfig->getOne(array('select' => 'launchsignswitch', 'asArray' => TRUE))['launchsignswitch'];
- if($launchsignSwitch == 0)
- exit('未开启发起签署功能');
- if(!isset($this->params['sid']) || !is_numeric($this->params['sid'])){
- exit('没有报表参数');
- }
- //获取报表信息
- $signmsg = $this->sign->getOneSignbysid($this->params['sid']);
- //获取标段审批人列表
- $auditactlist = $this->measureauditact->getUserAuditLast($signmsg['tender'],$signmsg['phaseno']);
- $userlist = array();
- if(!empty($auditactlist)){
- foreach($auditactlist as $k => $v){
- $usermsg = $this->auth->getRowByUid($v['auditoruid']);
- $userlist[$k]['userid'] = $usermsg['userid'];
- $userlist[$k]['name'] = $usermsg['name'];
- $userlist[$k]['jobs'] = $usermsg['jobs'];
- $userlist[$k]['avatar'] = $usermsg['avatar'];
- }
- }
- //获取原报人
- $measureArray = $this->actmeasure->getRowByPmid($signmsg['tender']);
- // $lastRowArray = $this->numofperact->getLastNew2($signmsg['tender']);
- $usermsg2 = $this->auth->getRowByUid($measureArray['uid']);
- $orginArray['userid'] = $measureArray['uid'];
- $orginArray['avatar'] = $usermsg2['avatar'];
- $orginArray['name'] = $usermsg2['name'];
- $orginArray['jobs'] = $usermsg2['jobs'];
- // $attfileArray = $this->attfile->getFirstFile($lastRowArray['pmid'], $lastRowArray['numpname'], $lastRowArray['times']);
- // $orginArray['time'] = date('Y-m-d', $attfileArray['intime']);
- //获取项目名,标段名,标段期数
- $project = $this->project->getRowByPid($signmsg['project']);
- $tender = $this->actmeasure->getRowByPmid($signmsg['tender']);
- // $phaseno = $this->numofperact->getCurrStatus($signmsg['phaseno']);
- $signmsg['project'] = $project['pname'];
- $signmsg['tender'] = $tender['pmname'];
- // $signmsg['phaseno'] = $phaseno['numpname'];
- //获取报表图片
- $maxwidth = 794; //默认图片最大宽度 a4
- $maxheight = 1123; //默认图片最大高度 a4
- if(!empty($signmsg['widhei'])){
- $widhei = explode('_', $signmsg['widhei']);
- $style = $widhei[0].'mm '.$widhei[1].'mm';
- }else{
- $style = '210mm 297mm';
- }
- $signattlist = $this->sign->getSignAttList($this->params['sid']);
- if(!empty($signattlist)){
- foreach($signattlist as $sak => $sav){
- if($sak == 0){
- $imgmsg = getimagesize(Doo::conf()->APP_URL.$sav['filepath']);
- $maxwidth = $imgmsg[0];
- $maxheight = $imgmsg[1];
- break;
- }
- }
- }
- $this->data['signmsg'] = $signmsg;
- $this->data['userlist'] = $userlist;
- $this->data['attlist'] = $signattlist;
- $this->data['reportlist'] = $orginArray;
- $this->data['maxwidth'] = $maxwidth;
- $this->data['maxheight'] = $maxheight;
- $this->data['style'] = $style;
- $this->render('sign-view-set_signer', $this->data, TRUE);
- }
- public function signSearchUser(){
- if(!isset($_GET['email']) || empty($_GET['email'])){
- echo json_encode(array('code' => 400, 'msg' => '请输入邮箱地址'));
- exit;
- }
- $usermsg = $this->auth->checkUserEmail($_GET['email']);
- if(!empty($usermsg)){
- echo json_encode(array('code' => 200, 'user' => $usermsg));
- exit;
- }else{
- echo json_encode(array('code' => 400, 'msg' => '没有此邮箱用户'));
- exit;
- }
- }
- public function signUpSigner(){
- if(!isset($_POST['ids']) || !isset($_POST['names']) || !isset($_POST['sid']) || !is_numeric($_POST['sid'])){
- echo json_encode(array('code' => 400, 'msg' => '上传参数有误'));
- exit;
- }
- $useridarr = $_POST['ids'];
- $usernamearr = $_POST['names'];
- foreach($useridarr as $k => $v){
- $signs = new Signn();
- $status = $k != 0 ? 'uncheck' : 'checking';
- $result = $signs->insertSignAudit($_POST['sid'],$status,$v,$usernamearr[$k]);
- if(empty($result)){
- echo json_encode(array('code' => 400, 'msg' => '添加签署人出错'));
- exit;
- }
- }
- //更新报表信息
- $result2 = $this->sign->updateSignMsg($_POST['sid'],$this->auth->getUid());
- if(!empty($result2)){
- echo json_encode(array('code' => 200, 'msg' => '添加成功'));
- exit;
- }else{
- echo json_encode(array('code' => 400, 'msg' => '添加签署人出错'));
- exit;
- }
- }
- /**
- *
- * @return type
- */
- public function signView()
- {
- if(!isset($this->params['sid']) || !is_numeric($this->params['sid'])){
- exit('没有报表参数');
- }
- //获取报表信息
- $signmsg = $this->sign->getOneSignbysid($this->params['sid']);
- //获取项目名,标段名,标段期数
- $project = $this->project->getRowByPid($signmsg['project']);
- $tender = $this->actmeasure->getRowByPmid($signmsg['tender']);
- // $phaseno = $this->numofperact->getCurrStatus($signmsg['phaseno']);
- $signmsg['project'] = $project['pname'];
- $signmsg['tender'] = $tender['pmname'];
- // $signmsg['phaseno'] = $phaseno['numpname'];
- //获取签署人列表
- $signauditlist = $this->sign->getSignAuditList($this->params['sid']);
- if(!empty($signauditlist)){
- foreach($signauditlist as $k => $v){
- //获取签署人头像
- $signauditlist[$k]['index'] = $k+1;
- $signauditlist[$k]['avatar'] = $this->auth->getAvatar($v['audituid']);
- }
- }
- //获取报表图片
- $maxwidth = 794; //默认图片最大宽度 a4
- $maxheight = 1123; //默认图片最大高度 a4
- if(!empty($signmsg['widhei'])){
- $widhei = explode('_', $signmsg['widhei']);
- $style = $widhei[0].'mm '.$widhei[1].'mm';
- }else{
- $style = '210mm 297mm';
- }
- $signattlist = $this->sign->getSignAttList($this->params['sid']);
- if(!empty($signattlist)){
- foreach($signattlist as $sak => $sav){
- $signattlist[$sak]['auditatt'] = $this->sign->getSignAuditAttList($sav['said']);
- if($sak == 0){
- $imgmsg = getimagesize(Doo::conf()->APP_URL.$sav['filepath']);
- $maxwidth = $imgmsg[0];
- $maxheight = $imgmsg[1];
- }
- }
- }
- $backurl = '/sign/list';
- if(isset($_GET['status'])){
- switch($_GET['status']){
- case 'done' : $backurl = '/sign/donelist';break;
- case 'doing' : $backurl = '/sign/onlist';break;
- case 'mylist' : $backurl = '/sign/mylist';break;
- case 'onlist' : $backurl = '/sign/onlist';break;
- case 'donelist' : $backurl = '/sign/donelist';break;
- default: $backurl = '/sign/list';break;
- }
- }
- $this->data['signmsg'] = $signmsg;
- $this->data['auditlist'] = $signauditlist;
- $this->data['attlist'] = $signattlist;
- $this->data['backurl'] = $backurl;
- $this->data['maxwidth'] = $maxwidth;
- $this->data['maxheight'] = $maxheight;
- $this->data['style'] = $style;
- $this->render('sign-view-page', $this->data, TRUE);
- }
- public function substr_replace_cn($string, $repalce = '*', $start = 0, $len = 0)
- {
- $count = mb_strlen($string, 'UTF-8'); //此处传入编码,建议使用utf-8。此处编码要与下面mb_substr()所使用的一致
- if (!$count) {
- return $string;
- }
- if ($len == 0) {
- $end = $count; //传入0则替换到最后
- } else {
- $end = $start + $len; //传入指定长度则为开始长度+指定长度
- }
- $i = 0;
- $returnString = '';
- while ($i < $count) { //循环该字符串
- $tmpString = mb_substr($string, $i, 1, 'UTF-8'); // 与mb_strlen编码一致
- if ($start <= $i && $i < $end) {
- $returnString .= $repalce;
- } else {
- $returnString .= $tmpString;
- }
- $i++;
- }
- return $returnString;
- }
- function unicode_encode($name)
- {//to Unicode
- $name = iconv('UTF-8', 'UCS-2', $name);
- $len = strlen($name);
- $str = '';
- for ($i = 0; $i < $len - 1; $i = $i + 2) {
- $c = $name[$i];
- $c2 = $name[$i + 1];
- if (ord($c) > 0) {// 两个字节的字
- $str .= '\\' . base_convert(ord($c), 10, 16) . base_convert(ord($c2), 10, 16);
- } else {
- $str .= $c2;
- }
- }
- $str = strtoupper($str);
- return $str;
- }
- function unicode_decode($name)
- {//Unicode to
- $pattern = '/([\w]+)|(\\\u([\w]{4}))/i';
- preg_match_all($pattern, $name, $matches);
- if (!empty($matches)) {
- $name = '';
- for ($j = 0; $j < count($matches[0]); $j++) {
- $str = $matches[0][$j];
- if (strpos($str, '\\u') === 0) {
- $code = base_convert(substr($str, 2, 2), 16, 10);
- $code2 = base_convert(substr($str, 4), 16, 10);
- $c = chr($code) . chr($code2);
- $c = iconv('UCS-2', 'UTF-8', $c);
- $name .= $c;
- } else {
- $name .= $str;
- }
- }
- }
- return $name;
- }
- }
- ?>
|