nitro_kit 0.8.0 → 0.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 3f96e86485be82839eb17fea8522c31b8bac982f5b9e09a479d159e9f69b59f7
4
- data.tar.gz: 41814a0fc817bd11dab95a132de45a83c300c52a39cf3d407e0174c0a6af9584
3
+ metadata.gz: 06ec36dc808b0223864423889cf64d62465c925e111a49d334110aadfa0859a3
4
+ data.tar.gz: 9a1f9f81419b52fcfb8c5a956e134f424419a4c5b922ecc68d820f3bfb135a9d
5
5
  SHA512:
6
- metadata.gz: 73c6883c42f6cab78d4fe6550ea88dda8c0546ae33c6c9f9696b894bbba47d98a381de82385c754f41e56f1971177876c2ca2e1460ee53243ee4eba82f7ddd74
7
- data.tar.gz: 81998e474d6125fcc2bd6fa094223c3e4470261519049535c0301922873325206c50ad49b6c4756be1914f0a88bb915a7221f1b99c75018120cb6f26dd34f321
6
+ metadata.gz: dd3df11e3987edb2be111e580442b9ccac3d3e1f414bdb7933469f1ab7d1c29cf0e3b17648eb01793301ea64b8880a776d545428b34e76aabf779c9161e7c889
7
+ data.tar.gz: b5ef21b4509537b8e373278ea1fa52e08d154e5a46869c942ad39f2fe69888ba2cb215a85e00e1e34f196a94afbace25e2a6b1ed744ef18116724462b2a22676
@@ -0,0 +1,49 @@
1
+ @import "tailwindcss";
2
+
3
+ @theme {
4
+ --color-foreground: var(--color-zinc-900);
5
+ --color-background: var(--color-white);
6
+
7
+ --color-border: var(--color-zinc-200);
8
+ --color-ring: var(--color-blue-600);
9
+ --color-muted: var(--color-zinc-100);
10
+ --color-muted-content: var(--color-zinc-500);
11
+ --color-primary: var(--color-zinc-800);
12
+ --color-primary-content: var(--zinc-800);
13
+ --color-primary-foreground: var(--color-zinc-100);
14
+ --color-destructive: var(--color-red-500);
15
+ --color-destructive-content: var(--color-red-800);
16
+ --color-destructive-foreground: var(--color-white);
17
+ }
18
+
19
+ @layer base {
20
+ [data-theme="dark"] {
21
+ --color-foreground: var(--color-zinc-100);
22
+ --color-background: var(--color-zinc-950);
23
+
24
+ --color-border: var(--color-zinc-700);
25
+ --color-ring: var(--color-blue-700);
26
+ --color-muted: var(--color-zinc-800);
27
+ --color-muted-content: var(--color-zinc-400);
28
+ --color-primary: var(--color-zinc-50);
29
+ --color-primary-content: var(--color-zinc-50);
30
+ --color-primary-foreground: var(--color-zinc-900);
31
+ --color-destructive: var(--color-red-900);
32
+ --color-destructive-content: var(--color-red-600);
33
+ --color-destructive-foreground: var(--color-white);
34
+ }
35
+ }
36
+
37
+ @variant dark (&:where([data-theme="dark"], [data-theme="dark"] *));
38
+
39
+ @layer base {
40
+ * {
41
+ @apply border-border ring-ring min-w-0;
42
+ }
43
+
44
+ body {
45
+ /* Nitro Kit looks great in Inter as well */
46
+ /* https://rsms.me/inter */
47
+ @apply bg-background text-foreground font-sans;
48
+ }
49
+ }
@@ -56,8 +56,8 @@ module NitroKit
56
56
 
57
57
  def view_template
58
58
  div(
59
+ class: "isolate",
59
60
  data: {
60
- class: "isolate",
61
61
  slot: "control",
62
62
  controller: "nk--combobox",
63
63
  nk__combobox_placement_value: placement,
@@ -13,7 +13,7 @@ module NitroKit
13
13
  end
14
14
 
15
15
  def builder(&block)
16
- @_nk_from_template ? capture(&block) : yield
16
+ @_nk_from_template && !self.is_a?(NitroKit::Component) ? capture(&block) : yield
17
17
  end
18
18
 
19
19
  private
@@ -117,7 +117,11 @@ module NitroKit
117
117
 
118
118
  def destructive_item_to(text_or_block, href = nil, **attrs, &block)
119
119
  builder do
120
- href = args.shift if block_given?
120
+ if block_given?
121
+ href = text_or_block
122
+ text_or_block = nil
123
+ end
124
+
121
125
  destructive_item(text_or_block, href: href, **attrs, &block)
122
126
  end
123
127
  end
@@ -15,7 +15,7 @@ module NitroKit
15
15
  )
16
16
  end
17
17
 
18
- attr_reader :value, :options, :include_empty, :prompts, :index
18
+ attr_reader :value, :options, :include_empty, :prompt, :index
19
19
 
20
20
  def view_template
21
21
  span(class: wrapper_class, data: { slot: "control" }) do
@@ -1,9 +1,13 @@
1
1
  # frozen_string_literal: true
2
2
 
3
+ begin
4
+ require "pagy/toolbox/helpers/support/series"
5
+ rescue LoadError
6
+ # Pagy isn't around
7
+ end
8
+
3
9
  module NitroKit
4
10
  module PaginationHelper
5
- include Pagy::UrlHelpers if defined?(Pagy)
6
-
7
11
  def nk_pagination(**attrs, &block)
8
12
  render(Pagination.from_template(**attrs), &block)
9
13
  end
@@ -12,16 +16,16 @@ module NitroKit
12
16
  attrs[:aria] ||= { label: aria_label }
13
17
 
14
18
  nk_pagination(id:, **attrs) do |p|
15
- if prev_page = pagy.prev
16
- p.prev(href: pagy_url_for(pagy, prev_page))
19
+ if prev_page = pagy.previous
20
+ p.prev(href: pagy.page_url(prev_page))
17
21
  else
18
22
  p.prev(disabled: true)
19
23
  end
20
24
 
21
- pagy.series.each do |item|
25
+ pagy.send(:series).each do |item|
22
26
  case item
23
27
  when Integer
24
- p.page(item.to_s, href: pagy_url_for(pagy, item))
28
+ p.page(item.to_s, href: pagy.page_url(item))
25
29
  when String
26
30
  p.page(item, current: true)
27
31
  when :gap
@@ -32,7 +36,7 @@ module NitroKit
32
36
  end
33
37
 
34
38
  if next_page = pagy.next
35
- p.next(href: pagy_url_for(pagy, next_page))
39
+ p.next(href: pagy.page_url(next_page))
36
40
  else
37
41
  p.next(disabled: true)
38
42
  end
@@ -1,3 +1,5 @@
1
+ require "set"
2
+
1
3
  module NitroKit
2
4
  module SchemaBuilder
3
5
  class Component
@@ -21,12 +23,18 @@ module NitroKit
21
23
  def resolve!
22
24
  raise "Component already resolved" if resolved?
23
25
 
24
- @dependencies = @unresolved_dependencies
25
- .each_with_object(Set.new) do |name, list|
26
- list.add(name)
27
- list.merge(@schema.find(name).unresolved_dependencies)
28
- end
29
- .map { |name| @schema.find(name) }
26
+ dependencies = Set.new
27
+ stack = @unresolved_dependencies.dup
28
+
29
+ until stack.empty?
30
+ name = stack.pop
31
+ next if dependencies.include?(name)
32
+
33
+ dependencies.add(name)
34
+ stack.concat(@schema.find(name).unresolved_dependencies)
35
+ end
36
+
37
+ @dependencies = dependencies.map { |name| @schema.find(name) }
30
38
 
31
39
  @resolved = true
32
40
  end
@@ -1,3 +1,3 @@
1
1
  module NitroKit
2
- VERSION = "0.8.0"
2
+ VERSION = "0.9.0"
3
3
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: nitro_kit
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.8.0
4
+ version: 0.9.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Mikkel Malmberg
@@ -60,6 +60,7 @@ extra_rdoc_files: []
60
60
  files:
61
61
  - README.md
62
62
  - Rakefile
63
+ - app/assets/tailwind/application.css
63
64
  - app/components/nitro_kit/accordion.rb
64
65
  - app/components/nitro_kit/alert.rb
65
66
  - app/components/nitro_kit/avatar.rb
@@ -157,7 +158,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
157
158
  - !ruby/object:Gem::Version
158
159
  version: '0'
159
160
  requirements: []
160
- rubygems_version: 3.7.1
161
+ rubygems_version: 4.0.3
161
162
  specification_version: 4
162
163
  summary: WIP, not usable yet
163
164
  test_files: []