| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * GroupCollectorInterface.php | 
					
						
							| 
									
										
										
										
											2020-01-28 08:46:01 +01:00
										 |  |  |  * Copyright (c) 2019 james@firefly-iii.org | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii). | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU Affero General Public License as | 
					
						
							|  |  |  |  * published by the Free Software Foundation, either version 3 of the | 
					
						
							|  |  |  |  * License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * GNU Affero General Public License for more details. | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Helpers\Collector; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  | use FireflyIII\Models\Bill; | 
					
						
							|  |  |  | use FireflyIII\Models\Budget; | 
					
						
							|  |  |  | use FireflyIII\Models\Category; | 
					
						
							|  |  |  | use FireflyIII\Models\Tag; | 
					
						
							|  |  |  | use FireflyIII\Models\TransactionCurrency; | 
					
						
							| 
									
										
										
										
											2019-03-30 07:09:52 +01:00
										 |  |  | use FireflyIII\Models\TransactionGroup; | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  | use FireflyIII\User; | 
					
						
							| 
									
										
										
										
											2019-03-24 14:48:12 +01:00
										 |  |  | use Illuminate\Pagination\LengthAwarePaginator; | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  | use Illuminate\Support\Collection; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Interface GroupCollectorInterface | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | interface GroupCollectorInterface | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-03-30 07:09:52 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Get transactions with a specific amount. | 
					
						
							| 
									
										
										
										
											2019-03-30 07:09:52 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * @param string $amount | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							| 
									
										
										
										
											2019-03-30 07:09:52 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function amountIs(string $amount): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-03-30 07:09:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-14 19:06:05 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Get transactions where the amount is less than. | 
					
						
							| 
									
										
										
										
											2019-08-14 19:06:05 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * @param string $amount | 
					
						
							| 
									
										
										
										
											2019-08-14 19:06:05 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function amountLess(string $amount): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-08-14 19:06:05 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Get transactions where the amount is more than. | 
					
						
							| 
									
										
										
										
											2019-08-14 19:06:05 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * @param string $amount | 
					
						
							| 
									
										
										
										
											2019-08-14 19:06:05 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function amountMore(string $amount): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-08-14 19:06:05 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Exclude destination accounts. | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-08-14 19:06:05 +02:00
										 |  |  |      * @param Collection $accounts | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function excludeDestinationAccounts(Collection $accounts): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * These accounts must not be source accounts. | 
					
						
							| 
									
										
										
										
											2019-08-14 19:06:05 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @param Collection $accounts | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function excludeSourceAccounts(Collection $accounts): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-05-30 12:31:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-04 17:31:47 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Return the transaction journals without group information. Is useful in some instances. | 
					
						
							| 
									
										
										
										
											2019-07-04 17:31:47 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * @return array | 
					
						
							| 
									
										
										
										
											2019-07-04 17:31:47 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function getExtractedJournals(): array; | 
					
						
							| 
									
										
										
										
											2019-07-04 17:31:47 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Return the groups. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getGroups(): Collection; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-24 14:48:12 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Same as getGroups but everything is in a paginator. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return LengthAwarePaginator | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getPaginatedGroups(): LengthAwarePaginator; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Return the sum of all journals. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getSum(): string; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Define which accounts can be part of the source and destination transactions. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Collection $accounts | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setAccounts(Collection $accounts): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Collect transactions after a specific date. | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * @param Carbon $date | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function setAfter(Carbon $date): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Collect transactions before a specific date. | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * @param Carbon $date | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function setBefore(Carbon $date): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Limit the search to a specific bill. | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * @param Bill $bill | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function setBill(Bill $bill): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Limit the search to a specific set of bills. | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * @param Collection $bills | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function setBills(Collection $bills): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Both source AND destination must be in this list of accounts. | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * @param Collection $accounts | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function setBothAccounts(Collection $accounts): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Limit the search to a specific budget. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Budget $budget | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setBudget(Budget $budget): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Limit the search to a specific set of budgets. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Collection $budgets | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setBudgets(Collection $budgets): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Limit the search to a specific bunch of categories. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Collection $categories | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setCategories(Collection $categories): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Limit the search to a specific category. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Category $category | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setCategory(Category $category): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-17 15:01:00 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Collect transactions created on a specific date. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Carbon $date | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setCreatedAt(Carbon $date): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-05-29 21:52:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Limit results to a specific currency, either foreign or normal one. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param TransactionCurrency $currency | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setCurrency(TransactionCurrency $currency): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-22 12:24:01 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Limit results to a specific foreign currency. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param TransactionCurrency $currency | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setForeignCurrency(TransactionCurrency $currency): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Set destination accounts. | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * @param Collection $accounts | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function setDestinationAccounts(Collection $accounts): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Limit the result to a specific transaction group. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param TransactionGroup $transactionGroup | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setGroup(TransactionGroup $transactionGroup): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Limit the result to a set of specific transaction journals. | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * @param array $journalIds | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function setJournalIds(array $journalIds): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-03-30 07:09:52 +01:00
										 |  |  |      * Limit the number of returned entries. | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-03-30 07:09:52 +01:00
										 |  |  |      * @param int $limit | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-03-30 07:09:52 +01:00
										 |  |  |     public function setLimit(int $limit): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-03-30 07:09:52 +01:00
										 |  |  |      * Set the page to get. | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-03-30 07:09:52 +01:00
										 |  |  |      * @param int $page | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-03-30 07:09:52 +01:00
										 |  |  |     public function setPage(int $page): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Set the start and end time of the results to return. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Carbon $start | 
					
						
							|  |  |  |      * @param Carbon $end | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setRange(Carbon $start, Carbon $end): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Search for words in descriptions. | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * @param array $array | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function setSearchWords(array $array): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-22 12:24:01 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Beginning of the description must match: | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $array | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function descriptionStarts(array $array): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * End of the description must match: | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $array | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function descriptionEnds(array $array): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Description must be: | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $value | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function descriptionIs(string $value): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-29 21:52:08 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Set source accounts. | 
					
						
							| 
									
										
										
										
											2019-05-29 21:52:08 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * @param Collection $accounts | 
					
						
							| 
									
										
										
										
											2019-05-29 21:52:08 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function setSourceAccounts(Collection $accounts): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-05-29 21:52:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-30 12:31:19 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Limit results to a specific tag. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Tag $tag | 
					
						
							| 
									
										
										
										
											2019-05-30 12:31:19 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function setTag(Tag $tag): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-05-30 12:31:19 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Limit results to a specific set of tags. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Collection $tags | 
					
						
							| 
									
										
										
										
											2019-05-30 12:31:19 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function setTags(Collection $tags): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-05-30 12:31:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-22 12:24:01 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function withoutTags(): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function hasAnyTag(): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-30 07:09:52 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Limit the search to one specific transaction group. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param TransactionGroup $transactionGroup | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setTransactionGroup(TransactionGroup $transactionGroup): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-24 14:48:12 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Limit the included transaction types. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $types | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setTypes(array $types): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-17 15:01:00 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Collect transactions updated on a specific date. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Carbon $date | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setUpdatedAt(Carbon $date): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-24 09:23:36 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Set the user object and start the query. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param User $user | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setUser(User $user): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-17 15:01:00 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Either account can be set, but NOT both. This effectively excludes internal transfers. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Collection $accounts | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setXorAccounts(Collection $accounts): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Automatically include all stuff required to make API calls work. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function withAPIInformation(): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-24 14:48:12 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Will include the source and destination account names and types. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function withAccountInformation(): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-17 15:01:00 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Add basic info on attachments of transactions. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function withAttachmentInformation(): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-22 12:24:01 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Has attachments | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function hasAttachments(): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-29 21:52:08 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Include bill name + ID. | 
					
						
							| 
									
										
										
										
											2019-05-29 21:52:08 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function withBillInformation(): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-05-29 21:52:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Will include budget ID + name, if any. | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function withBudgetInformation(): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Will include category ID + name, if any. | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function withCategoryInformation(): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-05-31 13:35:33 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-09 17:40:09 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Will include notes. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function withNotes(): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-22 12:24:01 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Any notes, no matter what. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function withAnyNotes(): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string $value | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function notesContain(string $value): GroupCollectorInterface; | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string $value | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function withoutNotes(): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string $value | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function notesStartWith(string $value): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string $value | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function notesEndWith(string $value): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string $value | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function notesExactly(string $value): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-24 14:48:12 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Add tag info. | 
					
						
							| 
									
										
										
										
											2019-03-24 14:48:12 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function withTagInformation(): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-03-24 14:48:12 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Limit results to a transactions without a budget. | 
					
						
							| 
									
										
										
										
											2019-03-24 14:48:12 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function withoutBudget(): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-03-24 14:48:12 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |      * Limit results to a transactions without a category. | 
					
						
							| 
									
										
										
										
											2019-03-24 14:48:12 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-09-03 22:35:41 +02:00
										 |  |  |     public function withoutCategory(): GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2019-03-24 14:48:12 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-22 12:24:01 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Limit results to a transactions with a category. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function withCategory(): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Limit results to a transactions with a budget. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function withBudget(): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-23 20:18:59 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Look for specific external ID's. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $externalId | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setExternalId(string $externalId): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Look for specific external ID's. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $externalId | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return GroupCollectorInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setInternalReference(string $externalId): GroupCollectorInterface; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-17 12:09:03 +02:00
										 |  |  | } |