phlex_ui 0.0.5 → 0.1.6
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/phlex_ui/accordion/builder.rb +22 -0
- data/lib/phlex_ui/accordion/content.rb +15 -15
- data/lib/phlex_ui/accordion/default_content.rb +11 -11
- data/lib/phlex_ui/accordion/default_trigger.rb +14 -14
- data/lib/phlex_ui/accordion/icon.rb +31 -31
- data/lib/phlex_ui/accordion/item.rb +20 -20
- data/lib/phlex_ui/accordion/trigger.rb +11 -11
- data/lib/phlex_ui/accordion.rb +10 -21
- data/lib/phlex_ui/alert/description.rb +10 -10
- data/lib/phlex_ui/alert/title.rb +10 -10
- data/lib/phlex_ui/alert.rb +27 -27
- data/lib/phlex_ui/alert_dialog/action.rb +11 -11
- data/lib/phlex_ui/alert_dialog/cancel.rb +15 -15
- data/lib/phlex_ui/alert_dialog/content.rb +36 -36
- data/lib/phlex_ui/alert_dialog/description.rb +11 -11
- data/lib/phlex_ui/alert_dialog/footer.rb +11 -11
- data/lib/phlex_ui/alert_dialog/header.rb +11 -11
- data/lib/phlex_ui/alert_dialog/title.rb +11 -11
- data/lib/phlex_ui/alert_dialog/trigger.rb +12 -12
- data/lib/phlex_ui/alert_dialog.rb +18 -18
- data/lib/phlex_ui/aspect_ratio.rb +24 -24
- data/lib/phlex_ui/attribute_merger.rb +59 -61
- data/lib/phlex_ui/avatar/builder.rb +36 -0
- data/lib/phlex_ui/avatar/fallback.rb +11 -11
- data/lib/phlex_ui/avatar/image.rb +19 -19
- data/lib/phlex_ui/avatar.rb +23 -41
- data/lib/phlex_ui/badge.rb +50 -50
- data/lib/phlex_ui/base.rb +16 -16
- data/lib/phlex_ui/button.rb +80 -80
- data/lib/phlex_ui/calendar/body.rb +19 -0
- data/lib/phlex_ui/calendar/days.rb +104 -0
- data/lib/phlex_ui/calendar/header.rb +17 -0
- data/lib/phlex_ui/calendar/next.rb +43 -0
- data/lib/phlex_ui/calendar/prev.rb +43 -0
- data/lib/phlex_ui/calendar/title.rb +27 -0
- data/lib/phlex_ui/calendar/weekdays.rb +33 -0
- data/lib/phlex_ui/calendar.rb +39 -0
- data/lib/phlex_ui/card/content.rb +11 -11
- data/lib/phlex_ui/card/description.rb +11 -11
- data/lib/phlex_ui/card/footer.rb +11 -11
- data/lib/phlex_ui/card/header.rb +11 -11
- data/lib/phlex_ui/card/title.rb +11 -11
- data/lib/phlex_ui/card.rb +11 -11
- data/lib/phlex_ui/chart.rb +23 -0
- data/lib/phlex_ui/checkbox.rb +12 -12
- data/lib/phlex_ui/clipboard/popover.rb +28 -28
- data/lib/phlex_ui/clipboard/source.rb +13 -13
- data/lib/phlex_ui/clipboard/trigger.rb +14 -14
- data/lib/phlex_ui/clipboard.rb +30 -30
- data/lib/phlex_ui/codeblock.rb +86 -86
- data/lib/phlex_ui/collapsible/content.rb +12 -12
- data/lib/phlex_ui/collapsible/trigger.rb +13 -13
- data/lib/phlex_ui/collapsible.rb +18 -18
- data/lib/phlex_ui/command/dialog.rb +17 -0
- data/lib/phlex_ui/command/dialog_content.rb +49 -0
- data/lib/phlex_ui/command/dialog_trigger.rb +29 -0
- data/lib/phlex_ui/command/empty.rb +19 -0
- data/lib/phlex_ui/command/group.rb +41 -0
- data/lib/phlex_ui/command/input.rb +56 -0
- data/lib/phlex_ui/command/item.rb +31 -0
- data/lib/phlex_ui/command/list.rb +17 -0
- data/lib/phlex_ui/command.rb +17 -0
- data/lib/phlex_ui/context_menu/content.rb +19 -19
- data/lib/phlex_ui/context_menu/item.rb +55 -55
- data/lib/phlex_ui/context_menu/label.rb +16 -16
- data/lib/phlex_ui/context_menu/separator.rb +13 -13
- data/lib/phlex_ui/context_menu/trigger.rb +14 -14
- data/lib/phlex_ui/context_menu.rb +19 -19
- data/lib/phlex_ui/dialog/content.rb +67 -67
- data/lib/phlex_ui/dialog/description.rb +11 -11
- data/lib/phlex_ui/dialog/footer.rb +11 -11
- data/lib/phlex_ui/dialog/header.rb +11 -11
- data/lib/phlex_ui/dialog/middle.rb +11 -11
- data/lib/phlex_ui/dialog/title.rb +11 -11
- data/lib/phlex_ui/dialog/trigger.rb +14 -13
- data/lib/phlex_ui/dialog.rb +18 -18
- data/lib/phlex_ui/dropdown_menu/content.rb +16 -16
- data/lib/phlex_ui/dropdown_menu/item.rb +21 -21
- data/lib/phlex_ui/dropdown_menu/label.rb +11 -11
- data/lib/phlex_ui/dropdown_menu/separator.rb +13 -13
- data/lib/phlex_ui/dropdown_menu/trigger.rb +12 -11
- data/lib/phlex_ui/dropdown_menu.rb +19 -19
- data/lib/phlex_ui/form/builder.rb +38 -0
- data/lib/phlex_ui/form/item.rb +11 -11
- data/lib/phlex_ui/form/spacer.rb +11 -11
- data/lib/phlex_ui/form.rb +9 -28
- data/lib/phlex_ui/hint.rb +11 -11
- data/lib/phlex_ui/hover_card/content.rb +16 -16
- data/lib/phlex_ui/hover_card/trigger.rb +14 -13
- data/lib/phlex_ui/hover_card.rb +20 -20
- data/lib/phlex_ui/input.rb +22 -22
- data/lib/phlex_ui/input_error.rb +11 -11
- data/lib/phlex_ui/label.rb +11 -11
- data/lib/phlex_ui/link.rb +81 -81
- data/lib/phlex_ui/popover/content.rb +16 -16
- data/lib/phlex_ui/popover/trigger.rb +14 -13
- data/lib/phlex_ui/popover.rb +18 -18
- data/lib/phlex_ui/select/builder.rb +67 -0
- data/lib/phlex_ui/select/content.rb +30 -0
- data/lib/phlex_ui/select/group.rb +15 -0
- data/lib/phlex_ui/select/input.rb +20 -0
- data/lib/phlex_ui/select/item.rb +48 -0
- data/lib/phlex_ui/select/label.rb +17 -0
- data/lib/phlex_ui/select/trigger.rb +45 -0
- data/lib/phlex_ui/select/value.rb +27 -0
- data/lib/phlex_ui/select.rb +30 -0
- data/lib/phlex_ui/sheet/content.rb +77 -0
- data/lib/phlex_ui/sheet/description.rb +17 -0
- data/lib/phlex_ui/sheet/footer.rb +17 -0
- data/lib/phlex_ui/sheet/header.rb +17 -0
- data/lib/phlex_ui/sheet/middle.rb +17 -0
- data/lib/phlex_ui/sheet/title.rb +17 -0
- data/lib/phlex_ui/sheet/trigger.rb +17 -0
- data/lib/phlex_ui/sheet.rb +17 -0
- data/lib/phlex_ui/shortcut_key.rb +11 -11
- data/lib/phlex_ui/table/body.rb +11 -11
- data/lib/phlex_ui/table/builder.rb +59 -59
- data/lib/phlex_ui/table/caption.rb +11 -11
- data/lib/phlex_ui/table/cell.rb +11 -11
- data/lib/phlex_ui/table/footer.rb +11 -11
- data/lib/phlex_ui/table/head.rb +11 -11
- data/lib/phlex_ui/table/header.rb +11 -11
- data/lib/phlex_ui/table/row.rb +11 -11
- data/lib/phlex_ui/table.rb +13 -13
- data/lib/phlex_ui/tabs/content.rb +18 -18
- data/lib/phlex_ui/tabs/list.rb +11 -11
- data/lib/phlex_ui/tabs/trigger.rb +20 -20
- data/lib/phlex_ui/tabs.rb +17 -17
- data/lib/phlex_ui/theme_toggle.rb +31 -31
- data/lib/phlex_ui/tooltip/content.rb +16 -16
- data/lib/phlex_ui/tooltip/trigger.rb +12 -11
- data/lib/phlex_ui/tooltip.rb +18 -18
- data/lib/phlex_ui/typography/blockquote.rb +11 -11
- data/lib/phlex_ui/typography/h1.rb +10 -10
- data/lib/phlex_ui/typography/h2.rb +10 -10
- data/lib/phlex_ui/typography/h3.rb +11 -11
- data/lib/phlex_ui/typography/h4.rb +11 -11
- data/lib/phlex_ui/typography/inline_code.rb +11 -11
- data/lib/phlex_ui/typography/inline_link.rb +22 -0
- data/lib/phlex_ui/typography/large.rb +11 -11
- data/lib/phlex_ui/typography/lead.rb +11 -11
- data/lib/phlex_ui/typography/list.rb +36 -36
- data/lib/phlex_ui/typography/list_item.rb +11 -11
- data/lib/phlex_ui/typography/muted.rb +11 -11
- data/lib/phlex_ui/typography/p.rb +11 -11
- data/lib/phlex_ui/typography/small.rb +11 -11
- data/lib/phlex_ui.rb +9 -4
- metadata +88 -7
@@ -1,17 +1,17 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module PhlexUI
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
4
|
+
class AlertDialog::Header < Base
|
5
|
+
def template(&block)
|
6
|
+
div(**attrs, &block)
|
7
|
+
end
|
8
8
|
|
9
|
-
|
9
|
+
private
|
10
10
|
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
end
|
11
|
+
def default_attrs
|
12
|
+
{
|
13
|
+
class: "flex flex-col space-y-2 text-center sm:text-left"
|
14
|
+
}
|
16
15
|
end
|
17
|
-
end
|
16
|
+
end
|
17
|
+
end
|
@@ -1,17 +1,17 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module PhlexUI
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
4
|
+
class AlertDialog::Title < Base
|
5
|
+
def template(&block)
|
6
|
+
h2(**attrs, &block)
|
7
|
+
end
|
8
8
|
|
9
|
-
|
9
|
+
private
|
10
10
|
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
end
|
11
|
+
def default_attrs
|
12
|
+
{
|
13
|
+
class: "text-lg font-semibold"
|
14
|
+
}
|
16
15
|
end
|
17
|
-
end
|
16
|
+
end
|
17
|
+
end
|
@@ -1,18 +1,18 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module PhlexUI
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
4
|
+
class AlertDialog::Trigger < Base
|
5
|
+
def template(&block)
|
6
|
+
div(**attrs, &block)
|
7
|
+
end
|
8
8
|
|
9
|
-
|
9
|
+
private
|
10
10
|
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
end
|
11
|
+
def default_attrs
|
12
|
+
{
|
13
|
+
data: {action: "click->alert-dialog#open"},
|
14
|
+
class: "inline-block"
|
15
|
+
}
|
17
16
|
end
|
18
|
-
end
|
17
|
+
end
|
18
|
+
end
|
@@ -1,26 +1,26 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module PhlexUI
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
4
|
+
class AlertDialog < Base
|
5
|
+
def initialize(open: false, **attrs)
|
6
|
+
@open = open
|
7
|
+
super(**attrs)
|
8
|
+
end
|
9
9
|
|
10
|
-
|
11
|
-
|
12
|
-
|
10
|
+
def template(&block)
|
11
|
+
div(**attrs, &block)
|
12
|
+
end
|
13
13
|
|
14
|
-
|
14
|
+
private
|
15
15
|
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
end
|
16
|
+
def default_attrs
|
17
|
+
{
|
18
|
+
data: {
|
19
|
+
controller: "alert-dialog",
|
20
|
+
alert_dialog_open_value: @open
|
21
|
+
},
|
22
|
+
class: "inline-block"
|
23
|
+
}
|
25
24
|
end
|
25
|
+
end
|
26
26
|
end
|
@@ -1,33 +1,33 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module PhlexUI
|
4
|
-
|
5
|
-
|
6
|
-
|
4
|
+
class AspectRatio < Base
|
5
|
+
def initialize(aspect_ratio: "16/9", **attrs)
|
6
|
+
raise "aspect_ratio must be in the format of a string with a slash in the middle (eg. '16/9', '1/1')" unless aspect_ratio.is_a?(String) && aspect_ratio.include?("/")
|
7
7
|
|
8
|
-
|
9
|
-
|
10
|
-
|
8
|
+
@aspect_ratio = aspect_ratio
|
9
|
+
super(**attrs)
|
10
|
+
end
|
11
11
|
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
12
|
+
def template(&block)
|
13
|
+
div(
|
14
|
+
class: "relative w-full",
|
15
|
+
style: "padding-bottom: #{padding_bottom}%;"
|
16
|
+
) do
|
17
|
+
div(**attrs, &block)
|
18
|
+
end
|
19
|
+
end
|
20
20
|
|
21
|
-
|
21
|
+
private
|
22
22
|
|
23
|
-
|
24
|
-
|
25
|
-
|
23
|
+
def padding_bottom
|
24
|
+
@aspect_ratio.split("/").map(&:to_i).reverse.reduce(&:fdiv) * 100
|
25
|
+
end
|
26
26
|
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
end
|
27
|
+
def default_attrs
|
28
|
+
{
|
29
|
+
class: "bg-muted absolute inset-0 [&>img]:object-cover [&>img]:absolute [&>img]:h-full [&>img]:w-full [&>img]:inset-0 [&>img]:text-transparent"
|
30
|
+
}
|
32
31
|
end
|
33
|
-
end
|
32
|
+
end
|
33
|
+
end
|
@@ -1,75 +1,73 @@
|
|
1
1
|
module PhlexUI
|
2
|
-
|
3
|
-
|
4
|
-
|
2
|
+
class AttributeMerger
|
3
|
+
attr_reader :default_attrs, :user_attrs
|
4
|
+
OVERRIDE_KEY = "!".freeze
|
5
5
|
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
def call
|
12
|
-
merged_attrs = merge_hashes(default_attrs, non_override_attrs)
|
13
|
-
mix(merged_attrs, override_attrs)
|
14
|
-
end
|
6
|
+
def initialize(default_attrs, user_attrs)
|
7
|
+
@default_attrs = flatten_hash(default_attrs)
|
8
|
+
@user_attrs = flatten_hash(user_attrs)
|
9
|
+
end
|
15
10
|
|
16
|
-
|
11
|
+
def call
|
12
|
+
merged_attrs = merge_hashes(default_attrs, non_override_attrs)
|
13
|
+
mix(merged_attrs, override_attrs)
|
14
|
+
end
|
17
15
|
|
18
|
-
|
19
|
-
def mix(*args)
|
20
|
-
args.each_with_object({}) do |object, result|
|
21
|
-
result.merge!(object) do |_key, old, new|
|
22
|
-
case new
|
23
|
-
when Hash
|
24
|
-
old.is_a?(Hash) ? mix(old, new) : new
|
25
|
-
when Array
|
26
|
-
old.is_a?(Array) ? (old + new) : new
|
27
|
-
when String
|
28
|
-
old.is_a?(String) ? "#{old} #{new}" : new
|
29
|
-
else
|
30
|
-
new
|
31
|
-
end
|
32
|
-
end
|
16
|
+
private
|
33
17
|
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
18
|
+
# @return [Hash]
|
19
|
+
def mix(*args)
|
20
|
+
args.each_with_object({}) do |object, result|
|
21
|
+
result.merge!(object) do |_key, old, new|
|
22
|
+
case new
|
23
|
+
when Hash
|
24
|
+
old.is_a?(Hash) ? mix(old, new) : new
|
25
|
+
when Array
|
26
|
+
old.is_a?(Array) ? (old + new) : new
|
27
|
+
when String
|
28
|
+
old.is_a?(String) ? "#{old} #{new}" : new
|
29
|
+
else
|
30
|
+
new
|
31
|
+
end
|
38
32
|
end
|
39
33
|
|
40
|
-
|
41
|
-
|
42
|
-
key.to_s.include?(OVERRIDE_KEY)
|
43
|
-
end
|
34
|
+
result.transform_keys! do |key|
|
35
|
+
key.end_with?("!") ? key.name.chop.to_sym : key
|
44
36
|
end
|
37
|
+
end
|
38
|
+
end
|
45
39
|
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
40
|
+
def override_attrs
|
41
|
+
user_attrs.select do |key, value|
|
42
|
+
key.to_s.include?(OVERRIDE_KEY)
|
43
|
+
end
|
44
|
+
end
|
51
45
|
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
else
|
58
|
-
result_hash[new_key] = value
|
59
|
-
end
|
60
|
-
end
|
61
|
-
result_hash
|
62
|
-
end
|
46
|
+
def non_override_attrs
|
47
|
+
user_attrs.reject do |key, value|
|
48
|
+
key.to_s.include?(OVERRIDE_KEY)
|
49
|
+
end
|
50
|
+
end
|
63
51
|
|
64
|
-
|
65
|
-
|
66
|
-
|
52
|
+
def flatten_hash(hash, parent_key = "", result_hash = {})
|
53
|
+
hash.each do |key, value|
|
54
|
+
new_key = parent_key.empty? ? key : :"#{parent_key}_#{key}"
|
55
|
+
if value.is_a? Hash
|
56
|
+
flatten_hash(value, new_key, result_hash)
|
57
|
+
else
|
58
|
+
result_hash[new_key] = value
|
59
|
+
end
|
60
|
+
end
|
61
|
+
result_hash
|
62
|
+
end
|
67
63
|
|
68
|
-
|
69
|
-
|
70
|
-
|
64
|
+
def merge_hashes(hash1, hash2)
|
65
|
+
flat_hash1 = flatten_hash(hash1)
|
66
|
+
flat_hash2 = flatten_hash(hash2)
|
71
67
|
|
72
|
-
|
73
|
-
|
68
|
+
flat_hash1.merge(flat_hash2) do |key, oldval, newval|
|
69
|
+
"#{oldval} #{newval}"
|
70
|
+
end
|
74
71
|
end
|
75
|
-
end
|
72
|
+
end
|
73
|
+
end
|
@@ -0,0 +1,36 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PhlexUI
|
4
|
+
class Avatar::Builder < Base
|
5
|
+
def initialize(size: :md, src: nil, alt: nil, initials: nil, **attrs)
|
6
|
+
@size = size
|
7
|
+
@src = src
|
8
|
+
@alt = alt
|
9
|
+
@initials = initials
|
10
|
+
super(**attrs)
|
11
|
+
end
|
12
|
+
|
13
|
+
def template
|
14
|
+
render PhlexUI::Avatar.new(size: @size, **attrs) do
|
15
|
+
render_image if @src
|
16
|
+
render_initials if @initials
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
private
|
21
|
+
|
22
|
+
def render_image
|
23
|
+
render ::PhlexUI::Avatar::Image.new(src: @src, alt: @alt)
|
24
|
+
end
|
25
|
+
|
26
|
+
def render_initials
|
27
|
+
render ::PhlexUI::Avatar::Fallback.new { @initials }
|
28
|
+
end
|
29
|
+
|
30
|
+
def default_attrs
|
31
|
+
{
|
32
|
+
class: tokens("relative flex shrink-0 overflow-hidden rounded-full", @size_classes)
|
33
|
+
}
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
@@ -1,17 +1,17 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module PhlexUI
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
4
|
+
class Avatar::Fallback < Base
|
5
|
+
def template(&block)
|
6
|
+
span(**attrs, &block)
|
7
|
+
end
|
8
8
|
|
9
|
-
|
9
|
+
private
|
10
10
|
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
end
|
11
|
+
def default_attrs
|
12
|
+
{
|
13
|
+
class: "flex h-full w-full items-center justify-center rounded-full bg-muted"
|
14
|
+
}
|
16
15
|
end
|
17
|
-
end
|
16
|
+
end
|
17
|
+
end
|
@@ -1,26 +1,26 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module PhlexUI
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
4
|
+
class Avatar::Image < Base
|
5
|
+
def initialize(src:, alt: "", **attrs)
|
6
|
+
@src = src
|
7
|
+
@alt = alt
|
8
|
+
super(**attrs)
|
9
|
+
end
|
10
10
|
|
11
|
-
|
12
|
-
|
13
|
-
|
11
|
+
def template
|
12
|
+
img(**attrs)
|
13
|
+
end
|
14
14
|
|
15
|
-
|
15
|
+
private
|
16
16
|
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
end
|
17
|
+
def default_attrs
|
18
|
+
{
|
19
|
+
loading: "lazy",
|
20
|
+
class: "aspect-square h-full w-full",
|
21
|
+
alt: @alt,
|
22
|
+
src: @src
|
23
|
+
}
|
25
24
|
end
|
26
|
-
end
|
25
|
+
end
|
26
|
+
end
|
data/lib/phlex_ui/avatar.rb
CHANGED
@@ -1,49 +1,31 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module PhlexUI
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
4
|
+
class Avatar < Base
|
5
|
+
SIZES = {
|
6
|
+
xs: "h-4 w-4 text-[0.5rem]",
|
7
|
+
sm: "h-6 w-6 text-xs",
|
8
|
+
md: "h-10 w-10 text-base",
|
9
|
+
lg: "h-14 w-14 text-xl",
|
10
|
+
xl: "h-20 w-20 text-3xl"
|
11
|
+
}
|
12
12
|
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
@size_classes = SIZES[@size]
|
19
|
-
super(**attrs)
|
20
|
-
end
|
21
|
-
|
22
|
-
def template(&block)
|
23
|
-
if block_given?
|
24
|
-
span(**attrs, &block)
|
25
|
-
else
|
26
|
-
span(**attrs) do
|
27
|
-
render_image if @src
|
28
|
-
render_initials
|
29
|
-
end
|
30
|
-
end
|
31
|
-
end
|
32
|
-
|
33
|
-
private
|
13
|
+
def initialize(size: :md, **attrs)
|
14
|
+
@size = size
|
15
|
+
@size_classes = SIZES[@size]
|
16
|
+
super(**attrs)
|
17
|
+
end
|
34
18
|
|
35
|
-
|
36
|
-
|
37
|
-
|
19
|
+
def template(&block)
|
20
|
+
span(**attrs, &block)
|
21
|
+
end
|
38
22
|
|
39
|
-
|
40
|
-
render ::PhlexUI::Avatar::Fallback.new { @initials }
|
41
|
-
end
|
23
|
+
private
|
42
24
|
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
end
|
25
|
+
def default_attrs
|
26
|
+
{
|
27
|
+
class: tokens("relative flex shrink-0 overflow-hidden rounded-full", @size_classes)
|
28
|
+
}
|
48
29
|
end
|
49
|
-
end
|
30
|
+
end
|
31
|
+
end
|
data/lib/phlex_ui/badge.rb
CHANGED
@@ -1,60 +1,60 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module PhlexUI
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
4
|
+
class Badge < Base
|
5
|
+
SIZES = {
|
6
|
+
sm: "px-1.5 py-0.5 text-xs",
|
7
|
+
md: "px-2 py-1 text-xs",
|
8
|
+
lg: "px-3 py-1 text-sm"
|
9
|
+
}
|
10
10
|
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
11
|
+
COLORS = {
|
12
|
+
primary: "text-primary bg-primary/5 ring-primary/20",
|
13
|
+
secondary: "text-secondary bg-secondary/10 ring-secondary/20",
|
14
|
+
outline: "text-foreground bg-background ring-border",
|
15
|
+
destructive: "text-destructive bg-destructive/10 ring-destructive/20",
|
16
|
+
success: "text-success bg-success/10 ring-success/20",
|
17
|
+
warning: "text-warning bg-warning/10 ring-warning/20",
|
18
|
+
slate: "text-slate-500 bg-slate-500/10 ring-slate-500/20",
|
19
|
+
gray: "text-gray-500 bg-gray-500/10 ring-gray-500/20",
|
20
|
+
zinc: "text-zinc-500 bg-zinc-500/10 ring-zinc-500/20",
|
21
|
+
neutral: "text-neutral-500 bg-neutral-500/10 ring-neutral-500/20",
|
22
|
+
stone: "text-stone-500 bg-stone-500/10 ring-stone-500/20",
|
23
|
+
red: "text-red-500 bg-red-500/10 ring-red-500/20",
|
24
|
+
orange: "text-orange-500 bg-orange-500/10 ring-orange-500/20",
|
25
|
+
amber: "text-amber-500 bg-amber-500/10 ring-amber-500/20",
|
26
|
+
yellow: "text-yellow-500 bg-yellow-500/10 ring-yellow-500/20",
|
27
|
+
lime: "text-lime-500 bg-lime-500/10 ring-lime-500/20",
|
28
|
+
green: "text-green-500 bg-green-500/10 ring-green-500/20",
|
29
|
+
emerald: "text-emerald-500 bg-emerald-500/10 ring-emerald-500/20",
|
30
|
+
teal: "text-teal-500 bg-teal-500/10 ring-teal-500/20",
|
31
|
+
cyan: "text-cyan-500 bg-cyan-500/10 ring-cyan-500/20",
|
32
|
+
sky: "text-sky-500 bg-sky-500/10 ring-sky-500/20",
|
33
|
+
blue: "text-blue-500 bg-blue-500/10 ring-blue-500/20",
|
34
|
+
indigo: "text-indigo-500 bg-indigo-500/10 ring-indigo-500/20",
|
35
|
+
violet: "text-violet-500 bg-violet-500/10 ring-violet-500/20",
|
36
|
+
purple: "text-purple-500 bg-purple-500/10 ring-purple-500/20",
|
37
|
+
fuchsia: "text-fuchsia-500 bg-fuchsia-500/10 ring-fuchsia-500/20",
|
38
|
+
pink: "text-pink-500 bg-pink-500/10 ring-pink-500/20",
|
39
|
+
rose: "text-rose-500 bg-rose-500/10 ring-rose-500/20"
|
40
|
+
}
|
41
41
|
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
42
|
+
def initialize(variant: :primary, size: :md, **args)
|
43
|
+
@variant = variant
|
44
|
+
@size = size
|
45
|
+
super(**args)
|
46
|
+
end
|
47
47
|
|
48
|
-
|
49
|
-
|
50
|
-
|
48
|
+
def template(&block)
|
49
|
+
span(**attrs, &block)
|
50
|
+
end
|
51
51
|
|
52
|
-
|
52
|
+
private
|
53
53
|
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
end
|
54
|
+
def default_attrs
|
55
|
+
{
|
56
|
+
class: tokens("inline-flex items-center rounded-md font-medium ring-1 ring-inset", SIZES[@size], COLORS[@variant])
|
57
|
+
}
|
59
58
|
end
|
59
|
+
end
|
60
60
|
end
|