phlex 1.3.1 → 1.4.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.
Potentially problematic release.
This version of phlex might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/.rubocop.yml +2 -24
- data/.ruby-version +1 -1
- data/Gemfile +1 -0
- data/README.md +1 -0
- data/fixtures/view_helper.rb +6 -0
- data/lib/phlex/black_hole.rb +7 -9
- data/lib/phlex/callable.rb +3 -5
- data/lib/phlex/deferred_render.rb +2 -4
- data/lib/phlex/elements.rb +56 -50
- data/lib/phlex/helpers.rb +5 -2
- data/lib/phlex/html/standard_elements.rb +590 -0
- data/lib/phlex/html/void_elements.rb +79 -0
- data/lib/phlex/html.rb +14 -410
- data/lib/{overrides → phlex/overrides}/symbol/name.rb +1 -1
- data/lib/phlex/sgml.rb +315 -0
- data/lib/phlex/svg/standard_elements.rb +391 -0
- data/lib/phlex/svg.rb +11 -0
- data/lib/phlex/testing/view_helper.rb +10 -8
- data/lib/phlex/unbuffered.rb +34 -36
- data/lib/phlex/version.rb +1 -1
- data/lib/phlex.rb +5 -1
- metadata +9 -5
- data/lib/phlex/buffered.rb +0 -19
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: a8a6c8dfab161746b6b4e04d403fead1f2477f195ff27e72365838f169ecc287
|
4
|
+
data.tar.gz: e9e9da3414eba5fc53d5440b16c0eecf47d4fc5d09a178fe44c9acab3f554119
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 043c059dd8ce067a50df40c293d61475892acc934a4efdd18bedae7094ebaea3c9dd11a4bc5e5b7779120d38966964a2725dcd17de3dca2de48c50e837e2e8fd
|
7
|
+
data.tar.gz: 00edaf160d669c8f62f40c4f66faf17a6b76b2428648be0d7c7977ad629b119a146cfacffc8636312f87e46b77cdfc3074fe39ade0b4ff45ee10e874f0459a31
|
data/.rubocop.yml
CHANGED
@@ -5,27 +5,5 @@ inherit_from:
|
|
5
5
|
AllCops:
|
6
6
|
TargetRubyVersion: 2.7
|
7
7
|
|
8
|
-
Style/
|
9
|
-
Enabled: false
|
10
|
-
|
11
|
-
Layout/CaseIndentation:
|
12
|
-
Enabled: false
|
13
|
-
|
14
|
-
Style/StringConcatenation:
|
15
|
-
Enabled: false
|
16
|
-
|
17
|
-
Style/CaseEquality:
|
18
|
-
Enabled: false
|
19
|
-
|
20
|
-
Security/Eval:
|
21
|
-
Enabled: false
|
22
|
-
|
23
|
-
Style/MethodCallWithoutArgsParentheses:
|
24
|
-
Enabled: false
|
25
|
-
|
26
|
-
Style/MixinUsage:
|
27
|
-
Enabled: false
|
28
|
-
|
29
|
-
Style/AccessModifierDeclarations:
|
30
|
-
Enabled: true
|
31
|
-
EnforcedStyle: inline
|
8
|
+
Style/ExplicitBlockArgument:
|
9
|
+
Enabled: false
|
data/.ruby-version
CHANGED
@@ -1 +1 @@
|
|
1
|
-
3.2.
|
1
|
+
3.2.1
|
data/Gemfile
CHANGED
data/README.md
CHANGED
@@ -43,3 +43,4 @@ Thanks [Logology](https://www.logology.co) for sponsoring our logo.
|
|
43
43
|
- [hoshi](https://github.com/pete/hoshi)
|
44
44
|
- [hyperstack](https://github.com/hyperstack-org/hyperstack)
|
45
45
|
- [clearwater](https://github.com/clearwater-rb/clearwater)
|
46
|
+
- [paggio](https://github.com/opal/paggio)
|
data/fixtures/view_helper.rb
CHANGED
data/lib/phlex/black_hole.rb
CHANGED
@@ -1,15 +1,13 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
module Phlex
|
4
|
-
|
5
|
-
extend self
|
3
|
+
module Phlex::BlackHole
|
4
|
+
extend self
|
6
5
|
|
7
|
-
|
8
|
-
|
9
|
-
|
6
|
+
def <<(anything)
|
7
|
+
self
|
8
|
+
end
|
10
9
|
|
11
|
-
|
12
|
-
|
13
|
-
end
|
10
|
+
def length
|
11
|
+
0
|
14
12
|
end
|
15
13
|
end
|
data/lib/phlex/callable.rb
CHANGED
@@ -1,7 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
module Phlex
|
4
|
-
module
|
5
|
-
# This module doesn't do anything. Phlex::HTML#call checks for its inclusion in the ancestry instead.
|
6
|
-
end
|
3
|
+
module Phlex::DeferredRender
|
4
|
+
# This module doesn't do anything. Phlex::HTML#call checks for its inclusion in the ancestry instead.
|
7
5
|
end
|
data/lib/phlex/elements.rb
CHANGED
@@ -1,57 +1,63 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
if Gem::Version.new(RUBY_VERSION) < Gem::Version.new("3.0")
|
4
|
-
using Overrides::Symbol::Name
|
4
|
+
using Phlex::Overrides::Symbol::Name
|
5
5
|
end
|
6
6
|
|
7
|
-
module Phlex
|
8
|
-
|
9
|
-
|
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
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
7
|
+
module Phlex::Elements
|
8
|
+
def register_element(element, tag: element.name.tr("_", "-"))
|
9
|
+
class_eval(<<-RUBY, __FILE__, __LINE__ + 1)
|
10
|
+
# frozen_string_literal: true
|
11
|
+
|
12
|
+
def #{element}(**attributes, &block)
|
13
|
+
if attributes.length > 0
|
14
|
+
if block_given?
|
15
|
+
@_target << "<#{tag}" << (Phlex::ATTRIBUTE_CACHE[attributes.hash] || __attributes__(**attributes)) << ">"
|
16
|
+
yield_content(&block)
|
17
|
+
@_target << "</#{tag}>"
|
18
|
+
else
|
19
|
+
@_target << "<#{tag}" << (Phlex::ATTRIBUTE_CACHE[attributes.hash] || __attributes__(**attributes)) << "></#{tag}>"
|
20
|
+
end
|
21
|
+
else
|
22
|
+
if block_given?
|
23
|
+
@_target << "<#{tag}>"
|
24
|
+
yield_content(&block)
|
25
|
+
@_target << "</#{tag}>"
|
26
|
+
else
|
27
|
+
@_target << "<#{tag}></#{tag}>"
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
31
|
+
nil
|
32
|
+
end
|
33
|
+
|
34
|
+
alias_method :_#{element}, :#{element}
|
35
|
+
RUBY
|
36
|
+
|
37
|
+
self::REGISTERED_ELEMENTS[element] = tag
|
38
|
+
|
39
|
+
element
|
40
|
+
end
|
41
|
+
|
42
|
+
def register_void_element(element, tag: element.name.tr("_", "-"))
|
43
|
+
class_eval(<<-RUBY, __FILE__, __LINE__ + 1)
|
44
|
+
# frozen_string_literal: true
|
45
|
+
|
46
|
+
def #{element}(**attributes)
|
47
|
+
if attributes.length > 0
|
48
|
+
@_target << "<#{tag}" << (Phlex::ATTRIBUTE_CACHE[attributes.hash] || __attributes__(**attributes)) << ">"
|
49
|
+
else
|
50
|
+
@_target << "<#{tag}>"
|
51
|
+
end
|
52
|
+
|
53
|
+
nil
|
54
|
+
end
|
55
|
+
|
56
|
+
alias_method :_#{element}, :#{element}
|
57
|
+
RUBY
|
58
|
+
|
59
|
+
self::REGISTERED_ELEMENTS[element] = tag
|
60
|
+
|
61
|
+
element
|
56
62
|
end
|
57
63
|
end
|
data/lib/phlex/helpers.rb
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
if Gem::Version.new(RUBY_VERSION) < Gem::Version.new("3.0")
|
4
|
-
using Overrides::Symbol::Name
|
4
|
+
using Phlex::Overrides::Symbol::Name
|
5
5
|
end
|
6
6
|
|
7
7
|
module Phlex::Helpers
|
@@ -25,7 +25,10 @@ module Phlex::Helpers
|
|
25
25
|
end
|
26
26
|
end
|
27
27
|
|
28
|
-
tokens.join(" ")
|
28
|
+
tokens = tokens.select(&:itself).join(" ")
|
29
|
+
tokens.strip!
|
30
|
+
tokens.gsub!(/\s+/, " ")
|
31
|
+
tokens
|
29
32
|
end
|
30
33
|
|
31
34
|
private def __append_token__(tokens, token)
|