mirror of
https://github.com/actualbudget/actual.git
synced 2026-03-09 11:42:54 -05:00
[Tech Debt] ButtonLink, LinkButton, ExternalLink, AnchorLink #530
Closed
opened 2026-02-28 19:07:49 -06:00 by GiteaMirror
·
7 comments
No Branch/Tag Specified
master
claude/fix-simplefin-ssrf-T31gX
claude/release-notes-validation-X7rvR
matiss/7155
claude/fix-simplefin-batch-sync-O8LcD
ai/custom-theme-dual-prefs
matiss/fix-6804
add-claude-github-actions-1772738270730
claude/analyze-internal-errors-4k6O2
react-query-rules
react-query-useSchedules
matiss/separate-lint-format
dependabot/npm_and_yarn/ajv-6.14.0
cursor/sync-performance-notification-9899
react-query-prefs
matiss/chunked-sync-and-progress-ux
v26.2.1
copilot/sub-pr-6880
fix-react-query-clear-on-close-budget
copilot/sub-pr-6140
feat/auto-note
feat/scoped-bank-sync
cursor/desktop-transactions-react-table-1d0c
fix-exhaustive-deps-App
copilot/fix-find-replace-bug
release/v26.2.0-pre
matiss/browser-tests
mobile-fix-drag-and-drop-across-groups
budget-table-v2
PayeeAutocomplete2
pglite
bugfix/plugins/fix-plugins-sw
feat/plugins/plugins-core-package
prerelease
matiss/unicode-minus-fix
cursor/fix-actual-github-issue-6206-gemini-3-pro-preview-9c37
TransactionFormPage
cursor/implement-mortgage-and-loan-account-type-78ca
tests-update-fill-with-pressSequentially
mobile/link-modal
deps/25.11
cursor/fix-update-vrt-apply-ci-job-dispatch-b324
sync-server-plugins
cursor/propose-patch-for-github-issue-5680-2a18
fix/compiler-preserve-inner-dollar-escapes
cursor/analyze-actual-budget-issue-and-propose-fix-5b70
coderabbitai/docstrings/0c070e5
cursor/add-wip-prefix-and-comment-to-prs-d78d
jfdoming/08-21-auto-focus-on-navigate-in-all-browsers
show-totals-on-mobile-budget-banners
allow-child-transactions-make-transfer
mobile-calculator-keyboard
payee-geolocation
enhance/restore_scroll_position
dm-fix-second-click-on-mobile-new-transaction-2
scrollToLocationBudget
alert-autofix-38
tsconfig-composite
mobile-fix-uncategorized-transactions-on-tracking-budgets
server-budget-handlers
fix-sql-injection-in-cleanup-template
non-chrome-draggable-workaround
mobile-budget-page-swipe-navigation
ts-db-all
stable
dark-theme-with-brand-colors
fix-mobile-delete-group
ts-db-select
UnderKoen/reconcile-context-menu
master-before-server-merge
v25.2.1
ts-runQuery
rename-redux-hooks
UnderKoen/3557-persist-state-in-history
remove-redux-CLOSE_BUDGET
fix-exhaustive-deps-errors-FinancesApp
redux-toolkit-createSlice-backup
accounts-function-component
ts-useSplitsExpanded
loot-core-server-package
useTransactios-in-TransactionEdit
react-aria-input
move-redux-to-desktop-client
QueryState-type
fix-themes-applied-late
mobile-vrts
revert-3295-spendingCardFix
react-aria-button-4
split-payee-on-mobile
twk3/pin-apis-crdt
notes-tag-autocomplete
ts-LoadBackup
dnd-kit
package-upgrades
v26.3.0
v26.2.1
v26.2.0
v26.1.0
v25.12.0
v25.11.0
v25.10.0
v25.9.0
v25.8.0
v25.7.1
v25.7.0
v25.6.1
v25.6.0
v25.5.0
v25.4.0
v25.3.1
v25.3.0
v25.2.1
v25.2.0
v25.1.0
v24.12.0
v24.11.0
v24.10.1
v24.10.0
v24.9.0
v24.8.0
v24.7.0
v24.6.0
v24.5.0
v24.4.0
v24.3.0
v24.2.0
v24.1.0
v23.12.0
v23.11.0
v23.10.0
v23.9.0
v23.8.1
v23.8.0
v23.7.2
v23.7.1
v23.7.0
v23.6.0
v23.5.0
v23.4.2
v23.4.1
v23.4.0
v23.3.2
v23.3.0
v23.2.9
v23.2.5
v23.1.12
v22.12.9
Labels
Clear labels
AI generated
API
bank sync
budgeting
bug
can’t replicate
dependencies
docker
documentation
electron
experimental feature
feature
feedback
goal templates
good first issue
help wanted
importers
maintenance
needs info
needs testing
needs triage
needs votes
openid
payees
pull-request
regression
reports
responsive
rules
schedules
server
✨ merged
split transactions
tech debt
theme
transaction import
transaction reconciliation
transactions
translations
upstream
user interface
✅ approved
wontfix
Mirrored from GitHub Pull Request
Milestone
No items
No Milestone
Projects
Clear projects
No project
No Assignees
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: github-starred/actual#530
Reference in New Issue
Block a user
Blocking a user prevents them from interacting with repositories, such as opening or commenting on pull requests or issues. Learn more about blocking a user.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Originally created by @MatissJanis on GitHub (Jul 29, 2023).
We have many components that act as fundamentally the same thing: a link.
<a href>element for links to outside of the app (open in new tab)<a href>element for links inside the app (open in same window)The goal of this ticket is to unify them. Before starting: please post the proposed interface in the comments.
@MatissJanis commented on GitHub (Jul 29, 2023):
My recommendation:
Unify
ButtonLink,ExternalLinkandAnchorLinkto a single component. And moveLinkButtoninsidebuttonwith a newtype(Buttonsupports various styles - bare, primary, etc. - this could be anothertype).@j-f1 commented on GitHub (Jul 29, 2023):
These are all pretty different components despite the similar name so I’m not sure this makes sense.
ButtonLinkhas a completely different visual style than the others since it looks like a button instead of a link.AnchorLinkis confusingly named and really only needed in the sidebar (its other usage sites should be replaced with a plainLink). Its job is to change appearance when activated (this is how the current item in the sidebar turns purple). It should probably either be renamed or inlined into theItemContentcomponent. It doesn’t even end up really looking like a normal link.ExternalLinkis specifically for external links, ie not ones that go through React Router. I think being explicit about that is a good thing.Until recently,
LinkButtonjust usedButtonand overrode it with styles. This had some strange effects, but I think merging it with Button directly could help since all the relevant code affecting its appearance is in one place.@MatissJanis commented on GitHub (Jul 29, 2023):
Conceptually they are all the same thing though: links. Maybe the underlying logic or styling is a bit different (external link vs internal react-router link), but conceptually they are the same thing.
Think of it from a newcomers perspective. I (newcomer) want to add a new link. Should I use
ButtonLink? OrLinkButton? Or perhapsAnchorLink? I don't know.In an ideal world we would have a single shared component (highlight on the "shared" aspect; it's fine to have multiple variations internally, but not on the "shared" layer) for links that does some magic internally to convert it to button/a href/external link/etc.
(code snippet purely for illustration)
@th3c0d3br34ker commented on GitHub (Sep 10, 2023):
Hi @MatissJanis, I would like to take up this issue. Since it will require major refactoring, before starting, I wanted to have a quick discussion.
Here is what I plan to do:
ButtonLink,ExternalLinkandAnchorLinkto a single component calledLinktypeproperty (default:link) different components will be rendered.Linkcomponent.Please let know if your thoughts have changed on refactoring the Link component. Any suggestions are also appreciated.
@MatissJanis commented on GitHub (Sep 10, 2023):
That sounds good. My recommendation would also be to first create this new
component and then move only 3x existing buttons/links to the new version
(all in a single PR). And then once we get the initial Link component
approved and merged - slowly migrate all the old ones to the new format.
We try to avoid massive PRs as they have a high risk of breaking things.
On Sun 10 Sep 2023 at 16:00, Jainam Desai @.***> wrote:
@th3c0d3br34ker commented on GitHub (Sep 23, 2023):
hey @MatissJanis, I am glad to that I could contribute.
The remaining task is to add
ExternalLinkcomponent. Will be raising a PR for the same soon.I wanted to ask about -- when/how do we address the usage of old components?
@MatissJanis commented on GitHub (Sep 23, 2023):
Up to you: if you want to do it, then feel free to perform the migration over a single (or multiple smaller) PRs. If not - I'd recommend adding a
@deprecatedcomment to the old components with instructions how to port over to the new ones. And then hopefully someone else picks it up.