-
-
Notifications
You must be signed in to change notification settings - Fork 41
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fix inconsistent ids #758
Fix inconsistent ids #758
Conversation
If sort by is set to amount, try sorting by date if amounts are same. For sorting by date, if dates are equal sort by id. This should hopefully make the transactions order consistent. This also means that SortTransactions will almost never return zero which is a good thing I believe.
@UrtsiSantsi can you check if this pr fixes those issues. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Overall looks good to me!
Maybe update changelog too?
Currently there when pressing "Today" button the marks disappear. This commit fixes that
Once @UrtsiSantsi confirms the fixes, it's good to go! |
Feel free to update the version to V2023.12.0-next and then I will re-approve |
@nlogozzo Updated the changelog. Let me know if wording needs to be changed |
Alright |
@nlogozzo Is it just in the metainfo file? And what to do with the date? |
Dec 1st please . So 2023-12-01 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
On last grammar thing 😅
NickvisionMoney.Shared/Linux/org.nickvision.money.metainfo.xml.in
Outdated
Show resolved
Hide resolved
Oops 😂 Fixed now |
It is better now, but still not perfect:
So I wonder what this numbers represents - they are not the index in the list of all transactions ever created and they are not the index in the current list of transactions? |
That is intentional. The numbers are the ids of the transactions. We don't want to modify the id of an existing transaction.
I'm not sure I understand. If the biggest id remaining is 6 the new one picked will be 7. Isn't that how its supposed to be? |
What I mean is if I delete 7 and the remaining one is 6, when I create new one it will be 7 again. So it is not the id of the transaction, since there was already transaction 7 before. |
Yeah but you deleted transaction 7. So it is no more. Thus the id can be reused...that's the whole point, no? That's the problem u mentioned in #750 |
Following that logic if I delete 2 instead of 7, the next one should be 2, not 8? After all 2 can be reused. |
From a user point of view why do we have these numbers? They are not unique and can be reused, so the only information we get from them is the order of creation, but we can just order transactions by date and achieve the same result. |
We do not reuse any id numbers. When creating a new transaction Denaro assigns a new permanent unique id number for that transaction. For that it checks what all transactions are present and adds one to the biggest id so that we can get nice sequential numbers. When the last transaction is deleted, it isn't stored anywhere and Denaro doesn't consider its id as "used" (as we don't have any info on that anymore) so when its time to create a new transaction, its id gets reused, but still in the account's database, it is a unique number. If we use the numbers that are unused in between, the ids that will be assigned doesn't seem to be sequential anymore. It will more or less feel random to the user. These ids also help to sort based on creation time.
Not really. You can have multiple transactions in the same day. Here ids can be used to see which transaction happened first, if the user has entered them in that order. Also since you can create transactions that are dated in the past and future, dates can't be used for order of creation. |
I didn't realize the date can be changed 😅
I will prefer option 2. Even without my suggestions this pull request improves the consistency greatly, fixes #749 and mostly #750. |
Number 1 makes more sense to me tbh. Regardless I don't think that change makes sense here, as the point of this PR was to improve the consistency of whatever denaro is currently doing. Maybe move that to a separate issue? In that case this pr is ready to be merged unless @nlogozzo disagrees. |
Fixes #750
Fixes #749