123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- <?php
- /**
- * Define a Fiche employé
- * @author Administrateur PRINCIPAL
- * @category Plugin
- * @license MIT
- */
- class Employee extends Entity{
- public $id;
- public $photo; //Photo (Image)
- public $birthName; //Nom de naissance (Texte)
- public $name; //Nom marital (Texte)
- public $firstname; //Prénom (Texte)
- public $job; //Poste (Liste configurable)
- public $jobDescription; //Rôle/Missions (Texte enrichis)
- public $manager; //Responsable (Employee)
- public $account; //Responsable (Utilisateur)
- public $workplace; //Lieu de travail (Adresse)
- public $hardware; //Mise a disposition de matériel (Liste configurable)
- public $comment; //Comment (Wysiwyg)
- public $state; //Etat (Texte)
- protected $TABLE_NAME = 'employee';
- public $entityLabel = 'Fiche employé';
- public $fields = array(
- 'id' => array('type'=>'key', 'label' => 'Identifiant'),
- 'birthName' => array('type'=>'text', 'label' => 'Nom de naissance'),
- 'name' => array('type'=>'text', 'label' => 'Nom marital'),
- 'firstname' => array('type'=>'text', 'label' => 'Prénom'),
- 'job' => array('type'=>'dictionary', 'label' => 'Poste'),
- 'jobDescription' => array('type'=>'wysiwyg', 'label' => 'Rôle/Missions'),
- 'manager' => array('type'=>'integer','label' => 'Responsable','link'=>'plugin/employee/Employee.class.php'),
- 'account' => array('type'=>'user','label' => 'Compte lié'),
- 'workplace' => array('type'=>'address', 'label' => 'Lieu de travail'),
- 'hardware' => array('type'=>'longstring', 'label' => 'Mise a disposition de matériel'),
- 'comment' => array('type'=>'wysiwyg', 'label' => 'Information sur le recrutement'),
- 'state' => array('type'=>'text', 'label' => 'Etat'),
- );
- public function picture(){
- $pictures = glob(File::dir().'employee/employee/'.$this->id.'/photo.*');
- return !empty($pictures) ? $pictures[0] : '';
- }
- //Surchage de toArray pour prendre en compte le fullName et les initials régulierement utilisé en toArray
- public function toArray($decoded=false) {
- $fields = parent::toArray($decoded);
- $fields['fullName'] = $this->fullName();
- if($decoded){
- $fields['fullName'] = html_entity_decode($fields['fullName']);
- }
- return $fields;
- }
- public function fullName(){
- return ucfirst(mb_strtolower($this->firstname)).' '.mb_strtoupper($this->name);
- }
- //managers récursifs de l'employé ciblé
- public static function managers($employee){
- $alloweds = array();
- $alloweds[] = $employee;
- if(!empty($employee->manager) && $employee->manager!=$employee->id){
- $alloweds = array_merge($alloweds,self::managers(Employee::getById($employee->manager)));
- }
- return $alloweds;
- }
- //suboordonés récursifs de l'employé ciblé
- public static function subordinates($employee,$employees = null,$recursive = true){
- $subordinates = array();
- if(!isset($employee) || empty($employee->id)) return $subordinates;
- if(!isset($employees)){
- $employees = array();
- foreach(self::loadAll() as $item){
- if(!isset($employees[$item->manager])) $employees[$item->manager] = array();
- $employees[$item->manager][$item->id] = $item;
- }
- }
- $currentSubordinates = isset($employees[$employee->id]) ? $employees[$employee->id] : array();
- foreach($currentSubordinates as $subordinate){
- $subordinates[$subordinate->id] = $subordinate;
- if($recursive) $subordinates = array_merge($subordinates,self::subordinates($subordinate,$employees));
- }
- return $subordinates;
- }
- public function can($targetEmployee,$crud){
- //Droits de visibilité sur la fiche :
- // - L'admin configure dans tous les cas
- // - Le créateur de la fiche si pas de manager renseigné
- // - Le manager si renseigné
- $user = User::byLogin($this->account);
- if($user->can('employee','configure')) return true;
- if(!$user->can('employee',$crud)) return false;
- $hierarchy = array();
- foreach(Employee::subordinates($this) as $subordinate){
- $subordinatesIds[] = $subordinate->id;
- }
- $subordinatesIds[] = $this->id;
- if(empty($targetEmployee->manager) && $targetEmployee->creator==$user->login) return true;
- if(!in_array($targetEmployee->manager,$subordinatesIds)) return false;
- return true;
- }
- public function currentContract(){
- require_once(__DIR__.SLASH.'EmployeeContract.class.php');
- require_once(__DIR__.SLASH.'EmployeeWorkTime.class.php');
- $contract = new EmployeeContract();
- $contracts = EmployeeContract::staticQuery('SELECT main.*,'.EmployeeWorkTime::joinString('wt').','.Dictionary::joinString('ty').' FROM {{table}} main
- LEFT JOIN '.EmployeeWorkTime::tableName().' wt ON main.worktime = wt.id
- LEFT JOIN '.Dictionary::tableName().' ty ON main.type = ty.id
- WHERE (main.`end` IS NULL OR main.`end` = "" OR main.`end` > ?) AND main.employee=? LIMIT 1',array(time(),$this->id),true,1);
- if(isset($contracts[0])) $contract = $contracts[0];
- return $contract;
- }
- public function photo(){
- if(count(glob(File::dir().SLASH.'employee'.SLASH.'employee'.SLASH.$this->id.SLASH.'photo.*')) ==0 ) return 'img/default-avatar.png';
- return 'action.php?action=employee_employee_photo&type=download&path='.base64_encode('employee/employee/'.$this->id.'/photo.*');
- }
- //Colonnes indexées
- public $indexes = array();
- }
- ?>
|