| 
									
										
										
										
											2023-08-15 13:52:30 +02:00
										 |  |  | /* | 
					
						
							|  |  |  |  * create.js | 
					
						
							|  |  |  |  * Copyright (c) 2023 james@firefly-iii.org | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii).
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU Affero General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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/>.
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import '../../boot/bootstrap.js'; | 
					
						
							|  |  |  | import dates from '../../pages/shared/dates.js'; | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  | import {createEmptySplit, defaultErrorSet} from "./shared/create-empty-split.js"; | 
					
						
							| 
									
										
										
										
											2023-08-22 08:25:06 +02:00
										 |  |  | import {parseFromEntries} from "./shared/parse-from-entries.js"; | 
					
						
							| 
									
										
										
										
											2023-08-15 13:52:30 +02:00
										 |  |  | import formatMoney from "../../util/format-money.js"; | 
					
						
							| 
									
										
										
										
											2023-08-22 08:25:06 +02:00
										 |  |  | import Post from "../../api/v2/model/transaction/post.js"; | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  | import {loadCurrencies} from "./shared/load-currencies.js"; | 
					
						
							|  |  |  | import {loadBudgets} from "./shared/load-budgets.js"; | 
					
						
							|  |  |  | import {loadPiggyBanks} from "./shared/load-piggy-banks.js"; | 
					
						
							|  |  |  | import {loadSubscriptions} from "./shared/load-subscriptions.js"; | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-02 20:19:09 +01:00
										 |  |  | import 'leaflet/dist/leaflet.css'; | 
					
						
							| 
									
										
										
										
											2024-01-06 07:26:03 +01:00
										 |  |  | import {addAutocomplete, getUrls} from "./shared/add-autocomplete.js"; | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  | import { | 
					
						
							|  |  |  |     changeCategory, | 
					
						
							|  |  |  |     changeDescription, | 
					
						
							|  |  |  |     changeDestinationAccount, | 
					
						
							|  |  |  |     changeSourceAccount, | 
					
						
							|  |  |  |     selectDestinationAccount, | 
					
						
							|  |  |  |     selectSourceAccount | 
					
						
							|  |  |  | } from "./shared/autocomplete-functions.js"; | 
					
						
							|  |  |  | import {processAttachments} from "./shared/process-attachments.js"; | 
					
						
							|  |  |  | import {spliceErrorsIntoTransactions} from "./shared/splice-errors-into-transactions.js"; | 
					
						
							| 
									
										
										
										
											2024-01-05 08:12:17 +01:00
										 |  |  | import Tags from "bootstrap5-tags"; | 
					
						
							|  |  |  | import {addLocation} from "./shared/manage-locations.js"; | 
					
						
							| 
									
										
										
										
											2024-01-07 07:02:28 +01:00
										 |  |  | import i18next from "i18next"; | 
					
						
							| 
									
										
										
										
											2024-01-03 17:43:05 +01:00
										 |  |  | // TODO upload attachments to other file
 | 
					
						
							|  |  |  | // TODO fix two maps, perhaps disconnect from entries entirely.
 | 
					
						
							|  |  |  | // TODO group title
 | 
					
						
							|  |  |  | // TODO map location from preferences
 | 
					
						
							| 
									
										
										
										
											2024-01-03 19:34:50 +01:00
										 |  |  | // TODO field preferences
 | 
					
						
							| 
									
										
										
										
											2024-01-02 20:19:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-06 07:26:03 +01:00
										 |  |  | const urls = getUrls(); | 
					
						
							| 
									
										
										
										
											2023-08-15 13:52:30 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | let transactions = function () { | 
					
						
							|  |  |  |     return { | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |         // transactions are stored in "entries":
 | 
					
						
							|  |  |  |         entries: [], | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // state of the form is stored in formState:
 | 
					
						
							|  |  |  |         formStates: { | 
					
						
							|  |  |  |             loadingCurrencies: true, | 
					
						
							|  |  |  |             loadingBudgets: true, | 
					
						
							|  |  |  |             loadingPiggyBanks: true, | 
					
						
							|  |  |  |             loadingSubscriptions: true, | 
					
						
							|  |  |  |             isSubmitting: false, | 
					
						
							|  |  |  |             returnHereButton: false, | 
					
						
							|  |  |  |             saveAsNewButton: false, // edit form only
 | 
					
						
							| 
									
										
										
										
											2024-03-24 12:07:26 +01:00
										 |  |  |             resetButton: false, | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |             rulesButton: true, | 
					
						
							|  |  |  |             webhooksButton: true, | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |         // form behaviour during transaction
 | 
					
						
							|  |  |  |         formBehaviour: { | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  |             formType: 'create', foreignCurrencyEnabled: true, | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |         }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // form data (except transactions) is stored in formData
 | 
					
						
							|  |  |  |         formData: { | 
					
						
							|  |  |  |             defaultCurrency: null, | 
					
						
							|  |  |  |             enabledCurrencies: [], | 
					
						
							|  |  |  |             nativeCurrencies: [], | 
					
						
							|  |  |  |             foreignCurrencies: [], | 
					
						
							|  |  |  |             budgets: [], | 
					
						
							|  |  |  |             piggyBanks: [], | 
					
						
							|  |  |  |             subscriptions: [], | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // properties for the entire transaction group
 | 
					
						
							|  |  |  |         groupProperties: { | 
					
						
							| 
									
										
										
										
											2024-03-24 12:07:26 +01:00
										 |  |  |             transactionType: 'unknown', | 
					
						
							|  |  |  |             title: null, | 
					
						
							|  |  |  |             id: null, | 
					
						
							|  |  |  |             totalAmount: 0, | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |         }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // notifications
 | 
					
						
							|  |  |  |         notifications: { | 
					
						
							|  |  |  |             error: { | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  |                 show: false, text: '', url: '', | 
					
						
							|  |  |  |             }, success: { | 
					
						
							|  |  |  |                 show: false, text: '', url: '', | 
					
						
							|  |  |  |             }, wait: { | 
					
						
							|  |  |  |                 show: false, text: '', | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // part of the account selection auto-complete
 | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |         filters: { | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  |             source: [], destination: [], | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // events in the form
 | 
					
						
							|  |  |  |         changedDateTime(event) { | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  |             console.warn('changedDateTime, event is not used'); | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |         changedDescription(event) { | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  |             console.warn('changedDescription, event is not used'); | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |         changedDestinationAccount(event) { | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |             this.detectTransactionType(); | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |         changedSourceAccount(event) { | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |             this.detectTransactionType(); | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-02 20:19:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |         detectTransactionType() { | 
					
						
							|  |  |  |             const sourceType = this.entries[0].source_account.type ?? 'unknown'; | 
					
						
							|  |  |  |             const destType = this.entries[0].destination_account.type ?? 'unknown'; | 
					
						
							|  |  |  |             if ('unknown' === sourceType && 'unknown' === destType) { | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |                 this.groupProperties.transactionType = 'unknown'; | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |                 console.warn('Cannot infer transaction type from two unknown accounts.'); | 
					
						
							|  |  |  |                 return; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |             // transfer: both are the same and in strict set of account types
 | 
					
						
							|  |  |  |             if (sourceType === destType && ['Asset account', 'Loan', 'Debt', 'Mortgage'].includes(sourceType)) { | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |                 this.groupProperties.transactionType = 'transfer'; | 
					
						
							|  |  |  |                 console.log('Transaction type is detected to be "' + this.groupProperties.transactionType + '".'); | 
					
						
							| 
									
										
										
										
											2023-10-29 05:24:57 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 // this also locks the amount into the amount of the source account
 | 
					
						
							|  |  |  |                 // and the foreign amount (if different) in that of the destination account.
 | 
					
						
							|  |  |  |                 console.log('filter down currencies for transfer.'); | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |                 this.filterNativeCurrencies(this.entries[0].source_account.currency_code); | 
					
						
							|  |  |  |                 this.filterForeignCurrencies(this.entries[0].destination_account.currency_code); | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |                 return; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             // withdrawals:
 | 
					
						
							|  |  |  |             if ('Asset account' === sourceType && ['Expense account', 'Debt', 'Loan', 'Mortgage'].includes(destType)) { | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |                 this.groupProperties.transactionType = 'withdrawal'; | 
					
						
							|  |  |  |                 console.log('[a] Transaction type is detected to be "' + this.groupProperties.transactionType + '".'); | 
					
						
							| 
									
										
										
										
											2023-10-29 05:24:57 +01:00
										 |  |  |                 this.filterNativeCurrencies(this.entries[0].source_account.currency_code); | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |                 return; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if ('Asset account' === sourceType && 'unknown' === destType) { | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |                 this.groupProperties.transactionType = 'withdrawal'; | 
					
						
							|  |  |  |                 console.log('[b] Transaction type is detected to be "' + this.groupProperties.transactionType + '".'); | 
					
						
							| 
									
										
										
										
											2023-10-29 05:24:57 +01:00
										 |  |  |                 console.log(this.entries[0].source_account); | 
					
						
							|  |  |  |                 this.filterNativeCurrencies(this.entries[0].source_account.currency_code); | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |                 return; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (['Debt', 'Loan', 'Mortgage'].includes(sourceType) && 'Expense account' === destType) { | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |                 this.groupProperties.transactionType = 'withdrawal'; | 
					
						
							|  |  |  |                 console.log('[c] Transaction type is detected to be "' + this.groupProperties.transactionType + '".'); | 
					
						
							| 
									
										
										
										
											2023-10-29 05:24:57 +01:00
										 |  |  |                 this.filterNativeCurrencies(this.entries[0].source_account.currency_code); | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |                 return; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // deposits:
 | 
					
						
							|  |  |  |             if ('Revenue account' === sourceType && ['Asset account', 'Debt', 'Loan', 'Mortgage'].includes(destType)) { | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |                 this.groupProperties.transactionType = 'deposit'; | 
					
						
							|  |  |  |                 console.log('Transaction type is detected to be "' + this.groupProperties.transactionType + '".'); | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |                 return; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2024-02-25 18:09:52 +01:00
										 |  |  |             if ('unknown' === sourceType && ['Asset account', 'Debt', 'Loan', 'Mortgage'].includes(destType)) { | 
					
						
							|  |  |  |                 this.groupProperties.transactionType = 'deposit'; | 
					
						
							|  |  |  |                 console.log('Transaction type is detected to be "' + this.groupProperties.transactionType + '".'); | 
					
						
							|  |  |  |                 return; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2024-02-25 18:14:30 +01:00
										 |  |  |             if ('Expense account' === sourceType && ['Asset account', 'Debt', 'Loan', 'Mortgage'].includes(destType)) { | 
					
						
							|  |  |  |                 this.groupProperties.transactionType = 'deposit'; | 
					
						
							|  |  |  |                 console.warn('FORCE transaction type to be "' + this.groupProperties.transactionType + '".'); | 
					
						
							| 
									
										
										
										
											2024-02-25 18:24:10 +01:00
										 |  |  |                 this.entries[0].source_account.id = ''; | 
					
						
							| 
									
										
										
										
											2024-02-25 18:14:30 +01:00
										 |  |  |                 return; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |             if (['Debt', 'Loan', 'Mortgage'].includes(sourceType) && 'Asset account' === destType) { | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |                 this.groupProperties.transactionType = 'deposit'; | 
					
						
							|  |  |  |                 console.log('Transaction type is detected to be "' + this.groupProperties.transactionType + '".'); | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |                 return; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             console.warn('Unknown account combination between "' + sourceType + '" and "' + destType + '".'); | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |         formattedTotalAmount() { | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  |             if (this.entries.length === 0) { | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |                 return formatMoney(this.groupProperties.totalAmount, 'EUR'); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             return formatMoney(this.groupProperties.totalAmount, this.entries[0].currency_code ?? 'EUR'); | 
					
						
							| 
									
										
										
										
											2023-10-29 05:24:57 +01:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |         filterForeignCurrencies(code) { | 
					
						
							|  |  |  |             let list = []; | 
					
						
							|  |  |  |             let currency; | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |             for (let i in this.formData.enabledCurrencies) { | 
					
						
							|  |  |  |                 if (this.formData.enabledCurrencies.hasOwnProperty(i)) { | 
					
						
							|  |  |  |                     let current = this.formData.enabledCurrencies[i]; | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |                     if (current.code === code) { | 
					
						
							|  |  |  |                         currency = current; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             list.push(currency); | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |             this.formData.foreignCurrencies = list; | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |             // is he source account currency anyway:
 | 
					
						
							|  |  |  |             if (1 === list.length && list[0].code === this.entries[0].source_account.currency_code) { | 
					
						
							|  |  |  |                 console.log('Foreign currency is same as source currency. Disable foreign amount.'); | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |                 this.formBehaviour.foreignCurrencyEnabled = false; | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |             } | 
					
						
							|  |  |  |             if (1 === list.length && list[0].code !== this.entries[0].source_account.currency_code) { | 
					
						
							|  |  |  |                 console.log('Foreign currency is NOT same as source currency. Enable foreign amount.'); | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |                 this.formBehaviour.foreignCurrencyEnabled = true; | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // this also forces the currency_code on ALL entries.
 | 
					
						
							|  |  |  |             for (let i in this.entries) { | 
					
						
							|  |  |  |                 if (this.entries.hasOwnProperty(i)) { | 
					
						
							|  |  |  |                     this.entries[i].foreign_currency_code = code; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-29 05:24:57 +01:00
										 |  |  |         filterNativeCurrencies(code) { | 
					
						
							|  |  |  |             let list = []; | 
					
						
							|  |  |  |             let currency; | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |             for (let i in this.formData.enabledCurrencies) { | 
					
						
							|  |  |  |                 if (this.formData.enabledCurrencies.hasOwnProperty(i)) { | 
					
						
							|  |  |  |                     let current = this.formData.enabledCurrencies[i]; | 
					
						
							| 
									
										
										
										
											2023-10-29 05:24:57 +01:00
										 |  |  |                     if (current.code === code) { | 
					
						
							|  |  |  |                         currency = current; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             list.push(currency); | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |             this.formData.nativeCurrencies = list; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-29 05:24:57 +01:00
										 |  |  |             // this also forces the currency_code on ALL entries.
 | 
					
						
							| 
									
										
										
										
											2023-12-23 16:15:13 +01:00
										 |  |  |             for (let i in this.entries) { | 
					
						
							|  |  |  |                 if (this.entries.hasOwnProperty(i)) { | 
					
						
							| 
									
										
										
										
											2023-10-29 05:24:57 +01:00
										 |  |  |                     this.entries[i].currency_code = code; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |         changedAmount(e) { | 
					
						
							|  |  |  |             const index = parseInt(e.target.dataset.index); | 
					
						
							|  |  |  |             this.entries[index].amount = parseFloat(e.target.value); | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |             this.groupProperties.totalAmount = 0; | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |             for (let i in this.entries) { | 
					
						
							|  |  |  |                 if (this.entries.hasOwnProperty(i)) { | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |                     this.groupProperties.totalAmount = this.groupProperties.totalAmount + parseFloat(this.entries[i].amount); | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2023-10-29 05:24:57 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-23 07:54:01 +02:00
										 |  |  |         addedSplit() { | 
					
						
							| 
									
										
										
										
											2024-01-06 07:26:03 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-23 07:54:01 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |         processUpload(event) { | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |             this.showMessageOrRedirectUser(); | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |         processUploadError(event) { | 
					
						
							|  |  |  |             this.notifications.success.show = false; | 
					
						
							|  |  |  |             this.notifications.wait.show = false; | 
					
						
							|  |  |  |             this.notifications.error.show = true; | 
					
						
							|  |  |  |             this.formStates.isSubmitting = false; | 
					
						
							| 
									
										
										
										
											2024-01-07 07:02:28 +01:00
										 |  |  |             this.notifications.error.text = i18next.t('firefly.errors_upload'); | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |             console.error(event); | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2023-09-23 07:54:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-15 13:52:30 +02:00
										 |  |  |         init() { | 
					
						
							| 
									
										
										
										
											2024-01-07 07:02:28 +01:00
										 |  |  |             this.addSplit(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |             // load currencies and save in form data.
 | 
					
						
							|  |  |  |             loadCurrencies().then(data => { | 
					
						
							|  |  |  |                 this.formStates.loadingCurrencies = false; | 
					
						
							|  |  |  |                 this.formData.defaultCurrency = data.defaultCurrency; | 
					
						
							|  |  |  |                 this.formData.enabledCurrencies = data.enabledCurrencies; | 
					
						
							|  |  |  |                 this.formData.nativeCurrencies = data.nativeCurrencies; | 
					
						
							|  |  |  |                 this.formData.foreignCurrencies = data.foreignCurrencies; | 
					
						
							|  |  |  |             }); | 
					
						
							| 
									
										
										
										
											2023-09-23 07:54:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-04 07:26:45 +01:00
										 |  |  |             loadBudgets().then(data => { | 
					
						
							|  |  |  |                 this.formData.budgets = data; | 
					
						
							|  |  |  |                 this.formStates.loadingBudgets = false; | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  |             loadPiggyBanks().then(data => { | 
					
						
							|  |  |  |                 this.formData.piggyBanks = data; | 
					
						
							|  |  |  |                 this.formStates.loadingPiggyBanks = false; | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  |             loadSubscriptions().then(data => { | 
					
						
							|  |  |  |                 this.formData.subscriptions = data; | 
					
						
							|  |  |  |                 this.formStates.loadingSubscriptions = false; | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |             }); | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             document.addEventListener('upload-success', (event) => { | 
					
						
							|  |  |  |                 this.processUpload(event); | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |                 document.querySelectorAll("input[type=file]").value = ""; | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |             }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |             document.addEventListener('upload-error', (event) => { | 
					
						
							|  |  |  |                 this.processUploadError(event); | 
					
						
							|  |  |  |             }); | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  |             document.addEventListener('location-move', (event) => { | 
					
						
							|  |  |  |                 this.entries[event.detail.index].latitude = event.detail.latitude; | 
					
						
							|  |  |  |                 this.entries[event.detail.index].longitude = event.detail.longitude; | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             document.addEventListener('location-set', (event) => { | 
					
						
							|  |  |  |                 this.entries[event.detail.index].hasLocation = true; | 
					
						
							|  |  |  |                 this.entries[event.detail.index].latitude = event.detail.latitude; | 
					
						
							|  |  |  |                 this.entries[event.detail.index].longitude = event.detail.longitude; | 
					
						
							|  |  |  |                 this.entries[event.detail.index].zoomLevel = event.detail.zoomLevel; | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             document.addEventListener('location-zoom', (event) => { | 
					
						
							|  |  |  |                 this.entries[event.detail.index].hasLocation = true; | 
					
						
							|  |  |  |                 this.entries[event.detail.index].zoomLevel = event.detail.zoomLevel; | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-23 07:54:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |             // source can never be expense account
 | 
					
						
							|  |  |  |             this.filters.source = ['Asset account', 'Loan', 'Debt', 'Mortgage', 'Revenue account']; | 
					
						
							|  |  |  |             // destination can never be revenue account
 | 
					
						
							|  |  |  |             this.filters.destination = ['Expense account', 'Loan', 'Debt', 'Mortgage', 'Asset account']; | 
					
						
							| 
									
										
										
										
											2023-08-22 08:25:06 +02:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-22 08:25:06 +02:00
										 |  |  |         submitTransaction() { | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |             // reset all messages:
 | 
					
						
							|  |  |  |             this.notifications.error.show = false; | 
					
						
							|  |  |  |             this.notifications.success.show = false; | 
					
						
							|  |  |  |             this.notifications.wait.show = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // reset all errors in the entries array:
 | 
					
						
							|  |  |  |             for (let i in this.entries) { | 
					
						
							|  |  |  |                 if (this.entries.hasOwnProperty(i)) { | 
					
						
							|  |  |  |                     this.entries[i].errors = defaultErrorSet(); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // form is now submitting:
 | 
					
						
							|  |  |  |             this.formStates.isSubmitting = true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // final check on transaction type.
 | 
					
						
							| 
									
										
										
										
											2023-10-08 16:11:04 +02:00
										 |  |  |             this.detectTransactionType(); | 
					
						
							| 
									
										
										
										
											2023-09-20 06:18:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |             // parse transaction:
 | 
					
						
							| 
									
										
										
										
											2024-01-17 20:23:02 +01:00
										 |  |  |             let transactions = parseFromEntries(this.entries, null, this.groupProperties.transactionType); | 
					
						
							| 
									
										
										
										
											2023-08-22 08:25:06 +02:00
										 |  |  |             let submission = { | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |                 group_title: this.groupProperties.title, | 
					
						
							|  |  |  |                 fire_webhooks: this.formStates.webhooksButton, | 
					
						
							|  |  |  |                 apply_rules: this.formStates.rulesButton, | 
					
						
							|  |  |  |                 transactions: transactions | 
					
						
							| 
									
										
										
										
											2023-08-22 08:25:06 +02:00
										 |  |  |             }; | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             // catch for group title:
 | 
					
						
							| 
									
										
										
										
											2024-03-24 12:07:26 +01:00
										 |  |  |             // TODO later this must be handled with more care (ie use the group title input)
 | 
					
						
							|  |  |  |             if (transactions.length > 1) { | 
					
						
							| 
									
										
										
										
											2023-09-23 07:54:01 +02:00
										 |  |  |                 submission.group_title = transactions[0].description; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             // submit the transaction. Multi-stage process thing going on here!
 | 
					
						
							| 
									
										
										
										
											2023-08-22 08:25:06 +02:00
										 |  |  |             let poster = new Post(); | 
					
						
							|  |  |  |             console.log(submission); | 
					
						
							|  |  |  |             poster.post(submission).then((response) => { | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |                 const group = response.data.data; | 
					
						
							|  |  |  |                 // submission was a success!
 | 
					
						
							|  |  |  |                 this.groupProperties.id = parseInt(group.id); | 
					
						
							|  |  |  |                 this.groupProperties.title = group.attributes.group_title ?? group.attributes.transactions[0].description | 
					
						
							| 
									
										
										
										
											2024-03-24 12:07:26 +01:00
										 |  |  |                 console.log('group title is now: ', this.groupProperties.title); | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 // process attachments, if any:
 | 
					
						
							|  |  |  |                 const attachmentCount = processAttachments(this.groupProperties.id, group.attributes.transactions); | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 if (attachmentCount > 0) { | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |                     // if count is more than zero, system is processing transactions in the background.
 | 
					
						
							|  |  |  |                     this.notifications.wait.show = true; | 
					
						
							| 
									
										
										
										
											2024-01-07 07:02:28 +01:00
										 |  |  |                     this.notifications.wait.text = i18next.t('firefly.wait_attachments'); | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |                     return; | 
					
						
							| 
									
										
										
										
											2023-12-23 16:15:13 +01:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2023-09-23 07:54:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |                 // if not, respond to user options:
 | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |                 this.showMessageOrRedirectUser(); | 
					
						
							| 
									
										
										
										
											2023-08-22 08:25:06 +02:00
										 |  |  |             }).catch((error) => { | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-23 16:15:13 +01:00
										 |  |  |                 this.submitting = false; | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |                 console.log(error); | 
					
						
							| 
									
										
										
										
											2023-12-23 16:15:13 +01:00
										 |  |  |                 // todo put errors in form
 | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |                 if (typeof error.response !== 'undefined') { | 
					
						
							|  |  |  |                     this.parseErrors(error.response.data); | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2023-12-23 16:15:13 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-22 08:25:06 +02:00
										 |  |  |             }); | 
					
						
							| 
									
										
										
										
											2023-08-15 13:52:30 +02:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |         showMessageOrRedirectUser() { | 
					
						
							|  |  |  |             // disable all messages:
 | 
					
						
							|  |  |  |             this.notifications.error.show = false; | 
					
						
							|  |  |  |             this.notifications.success.show = false; | 
					
						
							|  |  |  |             this.notifications.wait.show = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (this.formStates.returnHereButton) { | 
					
						
							|  |  |  |                 this.notifications.success.show = true; | 
					
						
							|  |  |  |                 this.notifications.success.url = 'transactions/show/' + this.groupProperties.id; | 
					
						
							| 
									
										
										
										
											2024-03-24 12:07:26 +01:00
										 |  |  |                 this.notifications.success.text = i18next.t('firefly.stored_journal_js', {description: this.groupProperties.title, interpolation: { escapeValue: false }}); | 
					
						
							|  |  |  |                 this.formStates.isSubmitting = false; | 
					
						
							|  |  |  |                 // reset group title again
 | 
					
						
							|  |  |  |                 this.groupProperties.title = null; | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 if (this.formStates.resetButton) { | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |                     this.entries = []; | 
					
						
							|  |  |  |                     this.addSplit(); | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |                     this.groupProperties.totalAmount = 0; | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |                 return; | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |             window.location = 'transactions/show/' + this.groupProperties.id + '?transaction_group_id=' + this.groupProperties.id + '&message=created'; | 
					
						
							| 
									
										
										
										
											2024-01-02 15:41:14 +01:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-23 16:15:13 +01:00
										 |  |  |         parseErrors(data) { | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  |             // disable all messages:
 | 
					
						
							|  |  |  |             this.notifications.error.show = true; | 
					
						
							|  |  |  |             this.notifications.success.show = false; | 
					
						
							|  |  |  |             this.notifications.wait.show = false; | 
					
						
							|  |  |  |             this.formStates.isSubmitting = false; | 
					
						
							| 
									
										
										
										
											2024-01-24 07:03:08 +01:00
										 |  |  |             this.notifications.error.text = i18next.t('firefly.errors_submission_v2', {errorMessage: data.message}); | 
					
						
							| 
									
										
										
										
											2024-01-04 14:59:37 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  |             if (data.hasOwnProperty('errors')) { | 
					
						
							| 
									
										
										
										
											2024-01-10 20:29:00 +01:00
										 |  |  |                 this.entries = spliceErrorsIntoTransactions(data.errors, this.entries); | 
					
						
							| 
									
										
										
										
											2023-12-23 16:15:13 +01:00
										 |  |  |             } | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-15 13:52:30 +02:00
										 |  |  |         addSplit() { | 
					
						
							|  |  |  |             this.entries.push(createEmptySplit()); | 
					
						
							| 
									
										
										
										
											2024-01-05 08:12:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             setTimeout(() => { | 
					
						
							|  |  |  |                 // render tags:
 | 
					
						
							|  |  |  |                 Tags.init('select.ac-tags', { | 
					
						
							|  |  |  |                     allowClear: true, | 
					
						
							|  |  |  |                     server: urls.tag, | 
					
						
							|  |  |  |                     liveServer: true, | 
					
						
							|  |  |  |                     clearEnd: true, | 
					
						
							|  |  |  |                     allowNew: true, | 
					
						
							| 
									
										
										
										
											2024-01-07 07:02:28 +01:00
										 |  |  |                     notFoundMessage: i18next.t('firefly.nothing_found'), | 
					
						
							| 
									
										
										
										
											2024-01-05 08:12:17 +01:00
										 |  |  |                     noCache: true, | 
					
						
							|  |  |  |                     fetchOptions: { | 
					
						
							|  |  |  |                         headers: { | 
					
						
							|  |  |  |                             'X-CSRF-TOKEN': document.head.querySelector('meta[name="csrf-token"]').content | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 }); | 
					
						
							|  |  |  |                 const count = this.entries.length - 1; | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  |                 // if(document.querySelector('#location_map_' + count)) { }
 | 
					
						
							|  |  |  |                 addLocation(count); | 
					
						
							| 
									
										
										
										
											2024-01-06 07:26:03 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 // addedSplit, is called from the HTML
 | 
					
						
							|  |  |  |                 // for source account
 | 
					
						
							|  |  |  |                 const renderAccount = function (item, b, c) { | 
					
						
							| 
									
										
										
										
											2024-01-07 07:02:28 +01:00
										 |  |  |                     return item.name_with_balance + '<br><small class="text-muted">' + i18next.t('firefly.account_type_' + item.type) + '</small>'; | 
					
						
							| 
									
										
										
										
											2024-01-06 07:26:03 +01:00
										 |  |  |                 }; | 
					
						
							|  |  |  |                 addAutocomplete({ | 
					
						
							|  |  |  |                     selector: 'input.ac-source', | 
					
						
							|  |  |  |                     serverUrl: urls.account, | 
					
						
							|  |  |  |                     // filters: this.filters.source,
 | 
					
						
							|  |  |  |                     // onRenderItem: renderAccount,
 | 
					
						
							|  |  |  |                     onChange: changeSourceAccount, | 
					
						
							|  |  |  |                     onSelectItem: selectSourceAccount, | 
					
						
							| 
									
										
										
										
											2024-01-17 20:23:02 +01:00
										 |  |  |                     hiddenValue: this.entries[count].source_account.alpine_name | 
					
						
							| 
									
										
										
										
											2024-01-06 07:26:03 +01:00
										 |  |  |                 }); | 
					
						
							|  |  |  |                 addAutocomplete({ | 
					
						
							|  |  |  |                     selector: 'input.ac-dest', | 
					
						
							|  |  |  |                     serverUrl: urls.account, | 
					
						
							|  |  |  |                     filters: this.filters.destination, | 
					
						
							|  |  |  |                     onRenderItem: renderAccount, | 
					
						
							|  |  |  |                     onChange: changeDestinationAccount, | 
					
						
							|  |  |  |                     onSelectItem: selectDestinationAccount | 
					
						
							|  |  |  |                 }); | 
					
						
							|  |  |  |                 addAutocomplete({ | 
					
						
							|  |  |  |                     selector: 'input.ac-category', | 
					
						
							|  |  |  |                     serverUrl: urls.category, | 
					
						
							|  |  |  |                     valueField: 'id', | 
					
						
							|  |  |  |                     labelField: 'name', | 
					
						
							|  |  |  |                     onChange: changeCategory, | 
					
						
							|  |  |  |                     onSelectItem: changeCategory | 
					
						
							|  |  |  |                 }); | 
					
						
							|  |  |  |                 addAutocomplete({ | 
					
						
							|  |  |  |                     selector: 'input.ac-description', | 
					
						
							|  |  |  |                     serverUrl: urls.description, | 
					
						
							|  |  |  |                     valueField: 'id', | 
					
						
							|  |  |  |                     labelField: 'description', | 
					
						
							|  |  |  |                     onChange: changeDescription, | 
					
						
							|  |  |  |                     onSelectItem: changeDescription, | 
					
						
							|  |  |  |                 }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  |             }, 150); | 
					
						
							| 
									
										
										
										
											2023-08-15 13:52:30 +02:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-15 13:52:30 +02:00
										 |  |  |         removeSplit(index) { | 
					
						
							|  |  |  |             this.entries.splice(index, 1); | 
					
						
							|  |  |  |             // fall back to index 0
 | 
					
						
							|  |  |  |             const triggerFirstTabEl = document.querySelector('#split-0-tab') | 
					
						
							|  |  |  |             triggerFirstTabEl.click(); | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-02 20:19:09 +01:00
										 |  |  |         clearLocation(e) { | 
					
						
							|  |  |  |             e.preventDefault(); | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  |             // remove location from entry, fire event, do nothing else (the map is somebody else's problem).
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-02 20:19:09 +01:00
										 |  |  |             const target = e.currentTarget; | 
					
						
							|  |  |  |             const index = parseInt(target.attributes['data-index'].value); | 
					
						
							|  |  |  |             this.entries[index].hasLocation = false; | 
					
						
							| 
									
										
										
										
											2024-01-05 14:04:44 +01:00
										 |  |  |             this.entries[index].latitude = null; | 
					
						
							|  |  |  |             this.entries[index].longitude = null; | 
					
						
							|  |  |  |             this.entries[index].zoomLevel = null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             const removeEvent = new CustomEvent('location-remove', { | 
					
						
							|  |  |  |                 detail: { | 
					
						
							|  |  |  |                     index: index | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  |             document.dispatchEvent(removeEvent); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-02 20:19:09 +01:00
										 |  |  |             return false; | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2023-08-15 13:52:30 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | let comps = {transactions, dates}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function loadPage() { | 
					
						
							|  |  |  |     Object.keys(comps).forEach(comp => { | 
					
						
							|  |  |  |         console.log(`Loading page component "${comp}"`); | 
					
						
							|  |  |  |         let data = comps[comp](); | 
					
						
							|  |  |  |         Alpine.data(comp, () => data); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |     Alpine.start(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // wait for load until bootstrapped event is received.
 | 
					
						
							|  |  |  | document.addEventListener('firefly-iii-bootstrapped', () => { | 
					
						
							|  |  |  |     console.log('Loaded through event listener.'); | 
					
						
							|  |  |  |     loadPage(); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | // or is bootstrapped before event is triggered.
 | 
					
						
							|  |  |  | if (window.bootstrapped) { | 
					
						
							|  |  |  |     console.log('Loaded through window variable.'); | 
					
						
							|  |  |  |     loadPage(); | 
					
						
							|  |  |  | } |