proscenium 0.12.0-aarch64-linux → 0.13.0-aarch64-linux

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: cebc72a54f5fe16fdfad26be65064d9cd696cd2d35e56bae23fc64bd675a7e99
4
- data.tar.gz: c51d8f44705fd5c9a052a697039c3240096e09d23501d7eee80e3affdb340d71
3
+ metadata.gz: b5fecddd4e8bbc44a48ab7cdecae6bec2722b96b478f399595195d1caa377810
4
+ data.tar.gz: 1bd0c5d707e17f169c5817ed24e187b9e700a4f3c4767b7f4c56c4e8d8dd8fb0
5
5
  SHA512:
6
- metadata.gz: e489971106a5c0e1be424e62ef4b3b57c2cee3a7865aa3fa5366ba0acdfbbe61c88e11c440c9b961c6965c297a777c0cf90456444f65c83d5ec28b043979af5c
7
- data.tar.gz: a67fd3b7cbcfb8c0cfa9f4d83f67a0ff11cdfddcab6a9d039ab9c2bb096297ae4c45dd5b2a038241e0d70b134bf23ca153b819d84975de68138bb358e26acc31
6
+ metadata.gz: f6d128673a6dfb8b4116747e52eb9f68d55168199a42934781555bc1655281d617d71644510ab552793b3ccba5729871a4cd1be8a1c17a95fda816dc17d3b203
7
+ data.tar.gz: 30d12d944cea932c18853708e4e99615c27a6eaeb306460c629c155be59de255bb48a9f851fb39e0b070238f83ee330b984b2d201bef58155c7472450b689a71
data/README.md CHANGED
@@ -552,6 +552,13 @@ css_module 'mypackage/button@big_button'
552
552
  # => "big_button"
553
553
  ```
554
554
 
555
+ `css_module` also accepts a `path` keyword argument, which allows you to specify the path to the CSS
556
+ file. Note that this will use the given path for all class names passed to that instance of `css_module`.
557
+
558
+ ```ruby
559
+ css_module :my_module_name, path: Rails.root.join('app/components/button.css')
560
+ ```
561
+
555
562
  #### In your JavaScript
556
563
 
557
564
  Importing a CSS module from JS will automatically append the stylesheet to the document's head. And the result of the import will be an object of CSS class to module names.
@@ -18,16 +18,20 @@ module Proscenium::CssModule
18
18
  # Accepts one or more CSS class names, and transforms them into CSS module names.
19
19
  #
20
20
  # @param name [String,Symbol,Array<String,Symbol>]
21
+ # @param path [Pathname] the path to the CSS module file to use for the transformation.
21
22
  # @return [String] the transformed CSS module names concatenated as a string.
22
- def css_module(*names)
23
- cssm.class_names(*names, require_prefix: false).map { |name, _| name }.join(' ')
23
+ def css_module(*names, path: nil)
24
+ transformer = path.nil? ? cssm : Transformer.new(path)
25
+ transformer.class_names(*names, require_prefix: false).map { |name, _| name }.join(' ')
24
26
  end
25
27
 
26
28
  # @param name [String,Symbol,Array<String,Symbol>]
29
+ # @param path [Pathname] the path to the CSS file to use for the transformation.
27
30
  # @return [String] the transformed CSS module names concatenated as a string.
28
- def class_names(*names)
31
+ def class_names(*names, path: nil)
29
32
  names = names.flatten.compact
30
- cssm.class_names(*names).map { |name, _| name }.join(' ') unless names.empty?
33
+ transformer = path.nil? ? cssm : Transformer.new(path)
34
+ transformer.class_names(*names).map { |name, _| name }.join(' ') unless names.empty?
31
35
  end
32
36
 
33
37
  private
Binary file
@@ -20,11 +20,24 @@ module Proscenium
20
20
  #
21
21
  # @see CssModule::Transformer#class_names
22
22
  # @param name [String,Symbol,Array<String,Symbol>]
23
- def css_module(*names)
24
- path = Pathname.new(@lookup_context.find(@virtual_path).identifier).sub_ext('')
25
- CssModule::Transformer.new(path).class_names(*names, require_prefix: false).map do |name, _|
26
- name
27
- end.join(' ')
23
+ # @param path [Pathname] the path to the CSS module file to use for the transformation.
24
+ # @return [String] the transformed CSS module names concatenated as a string.
25
+ def css_module(*names, path: nil)
26
+ path ||= Pathname.new(@lookup_context.find(@virtual_path).identifier).sub_ext('')
27
+ CssModule::Transformer.new(path).class_names(*names, require_prefix: false)
28
+ .map { |name, _| name }.join(' ')
29
+ end
30
+
31
+ # @param name [String,Symbol,Array<String,Symbol>]
32
+ # @param path [Pathname] the path to the CSS file to use for the transformation.
33
+ # @return [String] the transformed CSS module names concatenated as a string.
34
+ def class_names(*names, path: nil)
35
+ names = names.flatten.compact
36
+
37
+ return if names.empty?
38
+
39
+ path ||= Pathname.new(@lookup_context.find(@virtual_path).identifier).sub_ext('')
40
+ CssModule::Transformer.new(path).class_names(*names).map { |name, _| name }.join(' ')
28
41
  end
29
42
 
30
43
  def include_stylesheets(**options)
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Proscenium
4
- VERSION = '0.12.0'
4
+ VERSION = '0.13.0'
5
5
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: proscenium
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.12.0
4
+ version: 0.13.0
5
5
  platform: aarch64-linux
6
6
  authors:
7
7
  - Joel Moss
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2023-11-10 00:00:00.000000000 Z
11
+ date: 2023-11-17 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: activesupport
@@ -149,7 +149,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
149
149
  - !ruby/object:Gem::Version
150
150
  version: '0'
151
151
  requirements: []
152
- rubygems_version: 3.4.21
152
+ rubygems_version: 3.4.22
153
153
  signing_key:
154
154
  specification_version: 4
155
155
  summary: The engine powering your Rails frontend