getPermissionObject()->Check( 'accrual', 'enabled' ) || !( $this->getPermissionObject()->Check( 'accrual', 'view' ) || $this->getPermissionObject()->Check( 'accrual', 'view_child' ) ) ) ) { $name = 'list_columns'; } return parent::getOptions( $name, $parent ); } /** * Get accrual balance data for one or more accrual balancees. * @param array $data filter data * @param bool $disable_paging * @return array|bool */ function getAccrualBalance( $data = null, $disable_paging = false ) { $data = $this->initializeFilterAndPager( $data, $disable_paging ); if ( !$this->getPermissionObject()->Check( 'accrual', 'enabled' ) || !( $this->getPermissionObject()->Check( 'accrual', 'view' ) || $this->getPermissionObject()->Check( 'accrual', 'view_own' ) || $this->getPermissionObject()->Check( 'accrual', 'view_child' ) ) ) { return $this->getPermissionObject()->PermissionDenied(); } $data['filter_data']['permission_children_ids'] = $this->getPermissionObject()->getPermissionChildren( 'accrual', 'view' ); $blf = TTnew( 'AccrualBalanceListFactory' ); /** @var AccrualBalanceListFactory $blf */ $blf->getAPISearchByCompanyIdAndArrayCriteria( $this->getCurrentCompanyObject()->getId(), $data['filter_data'], $data['filter_items_per_page'], $data['filter_page'], null, $data['filter_sort'] ); Debug::Text( 'Record Count: ' . $blf->getRecordCount(), __FILE__, __LINE__, __METHOD__, 10 ); if ( $blf->getRecordCount() > 0 ) { $this->getProgressBarObject()->start( $this->getAPIMessageID(), $blf->getRecordCount() ); $this->setPagerObject( $blf ); $retarr = []; foreach ( $blf as $b_obj ) { $retarr[] = $b_obj->getObjectAsArray( $data['filter_columns'], $data['filter_data']['permission_children_ids'] ); $this->getProgressBarObject()->set( $this->getAPIMessageID(), $blf->getCurrentRow() ); } $this->getProgressBarObject()->stop( $this->getAPIMessageID() ); return $this->returnHandler( $retarr ); } return $this->returnHandler( true ); //No records returned. } /** * Gets the accrual balance data for a given policy account and depending on requested type releases the accrual balance. * @param string $accrual_policy_account_id uuid * @param string $user_id uuid * @param int $type_id * @return array */ function getAccrualBalanceAndRelease( $accrual_policy_account_id, $user_id, $type_id ) { $result = $this->stripReturnHandler( $this->getAccrualBalance( [ 'filter_data' => [ 'accrual_policy_account_id' => $accrual_policy_account_id, 'user_id' => $user_id ] ] ) ); if ( is_array( $result ) and count( $result ) > 0 ) { $balance = $result[0]['balance']; $af = TTnew( 'AccrualFactory' ); /** @var AccrualFactory $af */ $af->setType( $type_id ); if ( $af->isValidAmount( $balance ) ) { $retval = $balance; } else { //Return opposite sign if balance is not a valid amount for time. $retval = ( $balance < 0 ) ? abs( $balance ) : bcmul( $balance, -1 ); } return $this->returnHandler( $retval ); } return $this->returnHandler( 0 ); //No Balance. } /** * Export data to csv * @param string $format file format (csv) * @param array $data filter data * @param bool $disable_paging * @return array */ function exportAccrualBalance( $format = 'csv', $data = null, $disable_paging = true ) { $result = $this->stripReturnHandler( $this->getAccrualBalance( $data, $disable_paging ) ); return $this->exportRecords( $format, 'export_accrual_balance', $result, ( ( isset( $data['filter_columns'] ) ) ? $data['filter_columns'] : null ) ); } } ?>