X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=DataObjects%2FCore_company.php;h=aaf08e29908ecd8d48b2d3cdf8239aa9764ffccb;hb=b02a820041af130c0bc572177baa9b52d5526188;hp=17c657ce334cab7091afebd1ff5b7d5da0f975b0;hpb=ac063d4fc41c55738e6b88e90ac1b5c325db765f;p=Pman.Core diff --git a/DataObjects/Core_company.php b/DataObjects/Core_company.php index 17c657ce..aaf08e29 100644 --- a/DataObjects/Core_company.php +++ b/DataObjects/Core_company.php @@ -240,13 +240,29 @@ class Pman_Core_DataObjects_Core_Company extends DB_DataObject $this->update(); } - - - + } + + function beforeInsert($q, $roo) + { + if(!empty($q['_check_name'])){ + if($this->checkName()){ + $roo->jok('OK'); + } + + $roo->jerr('EXIST'); + } } function beforeUpdate($old, $q,$roo) { + if(!empty($q['_check_name'])){ + if($this->checkName()){ + $roo->jok('OK'); + } + + $roo->jerr('EXIST'); + } + if(!empty($q['_merge_id'])){ $this->merge($q['_merge_id'], $roo); } @@ -466,4 +482,22 @@ class Pman_Core_DataObjects_Core_Company extends DB_DataObject $roo->jok('Merged'); } + + function checkName() + { + $company = DB_DataObject::factory('core_company'); + $company->setFrom(array( + 'name' => $this->name + )); + + if(!empty($this->id)){ + $company->whereAdd("id != {$this->id}"); + } + + if(!$company->find(true)){ + return true; + } + + return false; + } }