mirror of
https://github.com/we-promise/sure.git
synced 2026-04-19 12:04:08 +00:00
* Add lookbook + viewcomponent, organize design system file * Build menu component * Button updates * More button fixes * Replace all menus with new ViewComponent * Checkpoint: fix tests, all buttons and menus converted * Split into Link and Button components for clarity * Button cleanup * Simplify custom confirmation configuration in views * Finalize button, link component API * Add toggle field to custom form builder + Component * Basic tabs component * Custom tabs, convert all menu / tab instances in app * Gem updates * Centralized icon helper * Update all icon usage to central helper * Lint fixes * Centralize all disclosure instances * Dialog replacements * Consolidation of all dialog styles * Test fixes * Fix app layout issues, move to component with slots * Layout simplification * Flakey test fix * Fix dashboard mobile issues * Finalize homepage * Lint fixes * Fix shadows and borders in dark mode * Fix tests * Remove stale class * Fix filled icon logic * Move transparent? to public interface
50 lines
1.7 KiB
Plaintext
50 lines
1.7 KiB
Plaintext
<%# locals: (form:) %>
|
|
|
|
<% condition = form.object %>
|
|
<% rule = condition.rule %>
|
|
|
|
<li data-controller="rule--conditions element-removal" 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">
|
|
<% unless form.index == 0 %>
|
|
<div class="pl-2">
|
|
<span class="font-medium uppercase text-xs">and</span>
|
|
</div>
|
|
<% end %>
|
|
<p class="text-sm text-secondary">match</p>
|
|
<%= form.select :operator, [["all", "and"], ["any", "or"]], { container_class: "w-fit" }, data: { rules_target: "operatorField" } %>
|
|
<p class="text-sm text-secondary">of the following conditions</p>
|
|
</div>
|
|
|
|
<%= icon(
|
|
"trash-2",
|
|
size: "sm",
|
|
as_button: true,
|
|
data: { action: "element-removal#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_PLACEHOLDER" do |scf| %>
|
|
<%= render "rule/conditions/condition", form: scf %>
|
|
<% end %>
|
|
</template>
|
|
|
|
<ul data-rule--conditions-target="subConditionsList" class="space-y-3">
|
|
<%= form.fields_for :sub_conditions do |scf| %>
|
|
<%= render "rule/conditions/condition", form: scf, show_prefix: false %>
|
|
<% end %>
|
|
</ul>
|
|
|
|
<%= render ButtonComponent.new(
|
|
text: "Add condition",
|
|
leading_icon: "plus",
|
|
variant: "ghost",
|
|
data: { action: "rule--conditions#addSubCondition" }
|
|
) %>
|
|
</li>
|