mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-25 02:19:21 -04:00 
			
		
		
		
	Add filters to Bank Integrations
This commit is contained in:
		
							parent
							
								
									8f44f647c3
								
							
						
					
					
						commit
						52a01cb924
					
				| @ -98,7 +98,8 @@ class Kernel extends ConsoleKernel | ||||
| 
 | ||||
|             $schedule->job(new AdjustEmailQuota)->dailyAt('23:30')->withoutOverlapping(); | ||||
| 
 | ||||
|             $schedule->job(new SendFailedEmails)->daily()->withoutOverlapping(); | ||||
|             //not used @deprecate
 | ||||
|             // $schedule->job(new SendFailedEmails)->daily()->withoutOverlapping();
 | ||||
| 
 | ||||
|             $schedule->command('ninja:check-data --database=db-ninja-01')->daily('02:00')->withoutOverlapping(); | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										133
									
								
								app/Filters/BankIntegrationFilters.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										133
									
								
								app/Filters/BankIntegrationFilters.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,133 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Invoice Ninja (https://invoiceninja.com). | ||||
|  * | ||||
|  * @link https://github.com/invoiceninja/invoiceninja source repository | ||||
|  * | ||||
|  * @copyright Copyright (c) 2022. Invoice Ninja LLC (https://invoiceninja.com) | ||||
|  * | ||||
|  * @license https://www.elastic.co/licensing/elastic-license | ||||
|  */ | ||||
| 
 | ||||
| namespace App\Filters; | ||||
| 
 | ||||
| use App\Models\BankIntegration; | ||||
| use App\Models\User; | ||||
| use Illuminate\Database\Eloquent\Builder; | ||||
| use Illuminate\Support\Facades\DB; | ||||
| use Illuminate\Support\Facades\Gate; | ||||
| 
 | ||||
| /** | ||||
|  * BankIntegrationFilters. | ||||
|  */ | ||||
| class BankIntegrationFilters extends QueryFilters | ||||
| { | ||||
|     /** | ||||
|      * Filter by name. | ||||
|      * | ||||
|      * @param string $name | ||||
|      * @return Builder | ||||
|      */ | ||||
|     public function name(string $name = ''): Builder | ||||
|     { | ||||
|         if(strlen($name) >=1) | ||||
|             return $this->builder->where('bank_account_name', 'like', '%'.$name.'%'); | ||||
| 
 | ||||
|         return $this->builder; | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Filter based on search text. | ||||
|      * | ||||
|      * @param string query filter | ||||
|      * @return Builder | ||||
|      * @deprecated | ||||
|      */ | ||||
|     public function filter(string $filter = '') : Builder | ||||
|     { | ||||
|         if (strlen($filter) == 0) { | ||||
|             return $this->builder; | ||||
|         } | ||||
| 
 | ||||
|         return  $this->builder->where(function ($query) use ($filter) { | ||||
|             $query->where('bank_integrations.bank_account_name', 'like', '%'.$filter.'%'); | ||||
|         }); | ||||
| 
 | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Filters the list based on the status | ||||
|      * archived, active, deleted. | ||||
|      * | ||||
|      * @param string filter | ||||
|      * @return Builder | ||||
|      */ | ||||
|     public function status(string $filter = '') : Builder | ||||
|     { | ||||
|         if (strlen($filter) == 0) { | ||||
|             return $this->builder; | ||||
|         } | ||||
| 
 | ||||
|         $table = 'bank_integrations'; | ||||
|         $filters = explode(',', $filter); | ||||
| 
 | ||||
|         return $this->builder->where(function ($query) use ($filters, $table) { | ||||
|             $query->whereNull($table.'.id'); | ||||
| 
 | ||||
|             if (in_array(parent::STATUS_ACTIVE, $filters)) { | ||||
|                 $query->orWhereNull($table.'.deleted_at'); | ||||
|             } | ||||
| 
 | ||||
|             if (in_array(parent::STATUS_ARCHIVED, $filters)) { | ||||
|                 $query->orWhere(function ($query) use ($table) { | ||||
|                     $query->whereNotNull($table.'.deleted_at'); | ||||
| 
 | ||||
|                     if (! in_array($table, ['users'])) { | ||||
|                         $query->where($table.'.is_deleted', '=', 0); | ||||
|                     } | ||||
|                 }); | ||||
|             } | ||||
| 
 | ||||
|             if (in_array(parent::STATUS_DELETED, $filters)) { | ||||
|                 $query->orWhere($table.'.is_deleted', '=', 1); | ||||
|             } | ||||
|         }); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Sorts the list based on $sort. | ||||
|      * | ||||
|      * @param string sort formatted as column|asc | ||||
|      * @return Builder | ||||
|      */ | ||||
|     public function sort(string $sort) : Builder | ||||
|     { | ||||
|         $sort_col = explode('|', $sort); | ||||
|          | ||||
|         return $this->builder->orderBy($sort_col[0], $sort_col[1]); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Returns the base query. | ||||
|      * | ||||
|      * @param int company_id | ||||
|      * @param User $user | ||||
|      * @return Builder | ||||
|      * @deprecated | ||||
|      */ | ||||
|     public function baseQuery(int $company_id, User $user) : Builder | ||||
|     { | ||||
| 
 | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Filters the query by the users company ID. | ||||
|      * | ||||
|      * @return Illuminate\Database\Query\Builder | ||||
|      */ | ||||
|     public function entityFilter() | ||||
|     { | ||||
|         //return $this->builder->whereCompanyId(auth()->user()->company()->id);
 | ||||
|         return $this->builder->company(); | ||||
|     } | ||||
| } | ||||
| @ -12,6 +12,7 @@ | ||||
| namespace App\Http\Controllers; | ||||
| 
 | ||||
| use App\Factory\BankIntegrationFactory; | ||||
| use App\Filters\BankIntegrationFilters; | ||||
| use App\Helpers\Bank\Yodlee\Yodlee; | ||||
| use App\Http\Requests\BankIntegration\AdminBankIntegrationRequest; | ||||
| use App\Http\Requests\BankIntegration\CreateBankIntegrationRequest; | ||||
| @ -91,10 +92,10 @@ class BankIntegrationController extends BaseController | ||||
|      * @param Request $request | ||||
|      * @return Response|mixed | ||||
|      */ | ||||
|     public function index(Request $request) | ||||
|     public function index(BankIntegrationFilters $filters) | ||||
|     { | ||||
| 
 | ||||
|         $bank_integrations = BankIntegration::query()->company(); | ||||
|         $bank_integrations = BankIntegration::filter($filters); | ||||
| 
 | ||||
|         return $this->listResponse($bank_integrations); | ||||
| 
 | ||||
|  | ||||
| @ -11,11 +11,13 @@ | ||||
| 
 | ||||
| namespace App\Models; | ||||
| 
 | ||||
| use App\Models\Filterable; | ||||
| use Illuminate\Database\Eloquent\SoftDeletes; | ||||
| 
 | ||||
| class BankIntegration extends BaseModel | ||||
| { | ||||
|     use SoftDeletes; | ||||
|     use Filterable; | ||||
| 
 | ||||
|     protected $fillable = [ | ||||
|         'bank_account_name', | ||||
|  | ||||
| @ -44,38 +44,6 @@ class QuoteInvitation extends BaseModel | ||||
|         return self::class; | ||||
|     } | ||||
| 
 | ||||
|     // public function getSignatureDateAttribute($value)
 | ||||
|     // {
 | ||||
|     //     if (!$value) {
 | ||||
|     //         return (new Carbon($value))->format('Y-m-d');
 | ||||
|     //     }
 | ||||
|     //     return $value;
 | ||||
|     // }
 | ||||
| 
 | ||||
|     // public function getSentDateAttribute($value)
 | ||||
|     // {
 | ||||
|     //     if (!$value) {
 | ||||
|     //         return (new Carbon($value))->format('Y-m-d');
 | ||||
|     //     }
 | ||||
|     //     return $value;
 | ||||
|     // }
 | ||||
| 
 | ||||
|     // public function getViewedDateAttribute($value)
 | ||||
|     // {
 | ||||
|     //     if (!$value) {
 | ||||
|     //         return (new Carbon($value))->format('Y-m-d');
 | ||||
|     //     }
 | ||||
|     //     return $value;
 | ||||
|     // }
 | ||||
| 
 | ||||
|     // public function getOpenedDateAttribute($value)
 | ||||
|     // {
 | ||||
|     //     if (!$value) {
 | ||||
|     //         return (new Carbon($value))->format('Y-m-d');
 | ||||
|     //     }
 | ||||
|     //     return $value;
 | ||||
|     // }
 | ||||
| 
 | ||||
|     public function entityType() | ||||
|     { | ||||
|         return Quote::class; | ||||
|  | ||||
| @ -24,7 +24,7 @@ return [ | ||||
|     */ | ||||
| 
 | ||||
|     'guzzle' => [ | ||||
|         'timeout' => 10, | ||||
|         'connect_timeout' => 10, | ||||
|         'timeout' => 120, | ||||
|         'connect_timeout' => 120, | ||||
|     ], | ||||
| ]; | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user