| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 | 
							- <?php
 
- defined('IN_PHPCMS') or exit('No permission resources.');
 
- pc_base::load_app_class('admin','admin',0);
 
- pc_base::load_sys_class('form','',0);
 
- class workflow extends admin {
 
- 	private $db,$admin_db;
 
- 	public $siteid;
 
- 	function __construct() {
 
- 		parent::__construct();
 
- 		$this->db = pc_base::load_model('workflow_model');
 
- 		$this->admin_db = pc_base::load_model('admin_model');
 
- 		$this->siteid = $this->get_siteid();
 
- 	}
 
- 	
 
- 	public function init () {
 
- 		$datas = array();
 
- 		$result_datas = $this->db->listinfo(array('siteid'=>$this->siteid));
 
- 		foreach($result_datas as $r) {
 
- 			$datas[] = $r;
 
- 		}
 
- 		$this->cache();
 
- 		include $this->admin_tpl('workflow_list');
 
- 	}
 
- 	public function add() {
 
- 		if(isset($_POST['dosubmit'])) {
 
- 			
 
- 			$_POST['info']['siteid'] = $this->siteid;
 
- 			$_POST['info']['workname'] = safe_replace($_POST['info']['workname']);
 
- 			$setting[1] = $_POST['checkadmin1'];
 
- 			$setting[2] = $_POST['checkadmin2'];
 
- 			$setting[3] = $_POST['checkadmin3'];
 
- 			$setting[4] = $_POST['checkadmin4'];
 
- 			$setting['nocheck_users'] = $_POST['nocheck_users'];
 
- 			$setting = array2string($setting);
 
- 			$_POST['info']['setting'] = $setting;
 
- 			
 
- 			$this->db->insert($_POST['info']);
 
- 			$this->cache();
 
- 			showmessage(L('add_success'));
 
- 		} else {
 
- 			$show_validator = '';
 
- 			$admin_data = array();
 
- 			$result = $this->admin_db->select();
 
- 			foreach($result as $_value) {
 
- 				if($_value['roleid']==1) continue;
 
- 				$admin_data[$_value['username']] = $_value['username'];
 
- 			}
 
- 			include $this->admin_tpl('workflow_add');
 
- 		}
 
- 	}
 
- 	public function edit() {
 
- 		if(isset($_POST['dosubmit'])) {
 
- 			$workflowid = intval($_POST['workflowid']);
 
- 			
 
- 			$_POST['info']['workname'] = safe_replace($_POST['info']['workname']);
 
- 			$setting[1] = $_POST['checkadmin1'];
 
- 			$setting[2] = $_POST['checkadmin2'];
 
- 			$setting[3] = $_POST['checkadmin3'];
 
- 			$setting[4] = $_POST['checkadmin4'];
 
- 			$setting['nocheck_users'] = $_POST['nocheck_users'];
 
- 			$setting = array2string($setting);
 
- 			$_POST['info']['setting'] = $setting;
 
- 			$this->db->update($_POST['info'],array('workflowid'=>$workflowid));
 
- 			$this->cache();
 
- 			showmessage(L('update_success'), '', '', 'edit');
 
- 		} else {
 
- 			$show_header = $show_validator = '';
 
- 			$workflowid = intval($_GET['workflowid']);
 
- 			$admin_data = array();
 
- 			$result = $this->admin_db->select();
 
- 			foreach($result as $_value) {
 
- 				if($_value['roleid']==1) continue;
 
- 				$admin_data[$_value['username']] = $_value['username'];
 
- 			}
 
- 			$r = $this->db->get_one(array('workflowid'=>$workflowid));
 
- 			extract($r);
 
- 			$setting = string2array($setting);
 
- 			$checkadmin1 = $this->implode_ids($setting[1]);
 
- 			$checkadmin2 = $this->implode_ids($setting[2]);
 
- 			$checkadmin3 = $this->implode_ids($setting[3]);
 
- 			$checkadmin4 = $this->implode_ids($setting[4]);
 
- 			$nocheck_users = $this->implode_ids($setting['nocheck_users']);
 
- 			
 
- 			include $this->admin_tpl('workflow_edit');
 
- 		}
 
- 	}
 
- 	public function view() {
 
- 			$show_header = '';
 
- 			$workflowid = intval($_GET['workflowid']);
 
- 			$admin_data = array();
 
- 			$result = $this->admin_db->select();
 
- 			foreach($result as $_value) {
 
- 				if($_value['roleid']==1) continue;
 
- 				$admin_data[$_value['username']] = $_value['username'];
 
- 			}
 
- 			$r = $this->db->get_one(array('workflowid'=>$workflowid));
 
- 			extract($r);
 
- 			$setting = string2array($setting);
 
- 			$checkadmin1 = $this->implode_ids($setting[1],'、');
 
- 			$checkadmin2 = $this->implode_ids($setting[2],'、');
 
- 			$checkadmin3 = $this->implode_ids($setting[3],'、');
 
- 			$checkadmin4 = $this->implode_ids($setting[4],'、');
 
- 			
 
- 			include $this->admin_tpl('workflow_view');
 
- 	}
 
- 	public function delete() {
 
- 		$_GET['workflowid'] = intval($_GET['workflowid']);
 
- 		$this->db->delete(array('workflowid'=>$_GET['workflowid']));
 
- 		$this->cache();
 
- 		exit('1');
 
- 	}
 
- 	
 
- 	
 
- 	public function cache() {
 
- 		$datas = array();
 
- 		$workflow_datas = $this->db->select(array('siteid'=>$this->siteid),'*',1000);
 
- 		foreach($workflow_datas as $_k=>$_v) {
 
- 			$datas[$_v['workflowid']] = $_v;
 
- 		}
 
- 		setcache('workflow_'.$this->siteid,$datas,'commons');
 
- 		return true;
 
- 	}
 
- 	/**
 
- 	 * 用逗号分隔数组
 
- 	 */
 
- 	private function implode_ids($array, $flags = ',') {
 
- 		if(empty($array)) return true;
 
- 		$length = strlen($flags);
 
- 		$string = '';
 
- 		foreach($array as $_v) {
 
- 			$string .= $_v.$flags;
 
- 		}
 
- 		return substr($string,0,-$length);
 
- 	}
 
- }
 
- ?>
 
 
  |