> * @since 1.0.0 */ protected static array $columns = [ 'hr_staff_id' => ['name' => 'hr_staff_id', 'type' => 'int', 'internal' => 'id'], 'hr_staff_profile' => ['name' => 'hr_staff_profile', 'type' => 'int', 'internal' => 'profile'], 'hr_staff_smiPHash' => ['name' => 'hr_staff_smiPHash', 'type' => 'string', 'internal' => 'semiPrivateHash'], 'hr_staff_image' => ['name' => 'hr_staff_image', 'type' => 'int', 'internal' => 'image', 'annotations' => ['gdpr' => true]], ]; /** * Belongs to. * * @var array> * @since 1.0.0 */ protected static array $belongsTo = [ 'profile' => [ 'mapper' => ProfileMapper::class, 'src' => 'hr_staff_profile', ], ]; /** * Has many relation. * * @var array> * @since 1.0.0 */ protected static array $hasMany = [ 'companyHistory' => [ 'mapper' => EmployeeHistoryMapper::class, 'table' => 'hr_staff_history', 'dst' => 'hr_staff_history_staff', 'src' => null, ], ]; /** * Primary table. * * @var string * @since 1.0.0 */ protected static string $table = 'hr_staff'; /** * Primary field name. * * @var string * @since 1.0.0 */ protected static string $primaryField = 'hr_staff_id'; /** * Get the employee from an account * * @param int $account Account to get the employee for * * @return Employee * * @since 1.0.0 */ public static function getFromAccount(int $account) : Employee { $query = new Builder(self::$db); $query->prefix(self::$db->getPrefix()) ->select(self::$table . '.*') ->from(self::$table) ->innerJoin(ProfileMapper::getTable()) ->on(self::$table . '.hr_staff_profile', '=', ProfileMapper::getTable() . '.' . ProfileMapper::getPrimaryField()) ->innerJoin(AccountMapper::getTable()) ->on(ProfileMapper::getTable() . '.profile_account_account', '=', AccountMapper::getTable() . '.' . AccountMapper::getPrimaryField()) ->where(AccountMapper::getTable() . '.' . AccountMapper::getPrimaryField(), '=', $account) ->limit(1); $employee = self::getAllByQuery($query); return empty($employee) ? new NullEmployee() : \end($employee); } }