mirror of
https://github.com/we-promise/sure.git
synced 2026-05-27 06:25:12 +00:00
* Extract hardcoded strings to i18n
Replace numerous hardcoded English strings with I18n lookups (t / I18n.t) across controllers, views, helpers, and components, and convert model validation error messages to symbol keys. Added multiple locale files under config/locales for models and views. This centralizes user-facing notices/alerts, UI text, import/validation messages, and prepares the app for localization and easier translation maintenance.
* Update en.yml
* Update preview-cleanup.yml
* Revert "Update preview-cleanup.yml"
This reverts commit 1ba6d3c34c.
* test: align i18n assertions with translated messages
* Standardize balance error key and tweak locales
Replace SophtronAccount's :requires_balance error key with :no_balance and update related locale strings for sophtron, plaid, and simplefin accounts to use the new key and clearer copy. Also switch the QIF upload redirect notice to use a relative translation key (t('.qif_uploaded')), remove an unused SSO providers help line, and fix a trailing-newline/whitespace issue in the subscriptions locale. These changes standardize validation keys and improve translation consistency and messaging.
---------
Co-authored-by: KiloClaw <kiloclaw@openclaw.ai>
70 lines
2.7 KiB
Plaintext
70 lines
2.7 KiB
Plaintext
<%= tag.div data: { controller: "donut-chart", donut_chart_segments_value: budget.to_donut_segments_json }, class: "relative h-full" do %>
|
|
<div data-donut-chart-target="chartContainer" class="absolute inset-0 pointer-events-none"></div>
|
|
|
|
<div data-donut-chart-target="contentContainer" class="flex justify-center items-center h-full">
|
|
<div data-donut-chart-target="defaultContent" class="flex flex-col items-center">
|
|
<% if budget.initialized? %>
|
|
<div class="text-secondary text-sm mb-2">
|
|
<span><%= t(".spent") %></span>
|
|
</div>
|
|
|
|
<div class="mb-2 text-3xl font-medium privacy-sensitive <%= budget.available_to_spend.negative? ? "text-red-500" : "text-primary" %>">
|
|
<%= format_money(budget.actual_spending_money) %>
|
|
</div>
|
|
|
|
<%= render DS::Link.new(
|
|
text: t(".of_budget", amount: budget.budgeted_spending_money.format),
|
|
variant: "secondary",
|
|
icon: "pencil",
|
|
icon_position: "right",
|
|
size: "sm",
|
|
href: edit_budget_path(budget)
|
|
) %>
|
|
<% else %>
|
|
<div class="text-subdued text-3xl mb-2 privacy-sensitive">
|
|
<span><%= format_money Money.new(0, budget.currency || budget.family.currency) %></span>
|
|
</div>
|
|
|
|
<%= render DS::Link.new(
|
|
text: t(".new_budget"),
|
|
size: "sm",
|
|
icon: "plus",
|
|
href: edit_budget_path(budget)
|
|
) %>
|
|
<% end %>
|
|
</div>
|
|
|
|
<% budget.budget_categories.each do |bc| %>
|
|
<div id="segment_<%= bc.id %>" class="hidden">
|
|
<div class="flex flex-col gap-2 items-center">
|
|
<div class="flex items-center gap-3">
|
|
<div class="w-1 h-3 rounded-xl" style="background-color: <%= bc.category.color %>"></div>
|
|
<p class="text-sm text-secondary"><%= bc.category.name %></p>
|
|
</div>
|
|
|
|
<p class="text-3xl font-medium privacy-sensitive <%= bc.available_to_spend.negative? ? "text-red-500" : "text-primary" %>">
|
|
<%= format_money(bc.actual_spending_money) %>
|
|
</p>
|
|
|
|
<%= render DS::Link.new(
|
|
text: t(".of_budget", amount: bc.budgeted_spending_money.format(precision: 0)),
|
|
variant: "secondary",
|
|
icon: "pencil",
|
|
icon_position: "right",
|
|
size: "sm",
|
|
href: budget_budget_categories_path(budget)
|
|
) %>
|
|
</div>
|
|
</div>
|
|
<% end %>
|
|
|
|
<div id="segment_unused" class="hidden">
|
|
<p class="text-sm text-secondary text-center mb-2"><%= t(".unused") %></p>
|
|
|
|
<p class="text-3xl font-medium text-primary privacy-sensitive">
|
|
<%= format_money(budget.available_to_spend_money) %>
|
|
</p>
|
|
</div>
|
|
</div>
|
|
<% end %>
|