mirror of
https://github.com/maybe-finance/maybe.git
synced 2025-07-18 20:59:39 +02:00
* WIP * WIP * WIP * WIP * WIP * WIP * WIP * format * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * WIP * fix conflict * fix conflict * chore: run rubocop * fix test * update PWA logo * fix tests * chore: lint * fix test * Refactor: Remove duplicate data attribute in activity partial and add chat form rendering in chats index --------- Co-authored-by: Josh Pigford <josh@joshpigford.com>
47 lines
2.1 KiB
Ruby
47 lines
2.1 KiB
Ruby
module MenusHelper
|
|
def contextual_menu(icon: "more-horizontal", id: nil, &block)
|
|
tag.div id: id, data: { controller: "menu" } do
|
|
concat contextual_menu_icon(icon)
|
|
concat contextual_menu_content(&block)
|
|
end
|
|
end
|
|
|
|
def contextual_menu_modal_action_item(label, url, icon: "pencil-line", turbo_frame: :modal, class_name: nil)
|
|
link_to url, class: "flex items-center rounded-md text-primary hover:bg-container-hover p-2 gap-2 #{class_name}", data: { action: "click->menu#close", turbo_frame: turbo_frame } do
|
|
concat(lucide_icon(icon, class: "shrink-0 w-5 h-5 text-secondary"))
|
|
concat(tag.span(label, class: "text-sm"))
|
|
end
|
|
end
|
|
|
|
def contextual_menu_item(label, url:, icon:, turbo_frame: nil)
|
|
link_to url, class: "flex items-center rounded-md text-primary hover:bg-container-hover p-2 gap-2", data: { action: "click->menu#close", turbo_frame: turbo_frame } do
|
|
concat(lucide_icon(icon, class: "shrink-0 w-5 h-5 text-secondary"))
|
|
concat(tag.span(label, class: "text-sm"))
|
|
end
|
|
end
|
|
|
|
def contextual_menu_destructive_item(label, url, turbo_confirm: true, turbo_frame: nil)
|
|
button_to url,
|
|
method: :delete,
|
|
class: "flex items-center w-full rounded-md text-red-500 hover:bg-red-500/5 p-2 gap-2",
|
|
data: { turbo_confirm: turbo_confirm, turbo_frame: } do
|
|
concat(lucide_icon("trash-2", class: "shrink-0 w-5 h-5"))
|
|
concat(tag.span(label, class: "text-sm"))
|
|
end
|
|
end
|
|
|
|
private
|
|
def contextual_menu_icon(icon)
|
|
tag.button class: "w-9 h-9 flex justify-center items-center hover:bg-surface-hover rounded-lg cursor-pointer focus:outline-none focus-visible:outline-none", data: { menu_target: "button" } do
|
|
concat lucide_icon("more-vertical", class: "w-5 h-5 text-secondary md:hidden")
|
|
concat lucide_icon(icon, class: "w-5 h-5 text-secondary hidden md:block")
|
|
end
|
|
end
|
|
|
|
def contextual_menu_content(&block)
|
|
tag.div class: "min-w-[200px] p-1 z-50 shadow-border-xs bg-container rounded-lg hidden",
|
|
data: { menu_target: "content" } do
|
|
capture(&block)
|
|
end
|
|
end
|
|
end
|