mirror of
https://github.com/we-promise/sure.git
synced 2026-05-30 07:49:01 +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>
50 lines
1.9 KiB
Plaintext
50 lines
1.9 KiB
Plaintext
<%# locals: (form:) %>
|
|
|
|
<% condition = form.object %>
|
|
<% rule = condition.rule %>
|
|
|
|
<li data-controller="rule--conditions" class="border border-secondary rounded-md p-4 space-y-3">
|
|
|
|
<%= form.hidden_field :condition_type, value: "compound" %>
|
|
|
|
<div class="flex items-center justify-between gap-2">
|
|
<div class="flex items-center gap-2">
|
|
<%# Show prefix on condition groups, except the first one %>
|
|
<div class="pl-2" data-condition-prefix>
|
|
<span class="font-medium uppercase text-xs"><%= t(".and_prefix") %></span>
|
|
</div>
|
|
<p class="text-sm text-secondary"><%= t(".match") %></p>
|
|
<%= form.select :operator, [[t(".all"), "and"], [t(".any"), "or"]], { container_class: "w-fit" }, data: { rules_target: "operatorField" } %>
|
|
<p class="text-sm text-secondary"><%= t(".of_the_following_conditions") %></p>
|
|
</div>
|
|
|
|
<%= icon(
|
|
"trash-2",
|
|
as_button: true,
|
|
size: "sm",
|
|
data: { action: "rule--conditions#remove" }
|
|
) %>
|
|
</div>
|
|
|
|
<%# Sub-condition template, used by Stimulus controller to add new sub-conditions dynamically %>
|
|
<template data-rule--conditions-target="subConditionTemplate">
|
|
<%= form.fields_for :sub_conditions, Rule::Condition.new(parent: condition, condition_type: rule.condition_filters.first.key), child_index: "IDX_CHILD_PLACEHOLDER" do |scf| %>
|
|
<%= render "rule/conditions/condition", form: scf, show_prefix: false %>
|
|
<% end %>
|
|
</template>
|
|
|
|
<ul data-rule--conditions-target="subConditionsList" class="space-y-3">
|
|
<%= form.fields_for :sub_conditions, condition.sub_conditions.select(&:persisted?) do |scf| %>
|
|
<%= render "rule/conditions/condition", form: scf, show_prefix: false %>
|
|
<% end %>
|
|
</ul>
|
|
|
|
<%= render DS::Button.new(
|
|
text: t(".add_condition"),
|
|
leading_icon: "plus",
|
|
variant: "ghost",
|
|
type: "button",
|
|
data: { action: "rule--conditions#addSubCondition" }
|
|
) %>
|
|
</li>
|