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();
Esempio n. 4
0
     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;
    }
Esempio n. 6
0
 //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;
         }