Skip to content

Commit

Permalink
wip: add shoelace/alert
Browse files Browse the repository at this point in the history
  • Loading branch information
tvdeyen committed Oct 14, 2023
1 parent d00cf37 commit 3bef695
Show file tree
Hide file tree
Showing 13 changed files with 151 additions and 75 deletions.
1 change: 0 additions & 1 deletion app/assets/javascripts/alchemy/admin.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@
//= require alchemy/alchemy.element_editors
//= require alchemy/alchemy.elements_window
//= require alchemy/alchemy.fixed_elements
//= require alchemy/alchemy.growler
//= require alchemy/alchemy.hotkeys
//= require alchemy/alchemy.image_overlay
//= require alchemy/alchemy.string_extension
Expand Down
24 changes: 0 additions & 24 deletions app/assets/javascripts/alchemy/alchemy.growler.js.coffee

This file was deleted.

28 changes: 4 additions & 24 deletions app/assets/stylesheets/alchemy/flash.scss
Original file line number Diff line number Diff line change
@@ -1,25 +1,3 @@
div#flash_notices {
position: fixed;
right: 0;
z-index: 400000;
width: 400px;
top: 0;

.flash.error {
cursor: pointer;
padding-right: 24px;

&:before {
content: fa-content($fa-var-times);
position: absolute;
right: 2*$default-padding;
top: 11px;
font-size: $small-font-size;
font-family: 'Font Awesome 5 Free';
}
}
}

div.flash {
border-radius: $default-border-radius;
opacity: 0.95;
Expand All @@ -28,7 +6,7 @@ div.flash {
border-width: 1px;
border-style: solid;
z-index: 1000;
margin: $default-margin $default-margin 2*$default-margin;
margin: $default-margin $default-margin 2 * $default-margin;
position: relative;
min-height: 2.6em;
word-break: break-all;
Expand Down Expand Up @@ -66,7 +44,9 @@ div.flash {
background-color: $info_background_color;
}

&.warn, &.warning, &.alert {
&.warn,
&.warning,
&.alert {
border-color: $warning_border_color;
color: $warning_text_color;
background-color: $warning_background_color;
Expand Down
5 changes: 2 additions & 3 deletions app/assets/stylesheets/alchemy/print.scss
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@
div#main_menu,
div#top_menu,
div#corner,
div#flash_notices,
div.pagination span,
div.pagination a {
display: none;
Expand All @@ -18,7 +17,7 @@ div#archive_all {
}

span.icon.true:before {
content: 'x';
content: "x";
}

div.pagination {
Expand All @@ -31,5 +30,5 @@ div.pagination em.current {
}

div.pagination em:before {
content: 'Page ';
content: "Page ";
}
56 changes: 56 additions & 0 deletions app/components/alchemy/admin/flash_message.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
class Alchemy::Admin::FlashMessage < ViewComponent::Base
def initialize(message, type: "notice", auto_dismiss: true, closable: true)
@message = message
@type = type
@auto_dismiss = (auto_dismiss == true) ? variant != "danger" : false
@closable = closable
end

def call
content_tag("sl-alert", message, attributes) do
content_tag("sl-icon", nil, name: icon, slot: "icon") + message
end
end

private

attr_reader :message, :type, :auto_dismiss, :closable

def icon
case type.to_s
when "warning", "warn", "alert"
"exclamation-triangle-fill"
when "notice"
"check-lg"
when "error"
"bug-fill"
else
"info-circle-fill"
end
end

def variant
case type.to_s
when "warning", "warn", "alert"
"warning"
when "notice", "success"
"success"
when "error"
"danger"
when "info"
"primary"
else
"neutral"
end
end

def attributes
{
variant: variant,
closable: closable,
open: true
}.tap do |a|
a[:duration] = 3000 if auto_dismiss
end
end
end
9 changes: 0 additions & 9 deletions app/helpers/alchemy/base_helper.rb
Original file line number Diff line number Diff line change
Expand Up @@ -58,15 +58,6 @@ def render_message(type = :info, msg = nil, &blk)
end
end

# Renders the flash partial (+alchemy/admin/partials/flash+)
#
# @param [String] notice The notice you want to display
# @param [Symbol] style The style of this flash. Valid values are +:notice+ (default), +:warn+ and +:error+
#
def render_flash_notice(notice, style = :notice)
render("alchemy/admin/partials/flash", flash_type: style, message: notice)
end

# Checks if the given argument is a String or a Page object.
# If a String is given, it tries to find the page via page_layout
# Logs a warning if no page is given.
Expand Down
2 changes: 2 additions & 0 deletions app/javascript/alchemy_admin.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import "@hotwired/turbo-rails"

import Buttons from "alchemy_admin/buttons"
import growl from "alchemy_admin/growler"
import GUI from "alchemy_admin/gui"
import { translate } from "alchemy_admin/i18n"
import Dirty from "alchemy_admin/dirty"
Expand Down Expand Up @@ -41,6 +42,7 @@ if (typeof window.Alchemy === "undefined") {
Object.assign(Alchemy, {
Buttons,
...Dirty,
growl,
GUI,
t: translate, // Global utility method for translating a given string
fileEditors,
Expand Down
74 changes: 74 additions & 0 deletions app/javascript/alchemy_admin/growler.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
import "@shoelace/alert"
import { registerIconLibrary } from "@shoelace/icon-library"

registerIconLibrary("default", {
resolver: (name) =>
`https://cdn.jsdelivr.net/npm/[email protected]/icons/${name}.svg`
})

function escapeHtml(html) {
const div = document.createElement("div")
div.textContent = html
return div.innerHTML
}

function notify(
message,
variant = "primary",
icon = "info-circle-fill",
duration = 3000
) {
const alert = Object.assign(document.createElement("sl-alert"), {
variant,
closable: true,
innerHTML: `
<sl-icon name="${icon}" slot="icon"></sl-icon>
${escapeHtml(message)}
`
})
if (variant !== "danger") {
alert.duration = duration
}
document.body.append(alert)
alert.toast()
}

function messageIcon(messageType) {
switch (messageType) {
case "warning":
return "exclamation-triangle-fill"
case "warn":
return "exclamation-triangle-fill"
case "alert":
return "exclamation-triangle-fill"
case "notice":
return "check-lg"
case "error":
return "bug-fill"
default:
return "info-circle-fill"
}
}

function messageStyle(messageType) {
switch (messageType) {
case "warning":
return "warning"
case "warn":
return "warning"
case "alert":
return "warning"
case "notice":
return "success"
case "error":
return "danger"
case "info":
return "primary"
default:
return "neutral"
}
}

export default function (message, style = "notice") {
notify(message, messageStyle(style), messageIcon(style))
}
5 changes: 0 additions & 5 deletions app/javascript/alchemy_admin/initializer.js
Original file line number Diff line number Diff line change
Expand Up @@ -25,11 +25,6 @@ function Initialize() {
// Initialize the GUI.
Alchemy.GUI.init()

// Fade all growl notifications.
if ($("#flash_notices").length > 0) {
Alchemy.Growler.fade()
}

// Add observer for please wait overlay.
$(".please_wait, .button_with_label form :submit")
.not("*[data-alchemy-confirm]")
Expand Down
5 changes: 1 addition & 4 deletions app/views/alchemy/admin/partials/_flash.html.erb
Original file line number Diff line number Diff line change
@@ -1,4 +1 @@
<div class="flash <%= flash_type %>">
<%= render_icon message_icon_class(flash_type) %>
<%= message %>
</div>
<%= render Alchemy::Admin::FlashMessage.new(message, type: flash_type) %>
13 changes: 9 additions & 4 deletions app/views/alchemy/admin/partials/_flash_notices.html.erb
Original file line number Diff line number Diff line change
@@ -1,5 +1,10 @@
<div id="flash_notices" style="display: <%= flash.keys.blank? ? "none" : "block" %>">
<% flash.keys.each do |flash_type| %>
<%= render_flash_notice(flash[flash_type.to_sym], flash_type) if flash[flash_type.to_sym].present? %>
<% end %>
<div class="sl-toast-stack">
<% flash.keys.each do |flash_type| %>
<% message = flash[flash_type.to_sym] %>
<% if message.present? %>
<%= render "alchemy/admin/partials/flash",
message: message,
flash_type: flash_type %>
<% end %>
<% end %>
</div>
2 changes: 1 addition & 1 deletion app/views/alchemy/base/error_notice.html.erb
Original file line number Diff line number Diff line change
@@ -1 +1 @@
<%= render_flash_notice @notice, :error %>
<%= render "alchemy/admin/partials/flash", flash_type: :error, message: @notice %>
2 changes: 2 additions & 0 deletions config/importmap.rb
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@
pin "@shoelace/tab", to: "https://cdn.jsdelivr.net/npm/@shoelace-style/[email protected]/cdn/components/tab/tab.js", preload: true
pin "@shoelace/tab-group", to: "https://cdn.jsdelivr.net/npm/@shoelace-style/[email protected]/cdn/components/tab-group/tab-group.js", preload: true
pin "@shoelace/tab-panel", to: "https://cdn.jsdelivr.net/npm/@shoelace-style/[email protected]/cdn/components/tab-panel/tab-panel.js", preload: true
pin "@shoelace/alert", to: "https://cdn.jsdelivr.net/npm/@shoelace-style/[email protected]/cdn/components/alert/alert.js", preload: true
pin "@shoelace/icon-library", to: "https://cdn.jsdelivr.net/npm/@shoelace-style/[email protected]/cdn/utilities/icon-library.js", preload: true

pin "alchemy_admin", to: "alchemy_admin.js", preload: true
pin_all_from File.expand_path("../app/javascript/alchemy_admin", __dir__), under: "alchemy_admin"

0 comments on commit 3bef695

Please sign in to comment.