phlexy_ui 0.1.8 → 0.1.10
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/phlexy_ui/button.rb +38 -45
- data/lib/phlexy_ui/navbar.rb +48 -0
- data/lib/phlexy_ui/version.rb +1 -1
- metadata +3 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: f59d7f461c2ebf91b2bf3646cc33fa8122c9df39449f3a59879766c2230406d8
|
4
|
+
data.tar.gz: 6972f8cb458ccfdd10af9212c840f62e02ef1a8050f014c7438cc58c923fb1e9
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: c4fbcc5a531c1b5c5cdb1a0eeb49bcd59a3dcf4ddd0562cd3fa297a909ea673d5b05493bb429548f5336966c668d07ea5e118b3aa7abfa8feba0ce2408a27f18
|
7
|
+
data.tar.gz: 5ecf6460831ce0047b4a1162aa5870f2adf01b2113927e9baa4f7573a82ce6494f8b4e416f1815657119e94dbdba1bad975cdd9250060ff9ec2e2ba5a3eb1d9c
|
data/lib/phlexy_ui/button.rb
CHANGED
@@ -16,52 +16,10 @@ module PhlexyUI
|
|
16
16
|
options:
|
17
17
|
).then do |classes|
|
18
18
|
if modal
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
#
|
23
|
-
# onclick: "#{modal}.showModal()"
|
24
|
-
#
|
25
|
-
# However, currently, Phlex does not allow you to use the "onclick"
|
26
|
-
# attribute.
|
27
|
-
#
|
28
|
-
# Once Phlex 2.0 is released, it will add a #safe method
|
29
|
-
# that will allow us to replace this with a single line:
|
30
|
-
#
|
31
|
-
# onclick: safe("#{modal}.showModal()")
|
32
|
-
#
|
33
|
-
# For now, at least this only runs once and uses event delegation
|
34
|
-
# so that it only adds a single event listener to the document.body.
|
35
|
-
#
|
36
|
-
# The downside is a bigger HTML payload.
|
37
|
-
options[:data] ||= {}
|
38
|
-
options[:data][:modal] = modal
|
39
|
-
script do
|
40
|
-
unsafe_raw <<~JS
|
41
|
-
// Will be replaced with a single line on the <button> once Phlex 2.0 is released.
|
42
|
-
(() => {
|
43
|
-
if (window.PhlexyUI && window.PhlexyUI.modalInitialized) {
|
44
|
-
return;
|
45
|
-
}
|
46
|
-
|
47
|
-
document.body.addEventListener("click", (event) => {
|
48
|
-
if (event.target.tagName === 'BUTTON' &&
|
49
|
-
event.target.dataset.modal) {
|
50
|
-
const modal = document.getElementById(event.target.dataset.modal);
|
51
|
-
if (modal) {
|
52
|
-
modal.showModal();
|
53
|
-
}
|
54
|
-
}
|
55
|
-
});
|
56
|
-
|
57
|
-
if (!window.PhlexyUI) window.PhlexyUI = {};
|
58
|
-
window.PhlexyUI.modalInitialized = true;
|
59
|
-
})();
|
60
|
-
JS
|
61
|
-
end
|
19
|
+
build_button_via_unsafe_raw(classes, &)
|
20
|
+
else
|
21
|
+
public_send(as, class: classes, **options, &)
|
62
22
|
end
|
63
|
-
|
64
|
-
public_send(as, class: classes, **options, &)
|
65
23
|
end
|
66
24
|
end
|
67
25
|
|
@@ -69,6 +27,41 @@ module PhlexyUI
|
|
69
27
|
|
70
28
|
attr_reader :modal
|
71
29
|
|
30
|
+
# TODO: Remove this once Phlex 2.0 is released.
|
31
|
+
#
|
32
|
+
# The cleanest way to do this is with a single:
|
33
|
+
#
|
34
|
+
# onclick: "#{Phlex::Escape.html_escape(modal)}.showModal()"
|
35
|
+
#
|
36
|
+
# However, currently, Phlex does not allow you to use the "onclick"
|
37
|
+
# attribute.
|
38
|
+
#
|
39
|
+
# Once Phlex 2.0 is released, it will add a #safe method
|
40
|
+
# that will allow us to replace this with a single line:
|
41
|
+
#
|
42
|
+
# onclick: safe("#{Phlex::Escape.html_escape(modal)}.showModal()")
|
43
|
+
def build_button_via_unsafe_raw(classes, &)
|
44
|
+
classes = Phlex::Escape.html_escape(classes.join(" "))
|
45
|
+
@options = options
|
46
|
+
.merge(onclick: "#{modal}.showModal()")
|
47
|
+
.reduce("") do |acc, (k, v)|
|
48
|
+
if k == :data
|
49
|
+
v.each do |k, v|
|
50
|
+
k = Phlex::Escape.html_escape(k)
|
51
|
+
v = Phlex::Escape.html_escape(v)
|
52
|
+
acc += " data-#{k}=\"#{v}\""
|
53
|
+
end
|
54
|
+
acc
|
55
|
+
else
|
56
|
+
k = Phlex::Escape.html_escape(k)
|
57
|
+
v = Phlex::Escape.html_escape(v)
|
58
|
+
"#{acc} #{k}=\"#{v}\""
|
59
|
+
end
|
60
|
+
end.strip
|
61
|
+
|
62
|
+
unsafe_raw %(<button class="#{classes}" #{options}>#{capture(&)}</button>)
|
63
|
+
end
|
64
|
+
|
72
65
|
register_modifiers(
|
73
66
|
# "sm:no-animation"
|
74
67
|
# "md:no-animation"
|
data/lib/phlexy_ui/navbar.rb
CHANGED
@@ -10,6 +10,7 @@ module PhlexyUI
|
|
10
10
|
def view_template(&)
|
11
11
|
generate_classes!(
|
12
12
|
component_html_class: :navbar,
|
13
|
+
modifiers_map: modifiers,
|
13
14
|
base_modifiers:,
|
14
15
|
options:
|
15
16
|
).then do |classes|
|
@@ -28,5 +29,52 @@ module PhlexyUI
|
|
28
29
|
def end(&)
|
29
30
|
div(class: :"navbar-end", &)
|
30
31
|
end
|
32
|
+
|
33
|
+
register_modifiers(
|
34
|
+
# "sm:bg-primary sm:text-primary-content"
|
35
|
+
# "md:bg-primary md:text-primary-content"
|
36
|
+
# "lg:bg-primary lg:text-primary-content"
|
37
|
+
primary: "bg-primary text-primary-content",
|
38
|
+
# "sm:bg-secondary sm:text-secondary-content"
|
39
|
+
# "md:bg-secondary md:text-secondary-content"
|
40
|
+
# "lg:bg-secondary lg:text-secondary-content"
|
41
|
+
secondary: "bg-secondary text-secondary-content",
|
42
|
+
# "sm:bg-accent sm:text-accent-content"
|
43
|
+
# "md:bg-accent md:text-accent-content"
|
44
|
+
# "lg:bg-accent lg:text-accent-content"
|
45
|
+
accent: "bg-accent text-accent-content",
|
46
|
+
# "sm:bg-neutral sm:text-neutral-content"
|
47
|
+
# "md:bg-neutral md:text-neutral-content"
|
48
|
+
# "lg:bg-neutral lg:text-neutral-content"
|
49
|
+
neutral: "bg-neutral text-neutral-content",
|
50
|
+
# "sm:bg-base-100 sm:text-base-content"
|
51
|
+
# "md:bg-base-100 md:text-base-content"
|
52
|
+
# "lg:bg-base-100 lg:text-base-content"
|
53
|
+
base_100: "bg-base-100 text-base-content",
|
54
|
+
# "sm:bg-base-200 sm:text-base-content"
|
55
|
+
# "md:bg-base-200 md:text-base-content"
|
56
|
+
# "lg:bg-base-200 lg:text-base-content"
|
57
|
+
base_200: "bg-base-200 text-base-content",
|
58
|
+
# "sm:bg-base-300 sm:text-base-content"
|
59
|
+
# "md:bg-base-300 md:text-base-content"
|
60
|
+
# "lg:bg-base-300 lg:text-base-content"
|
61
|
+
base_300: "bg-base-300 text-base-content",
|
62
|
+
# "sm:bg-info sm:text-info-content"
|
63
|
+
# "md:bg-info sm:text-info-content"
|
64
|
+
# "lg:bg-info sm:text-info-content"
|
65
|
+
info: "bg-info text-info-content",
|
66
|
+
# "sm:bg-success sm:text-success-content"
|
67
|
+
# "md:bg-success md:text-success-content"
|
68
|
+
# "lg:bg-success lg:text-success-content"
|
69
|
+
success: "bg-success text-success-content",
|
70
|
+
# "sm:bg-warning sm:text-warning-content"
|
71
|
+
# "md:bg-warning md:text-warning-content"
|
72
|
+
# "lg:bg-warning lg:text-warning-content"
|
73
|
+
warning: "bg-warning text-warning-content",
|
74
|
+
# "sm:bg-error sm:text-error-content"
|
75
|
+
# "md:bg-error md:text-error-content"
|
76
|
+
# "lg:bg-error lg:text-error-content"
|
77
|
+
error: "bg-error text-error-content"
|
78
|
+
)
|
31
79
|
end
|
32
80
|
end
|
data/lib/phlexy_ui/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: phlexy_ui
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.10
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- David Alejandro Aguilar Ramos
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2024-09-
|
11
|
+
date: 2024-09-29 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: phlex
|
@@ -144,7 +144,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
144
144
|
- !ruby/object:Gem::Version
|
145
145
|
version: '0'
|
146
146
|
requirements: []
|
147
|
-
rubygems_version: 3.5.
|
147
|
+
rubygems_version: 3.5.20
|
148
148
|
signing_key:
|
149
149
|
specification_version: 4
|
150
150
|
summary: PhlexyUI is a Ruby UI component library for DaisyUI using Phlex
|