174 lines
5.0 KiB
PHP
174 lines
5.0 KiB
PHP
<?php
|
|
/**
|
|
* The model file of company module of ZenTaoPMS.
|
|
*
|
|
* @copyright Copyright 2009-2015 禅道软件(青岛)有限公司(ZenTao Software (Qingdao) Co., Ltd. www.cnezsoft.com)
|
|
* @license ZPL(http://zpl.pub/page/zplv12.html) or AGPL(https://www.gnu.org/licenses/agpl-3.0.en.html)
|
|
* @author Chunsheng Wang <chunsheng@cnezsoft.com>
|
|
* @package company
|
|
* @version $Id: model.php 5086 2013-07-10 02:25:22Z wyd621@gmail.com $
|
|
* @link http://www.zentao.net
|
|
*/
|
|
?>
|
|
<?php
|
|
class companyModel extends model
|
|
{
|
|
/**
|
|
* Set menu.
|
|
*
|
|
* @param int $dept
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function setMenu($dept = 0)
|
|
{
|
|
/*
|
|
common::setMenuVars($this->lang->company->menu, 'name', array($this->app->company->name));
|
|
common::setMenuVars($this->lang->company->menu, 'addUser', array($dept));
|
|
common::setMenuVars($this->lang->company->menu, 'batchAddUser', array($dept));
|
|
*/
|
|
}
|
|
|
|
/**
|
|
* Get company list.
|
|
*
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function getList()
|
|
{
|
|
return $this->dao->select('*')->from(TABLE_COMPANY)->fetchAll();
|
|
}
|
|
|
|
/**
|
|
* Get the first company.
|
|
*
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function getFirst()
|
|
{
|
|
return $this->dao->select('*')->from(TABLE_COMPANY)->orderBy('id')->limit(1)->fetch();
|
|
}
|
|
|
|
/**
|
|
* Get company info by id.
|
|
*
|
|
* @param int $companyID
|
|
* @access public
|
|
* @return object
|
|
*/
|
|
public function getByID($companyID = '')
|
|
{
|
|
return $this->dao->findById((int)$companyID)->from(TABLE_COMPANY)->fetch();
|
|
}
|
|
|
|
/**
|
|
* Get users.
|
|
*
|
|
* @param string $browseType
|
|
* @param string $type
|
|
* @param int $queryID
|
|
* @param int $deptID
|
|
* @param string $sort
|
|
* @param object $pager
|
|
* @access public
|
|
* @return array
|
|
*/
|
|
public function getUsers($browseType = 'inside', $type = '', $queryID = 0, $deptID = 0, $sort = '', $pager = null)
|
|
{
|
|
/* Get users. */
|
|
if($type == 'bydept')
|
|
{
|
|
$childDeptIds = $this->loadModel('dept')->getAllChildID($deptID);
|
|
return $this->dept->getUsers($browseType, $childDeptIds, $pager, $sort);
|
|
}
|
|
else
|
|
{
|
|
if($queryID)
|
|
{
|
|
$query = $this->loadModel('search')->getQuery($queryID);
|
|
if($query)
|
|
{
|
|
$this->session->set('userQuery', $query->sql);
|
|
$this->session->set('userForm', $query->form);
|
|
}
|
|
else
|
|
{
|
|
$this->session->set('userQuery', ' 1 = 1');
|
|
}
|
|
}
|
|
return $this->loadModel('user')->getByQuery($browseType, $this->session->userQuery, $pager, $sort);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get outside companies.
|
|
*
|
|
* @access public
|
|
* @return array
|
|
*/
|
|
public function getOutsideCompanies()
|
|
{
|
|
$companies = $this->dao->select('id, name')->from(TABLE_COMPANY)->where('id')->ne(1)->fetchPairs();
|
|
return array('' => '') + $companies;
|
|
}
|
|
|
|
/**
|
|
* Get company-user pairs.
|
|
*
|
|
* @access public
|
|
* @return array
|
|
*/
|
|
public function getCompanyUserPairs()
|
|
{
|
|
$pairs = $this->dao->select("t1.account, CONCAT_WS('/', t2.name, t1.realname)")->from(TABLE_USER)->alias('t1')
|
|
->leftJoin(TABLE_COMPANY)->alias('t2')
|
|
->on('t1.company = t2.id')
|
|
->fetchPairs();
|
|
|
|
return $pairs;
|
|
}
|
|
|
|
/**
|
|
* Update a company.
|
|
*
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function update()
|
|
{
|
|
$company = fixer::input('post')
|
|
->stripTags('name')
|
|
->get();
|
|
if($company->website == 'http://') $company->website = '';
|
|
if($company->backyard == 'http://') $company->backyard = '';
|
|
$companyID = $this->app->company->id;
|
|
$this->dao->update(TABLE_COMPANY)
|
|
->data($company)
|
|
->autoCheck()
|
|
->batchCheck($this->config->company->edit->requiredFields, 'notempty')
|
|
->batchCheck('name', 'unique', "id != '$companyID'")
|
|
->where('id')->eq($companyID)
|
|
->exec();
|
|
}
|
|
|
|
/**
|
|
* Build search form.
|
|
*
|
|
* @param int $queryID
|
|
* @param string $actionURL
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function buildSearchForm($queryID, $actionURL)
|
|
{
|
|
$this->config->company->browse->search['actionURL'] = $actionURL;
|
|
$this->config->company->browse->search['queryID'] = $queryID;
|
|
$this->config->company->browse->search['params']['dept']['values'] = array('' => '') + $this->loadModel('dept')->getOptionMenu();
|
|
$this->config->company->browse->search['params']['visions']['values'] = $this->loadModel('user')->getVisionList();
|
|
|
|
$this->loadModel('search')->setSearchParams($this->config->company->browse->search);
|
|
}
|
|
}
|