function getTimesheetSummaryReportByCompanyIdAndArrayCriteria($company_id, $filter_data, $limit = NULL, $page = NULL, $where = NULL, $order = NULL) { //$order = array( 'b.pay_period_id' => 'asc', 'b.user_id' => 'asc' ); //$order = array( 'b.pay_period_id' => 'asc','uf.last_name' => 'asc', 'b.date_stamp' => 'asc' ); /* if ( $order == NULL ) { $order = array( 'b.pay_period_id' => 'asc', 'b.user_id' => 'asc' ); $strict = FALSE; } else { $strict = TRUE; } */ if (isset($filter_data['punch_branch_ids'])) { $filter_data['punch_branch_id'] = $filter_data['punch_branch_ids']; } if (isset($filter_data['punch_department_ids'])) { $filter_data['punch_department_id'] = $filter_data['punch_department_ids']; } if (isset($filter_data['branch_ids'])) { $filter_data['branch_id'] = $filter_data['branch_ids']; } if (isset($filter_data['department_ids'])) { $filter_data['department_id'] = $filter_data['department_ids']; } $uf = new UserFactory(); $udf = new UserDateFactory(); $bf = new BranchFactory(); $df = new DepartmentFactory(); $ppf_b = new PayPeriodFactory(); $uwf = new UserWageFactory(); $pcf = new PunchControlFactory(); $pf = new PunchFactory(); $otpf = new OverTimePolicyFactory(); $apf = new AbsencePolicyFactory(); $ppf = new PremiumPolicyFactory(); $pptsvlf = new PayPeriodTimeSheetVerifyListFactory(); $ph = array('company_id' => $company_id); //Make it so employees with 0 hours still show up!! Very important! //Order dock hours first, so it can be deducted from regular time. $query = ' select b.user_id as user_id, ppf.id as pay_period_id, ppf.start_date as pay_period_start_date, ppf.end_date as pay_period_end_date, ppf.transaction_date as pay_period_transaction_date, b.date_stamp as date_stamp, a.branch_id as branch_id, a.department_id as department_id, a.status_id as status_id, a.type_id as type_id, a.over_time_policy_id as over_time_policy_id, a.absence_policy_id as absence_policy_id, a.premium_policy_id as premium_policy_id, z.hourly_rate as hourly_rate, z.labor_burden_percent as labor_burden_percent, min_punch.time_stamp as min_punch_time_stamp, max_punch.time_stamp as max_punch_time_stamp, sum(total_time) as total_time, sum(actual_total_time) as actual_total_time from ' . $this->getTable() . ' as a LEFT JOIN ' . $udf->getTable() . ' as b ON a.user_date_id = b.id LEFT JOIN ' . $uf->getTable() . ' as uf ON b.user_id = uf.id LEFT JOIN ' . $bf->getTable() . ' as bf ON a.branch_id = bf.id LEFT JOIN ' . $df->getTable() . ' as df ON a.department_id = df.id LEFT JOIN ' . $ppf_b->getTable() . ' as ppf ON b.pay_period_id = ppf.id LEFT JOIN ' . $otpf->getTable() . ' as m ON (a.over_time_policy_id = m.id AND m.deleted = 0) LEFT JOIN ' . $apf->getTable() . ' as o ON (a.absence_policy_id = o.id AND o.deleted = 0) LEFT JOIN ' . $ppf->getTable() . ' as q ON (a.premium_policy_id = q.id AND q.deleted = 0) LEFT JOIN ' . $pptsvlf->getTable() . ' as pptsvlf ON ( ppf.id = pptsvlf.pay_period_id AND b.user_id = pptsvlf.user_id AND pptsvlf.deleted = 0 ) LEFT JOIN ' . $uwf->getTable() . ' as z ON z.id = (select z.id from ' . $uwf->getTable() . ' as z where z.user_id = b.user_id and z.effective_date <= b.date_stamp and z.wage_group_id = (CASE WHEN a.over_time_policy_id > 0 THEN m.wage_group_id ELSE CASE WHEN a.absence_policy_id > 0 THEN o.wage_group_id ELSE CASE WHEN a.premium_policy_id > 0 THEN q.wage_group_id ELSE 0 END END END) and z.deleted = 0 order by z.effective_date desc limit 1) LEFT JOIN ' . $pf->getTable() . ' as min_punch ON min_punch.id = ( select pf_a.id from ' . $pf->getTable() . ' as pf_a LEFT JOIN ' . $pcf->getTable() . ' as pcf_a ON pf_a.punch_control_id = pcf_a.id WHERE pcf_a.user_date_id = a.user_date_id AND pcf_a.branch_id = a.branch_id AND pcf_a.department_id = a.department_id AND pf_a.status_id = 10 ORDER BY pf_a.time_stamp ASC LIMIT 1 ) LEFT JOIN ' . $pf->getTable() . ' as max_punch ON max_punch.id = ( select pf_a.id from ' . $pf->getTable() . ' as pf_a LEFT JOIN ' . $pcf->getTable() . ' as pcf_a ON pf_a.punch_control_id = pcf_a.id WHERE pcf_a.user_date_id = a.user_date_id AND pcf_a.branch_id = a.branch_id AND pcf_a.department_id = a.department_id AND pf_a.status_id = 20 ORDER BY pf_a.time_stamp DESC LIMIT 1 ) where uf.company_id = ? '; $query .= isset($filter_data['permission_children_ids']) ? $this->getWhereClauseSQL('uf.id', $filter_data['permission_children_ids'], 'numeric_list', $ph) : NULL; $query .= isset($filter_data['include_user_id']) ? $this->getWhereClauseSQL('uf.id', $filter_data['include_user_id'], 'numeric_list', $ph) : NULL; $query .= isset($filter_data['exclude_user_id']) ? $this->getWhereClauseSQL('uf.id', $filter_data['exclude_user_id'], 'not_numeric_list', $ph) : NULL; $query .= isset($filter_data['user_status_id']) ? $this->getWhereClauseSQL('uf.status_id', $filter_data['user_status_id'], 'numeric_list', $ph) : NULL; if (isset($filter_data['include_user_subgroups']) and (bool) $filter_data['include_user_subgroups'] == TRUE) { $uglf = new UserGroupListFactory(); $filter_data['user_group_id'] = $uglf->getByCompanyIdAndGroupIdAndSubGroupsArray($company_id, $filter_data['user_group_id'], TRUE); } $query .= isset($filter_data['user_group_id']) ? $this->getWhereClauseSQL('uf.group_id', $filter_data['user_group_id'], 'numeric_list', $ph) : NULL; $query .= isset($filter_data['default_branch_id']) ? $this->getWhereClauseSQL('uf.default_branch_id', $filter_data['default_branch_id'], 'numeric_list', $ph) : NULL; $query .= isset($filter_data['default_department_id']) ? $this->getWhereClauseSQL('uf.default_department_id', $filter_data['default_department_id'], 'numeric_list', $ph) : NULL; $query .= isset($filter_data['user_title_id']) ? $this->getWhereClauseSQL('uf.title_id', $filter_data['user_title_id'], 'numeric_list', $ph) : NULL; $query .= isset($filter_data['punch_branch_id']) ? $this->getWhereClauseSQL('a.branch_id', $filter_data['punch_branch_id'], 'numeric_list', $ph) : NULL; $query .= isset($filter_data['punch_department_id']) ? $this->getWhereClauseSQL('a.department_id', $filter_data['punch_department_id'], 'numeric_list', $ph) : NULL; $query .= isset($filter_data['pay_period_id']) ? $this->getWhereClauseSQL('b.pay_period_id', $filter_data['pay_period_id'], 'numeric_list', $ph) : NULL; $query .= isset($filter_data['pay_period_time_sheet_verify_status_id']) ? $this->getWhereClauseSQL('pptsvlf.status_id', $filter_data['pay_period_time_sheet_verify_status_id'], 'numeric_list', $ph) : NULL; $query .= isset($filter_data['tag']) ? $this->getWhereClauseSQL('uf.id', array('company_id' => $company_id, 'object_type_id' => 200, 'tag' => $filter_data['tag']), 'tag', $ph) : NULL; if (isset($filter_data['start_date']) and trim($filter_data['start_date']) != '') { $ph[] = $this->db->BindDate($filter_data['start_date']); $query .= ' AND b.date_stamp >= ?'; } if (isset($filter_data['end_date']) and trim($filter_data['end_date']) != '') { $ph[] = $this->db->BindDate($filter_data['end_date']); $query .= ' AND b.date_stamp <= ?'; } //This isn't needed as it lists every status: AND a.status_id in (10,20,30) $query .= ' AND ( a.deleted = 0 AND b.deleted = 0 ) group by b.user_id, ppf.id, ppf.start_date, ppf.end_date, ppf.transaction_date, a.branch_id, a.department_id, b.date_stamp, z.hourly_rate, z.labor_burden_percent, a.status_id, a.type_id, a.over_time_policy_id, a.absence_policy_id, a.premium_policy_id, min_punch.time_stamp, max_punch.time_stamp '; $query .= $this->getSortSQL($order, FALSE); $this->ExecuteSQL($query, $ph); //Debug::Arr($ph ,'Query: '. $query, __FILE__, __LINE__, __METHOD__,10); return $this; }
Debug::Arr($timesheet_levels, 'TimeSheet Levels', __FILE__, __LINE__, __METHOD__, 10); if (isset($selected_levels['timesheet']) and isset($timesheet_levels[$selected_levels['timesheet']])) { $timesheet_selected_level = $timesheet_levels[$selected_levels['timesheet']]; Debug::Text(' Switching Levels to Level: ' . $timesheet_selected_level, __FILE__, __LINE__, __METHOD__, 10); } elseif (isset($timesheet_levels[1])) { $timesheet_selected_level = $request_levels[1]; } else { Debug::Text('No TimeSheet Levels... Not in hierarchy?', __FILE__, __LINE__, __METHOD__, 10); $timesheet_selected_level = 0; } Debug::Text('TimeSheet Selected Level: ' . $timesheet_selected_level, __FILE__, __LINE__, __METHOD__, 10); //Get all relevant hierarchy ids $timesheet_hierarchy_user_ids = $hlf->getByUserIdAndObjectTypeIDAndLevel($current_user->getId(), 90, (int) $timesheet_selected_level); //Debug::Arr( $request_hierarchy_user_ids, 'Request Hierarchy Ids', __FILE__, __LINE__, __METHOD__,10); if (is_array($timesheet_hierarchy_user_ids) and isset($timesheet_hierarchy_user_ids['child_level']) and isset($timesheet_hierarchy_user_ids['parent_level']) and isset($timesheet_hierarchy_user_ids['current_level'])) { $pptsvlf = new PayPeriodTimeSheetVerifyListFactory(); $pptsvlf->getByUserIdListAndStatusAndLevelAndMaxLevelAndNotAuthorized($timesheet_hierarchy_user_ids['child_level'], 30, (int) $timesheet_selected_level, (int) end($timesheet_levels), NULL, NULL, NULL, $sort_array); $status_options = $pptsvlf->getOptions('status'); foreach ($pptsvlf as $pptsv_obj) { //Grab authorizations for this object. $timesheets[] = array('id' => $pptsv_obj->getId(), 'pay_period_id' => $pptsv_obj->getPayPeriod(), 'user_id' => $pptsv_obj->getUser(), 'user_full_name' => $pptsv_obj->getUserObject()->getFullName(), 'pay_period_start_date' => $pptsv_obj->getPayPeriodObject()->getStartDate(), 'pay_period_end_date' => $pptsv_obj->getPayPeriodObject()->getEndDate(), 'status_id' => $pptsv_obj->getStatus(), 'status' => $status_options[$pptsv_obj->getStatus()]); } $smarty->assign_by_ref('timesheets', $timesheets); if (isset($timesheet_levels) and is_array($timesheet_levels)) { $smarty->assign_by_ref('timesheet_levels', $timesheet_levels); $smarty->assign_by_ref('selected_timesheet_level', $timesheet_selected_level); } } else { Debug::Text('No hierarchy information found...', __FILE__, __LINE__, __METHOD__, 10); } }
} //print_r($tmp_rows); $ulf = new UserListFactory(); $utlf = new UserTitleListFactory(); $title_options = $utlf->getByCompanyIdArray($current_company->getId()); $uglf = new UserGroupListFactory(); $group_options = $uglf->getArrayByNodes(FastTree::FormatArray($uglf->getByCompanyIdArray($current_company->getId()), 'no_tree_text', TRUE)); $blf = new BranchListFactory(); $branch_options = $blf->getByCompanyIdArray($current_company->getId()); $dlf = new DepartmentListFactory(); $department_options = $dlf->getByCompanyIdArray($current_company->getId()); //Get verified timesheets //Ignore if more then one pay period is selected $verified_time_sheets = NULL; if (isset($pay_period_ids) and count($pay_period_ids) > 0) { $pptsvlf = new PayPeriodTimeSheetVerifyListFactory(); $pptsvlf->getByPayPeriodIdAndCompanyId(array_keys($pay_period_ids), $current_company->getId()); if ($pptsvlf->getRecordCount() > 0) { foreach ($pptsvlf as $pptsv_obj) { $verified_time_sheets[$pptsv_obj->getUser()][$pptsv_obj->getPayPeriod()] = $pptsv_obj->getStatus(); } } } if (isset($tmp_rows)) { $x = 0; foreach ($tmp_rows as $user_id => $data_a) { $user_obj = $ulf->getById($user_id)->getCurrent(); foreach ($data_a as $pay_period_id => $data_b) { $rows[$x]['user_id'] = $user_obj->getId(); $rows[$x]['full_name'] = $user_obj->getFullName(TRUE); $rows[$x]['employee_number'] = $user_obj->getEmployeeNumber();
unset($plf, $p_obj); } $ulf = new UserListFactory(); $utlf = new UserTitleListFactory(); $title_options = $utlf->getByCompanyIdArray($current_company->getId()); $blf = new BranchListFactory(); $branch_options = $blf->getByCompanyIdArray($current_company->getId()); $dlf = new DepartmentListFactory(); $department_options = $dlf->getByCompanyIdArray($current_company->getId()); $uglf = new UserGroupListFactory(); $group_options = $uglf->getArrayByNodes(FastTree::FormatArray($uglf->getByCompanyIdArray($current_company->getId()), 'no_tree_text', TRUE)); //Get verified timesheets //Ignore if more then one pay period is selected $verified_time_sheets = NULL; if (isset($filter_data['pay_period_ids']) and count($filter_data['pay_period_ids']) > 0) { $pptsvlf = new PayPeriodTimeSheetVerifyListFactory(); $pptsvlf->getByPayPeriodIdAndCompanyId($filter_data['pay_period_ids'][0], $current_company->getId()); if ($pptsvlf->getRecordCount() > 0) { foreach ($pptsvlf as $pptsv_obj) { $verified_time_sheets[$pptsv_obj->getUser()][$pptsv_obj->getPayPeriod()] = array('status_id' => $pptsv_obj->getStatus(), 'created_date' => $pptsv_obj->getCreatedDate()); } } } if (isset($tmp_rows)) { $i = 0; foreach ($tmp_rows as $pay_period_id => $data_a) { foreach ($data_a as $user_id => $data_b) { $user_obj = $ulf->getById($user_id)->getCurrent(); if (isset($pay_period_options[$pay_period_id])) { $rows[$i]['pay_period'] = $pay_period_options[$pay_period_id]; } else {
function getAPISearchByCompanyIdAndArrayCriteria($company_id, $filter_data, $limit = NULL, $page = NULL, $where = NULL, $order = NULL) { if ($company_id == '') { return FALSE; } if (!is_array($order)) { //Use Filter Data ordering if its set. if (isset($filter_data['sort_column']) and $filter_data['sort_order']) { $order = array(Misc::trimSortPrefix($filter_data['sort_column']) => $filter_data['sort_order']); } } $additional_order_fields = array(); $sort_column_aliases = array(); $order = $this->getColumnsFromAliases($order, $sort_column_aliases); if ($order == NULL) { $order = array('created_date' => 'desc'); $strict = FALSE; } else { //Always try to order by status first so INACTIVE employees go to the bottom. if (!isset($order['created_date'])) { $order = Misc::prependArray(array('created_date' => 'desc'), $order); } $strict = TRUE; } //Debug::Arr($order,'Order Data:', __FILE__, __LINE__, __METHOD__,10); //Debug::Arr($filter_data,'Filter Data:', __FILE__, __LINE__, __METHOD__,10); $uf = new UserFactory(); $rf = new RequestFactory(); $udf = new UserDateFactory(); $pptsvf = new PayPeriodTimeSheetVerifyListFactory(); if (getTTProductEdition() >= TT_PRODUCT_ENTERPRISE) { $uef = new UserExpenseFactory(); } $ph = array('company_id' => $company_id); $query = ' select a.*, CASE WHEN a.object_type_id = 90 THEN pptsvf.user_id ELSE ud.user_id END as user_id, y.first_name as created_by_first_name, y.middle_name as created_by_middle_name, y.last_name as created_by_last_name, z.first_name as updated_by_first_name, z.middle_name as updated_by_middle_name, z.last_name as updated_by_last_name from ' . $this->getTable() . ' as a LEFT JOIN ' . $rf->getTable() . ' as rf ON ( a.object_type_id in (1010,1020,1030,1040,1100) AND a.object_id = rf.id ) LEFT JOIN ' . $udf->getTable() . ' as ud ON ( rf.user_date_id = ud.id ) LEFT JOIN ' . $pptsvf->getTable() . ' as pptsvf ON ( a.object_type_id = 90 AND a.object_id = pptsvf.id ) '; if (getTTProductEdition() >= TT_PRODUCT_ENTERPRISE) { $query .= ' LEFT JOIN ' . $uef->getTable() . ' as uef ON ( a.object_type_id = 200 AND a.object_id = uef.id ) '; } $query .= ' LEFT JOIN ' . $uf->getTable() . ' as y ON ( a.created_by = y.id AND y.deleted = 0 ) LEFT JOIN ' . $uf->getTable() . ' as z ON ( a.updated_by = z.id AND z.deleted = 0 ) where y.company_id = ?'; $user_id_column = 'a.created_by'; if (isset($filter_data['object_type_id']) and in_array($filter_data['object_type_id'], array(1010, 1020, 1030, 1040, 1100))) { //Requests $user_id_column = 'ud.user_id'; } elseif (isset($filter_data['object_type_id']) and in_array($filter_data['object_type_id'], array(90))) { //TimeSheet $user_id_column = 'pptsvf.user_id'; } elseif (isset($filter_data['object_type_id']) and in_array($filter_data['object_type_id'], array(200))) { //Expense $user_id_column = 'uef.user_id'; } if (isset($filter_data['permission_children_ids']) and isset($filter_data['permission_children_ids'][0]) and !in_array(-1, (array) $filter_data['permission_children_ids'])) { $query .= ' AND ' . $user_id_column . ' in (' . $this->getListSQL($filter_data['permission_children_ids'], $ph) . ') '; } if (isset($filter_data['id']) and isset($filter_data['id'][0]) and !in_array(-1, (array) $filter_data['id'])) { $query .= ' AND a.id in (' . $this->getListSQL($filter_data['id'], $ph) . ') '; } if (isset($filter_data['exclude_id']) and isset($filter_data['exclude_id'][0]) and !in_array(-1, (array) $filter_data['exclude_id'])) { $query .= ' AND a.id not in (' . $this->getListSQL($filter_data['exclude_id'], $ph) . ') '; } if (isset($filter_data['object_type_id']) and isset($filter_data['object_type_id'][0]) and !in_array(-1, (array) $filter_data['object_type_id'])) { $query .= ' AND a.object_type_id in (' . $this->getListSQL($filter_data['object_type_id'], $ph) . ') '; } if (isset($filter_data['object_id']) and isset($filter_data['object_id'][0]) and !in_array(-1, (array) $filter_data['object_id'])) { $query .= ' AND a.object_id in (' . $this->getListSQL($filter_data['object_id'], $ph) . ') '; } $query .= isset($filter_data['created_by']) ? $this->getWhereClauseSQL(array('a.created_by', 'y.first_name', 'y.last_name'), $filter_data['created_by'], 'user_id_or_name', $ph) : NULL; $query .= isset($filter_data['updated_by']) ? $this->getWhereClauseSQL(array('a.updated_by', 'z.first_name', 'z.last_name'), $filter_data['updated_by'], 'user_id_or_name', $ph) : NULL; $query .= ' AND a.deleted = 0 '; $query .= $this->getWhereSQL($where); $query .= $this->getSortSQL($order, $strict, $additional_order_fields); $this->ExecuteSQL($query, $ph, $limit, $page); return $this; }
//Get all pending requests $pending_requests = 0; $rlf = new RequestListFactory(); $rlf->getSumByPayPeriodIdAndStatus($pay_period_obj->getId(), 30); if ($rlf->getRecordCount() > 0) { $pending_requests = $rlf->getCurrent()->getColumn('total'); } //Get PS Amendments. $psalf = new PayStubAmendmentListFactory(); $psalf->getByUserIdAndAuthorizedAndStartDateAndEndDate($pay_period_schedule->getUser(), TRUE, $pay_period_obj->getStartDate(), $pay_period_obj->getEndDate()); $total_ps_amendments = 0; if (is_object($psalf)) { $total_ps_amendments = $psalf->getRecordCount(); } //Get verified timesheets $pptsvlf = new PayPeriodTimeSheetVerifyListFactory(); $pptsvlf->getByPayPeriodIdAndCompanyId($pay_period_obj->getId(), $current_company->getId()); $verified_time_sheets = 0; $pending_time_sheets = 0; if ($pptsvlf->getRecordCount() > 0) { foreach ($pptsvlf as $pptsv_obj) { if ($pptsv_obj->getAuthorized() == TRUE) { $verified_time_sheets++; } elseif ($pptsv_obj->getStatus() == 30) { $pending_time_sheets++; } } } //Get total employees with time for this pay period. $udtlf = new UserDateTotalListFactory(); $total_worked_users = $udtlf->getWorkedUsersByPayPeriodId($pay_period_obj->getId());
$pptsvlf = new PayPeriodTimeSheetVerifyListFactory(); $pptsvlf->getByPayPeriodIdAndUserId($pay_period_obj->getId(), $user_id); if ($pptsvlf->getRecordCount() > 0) { $pptsv_obj = $pptsvlf->getCurrent(); $time_sheet_verify = array('id' => $pptsv_obj->getId(), 'status_id' => $pptsv_obj->getStatus(), 'status' => Option::getByKey($pptsv_obj->getStatus(), $pptsv_obj->getOptions('status')), 'pay_period_id' => $pptsv_obj->getPayPeriod(), 'user_id' => $pptsv_obj->getUser(), 'created_date' => $pptsv_obj->getCreatedDate(), 'created_by' => $pptsv_obj->getCreatedBy(), 'updated_date' => $pptsv_obj->getUpdatedDate(), 'updated_by' => $pptsv_obj->getUpdatedBy(), 'deleted_date' => $pptsv_obj->getDeletedDate(), 'deleted_by' => $pptsv_obj->getDeletedBy()); } //Check if previous pay period was verified or not $is_previous_time_sheet_verified = FALSE; $pplf = new PayPeriodListFactory(); $pplf->getPreviousPayPeriodById($pay_period_obj->getId()); if ($pplf->getRecordCount() > 0) { $previous_pay_period_obj = $pplf->getCurrent(); if ($previous_pay_period_obj->getStatus() == 20) { $is_previous_time_sheet_verified = TRUE; } else { $pptsvlf = new PayPeriodTimeSheetVerifyListFactory(); $pptsvlf->getByPayPeriodIdAndUserId($previous_pay_period_obj->getId(), $user_id); if ($pptsvlf->getRecordCount() > 0) { $pptsv_obj = $pptsvlf->getCurrent(); if ($pptsv_obj->getAuthorized() == TRUE) { $is_previous_time_sheet_verified = TRUE; } } } } else { $is_previous_time_sheet_verified = TRUE; //There is no previous pay period } unset($previous_pay_period_obj, $pptsvlf, $pptsv_obj, $pplf); } //Get pay period totals
$hlf = new HierarchyListFactory(); $hllf = new HierarchyLevelListFactory(); $timesheet_levels = $hllf->getLevelsByUserIdAndObjectTypeID($current_user->getId(), 90); Debug::Arr($timesheet_levels, 'TimeSheet Levels', __FILE__, __LINE__, __METHOD__, 10); if (isset($selected_levels['timesheet']) and isset($request_levels[$selected_levels['timesheet']])) { $timesheet_selected_level = $timesheet_levels[$selected_levels['timesheet']]; Debug::Text(' Switching Levels to Level: ' . $request_selected_level, __FILE__, __LINE__, __METHOD__, 10); } else { $timesheet_selected_level = 1; } Debug::Text('Request Selected Level: ' . $timesheet_selected_level, __FILE__, __LINE__, __METHOD__, 10); //Get all relevant hierarchy ids $timesheet_hierarchy_user_ids = $hlf->getByUserIdAndObjectTypeIDAndLevel($current_user->getId(), 90, (int) $timesheet_selected_level); //Debug::Arr( $request_hierarchy_user_ids, 'Request Hierarchy Ids', __FILE__, __LINE__, __METHOD__,10); if (is_array($timesheet_hierarchy_user_ids) and isset($timesheet_hierarchy_user_ids['child_level']) and isset($timesheet_hierarchy_user_ids['parent_level']) and isset($timesheet_hierarchy_user_ids['current_level'])) { $pptsvlf = new PayPeriodTimeSheetVerifyListFactory(); $pptsvlf->getByUserIdListAndStatusAndLevelAndMaxLevelAndNotAuthorized($timesheet_hierarchy_user_ids['child_level'], 30, (int) $timesheet_selected_level, (int) end($timesheet_levels)); //Get all IDs that need authorizing. //Only do 25 at a time, then grab more. $i = 0; $start = FALSE; foreach ($pptsvlf as $pptsv_obj) { if ($id == $pptsv_obj->getId()) { $start = TRUE; } if ($start == TRUE) { $timesheet_queue_ids[] = $pptsv_obj->getId(); } if ($i > 25) { break; }