vident-phlex 0.2.0 → 0.4.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +9 -1
- data/lib/vident/phlex/core.rb +29 -0
- data/lib/vident/phlex/html.rb +1 -21
- data/lib/vident/phlex/root_component.rb +8 -4
- data/lib/vident/phlex/version.rb +1 -1
- metadata +27 -6
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 491b0cefd3a8305411d28a0f622b26d23353110e3c6b14a1f2dcbee1e66778d3
|
4
|
+
data.tar.gz: 679f4b3f77509ea345f0c656cd47d401407e38289e786cb799cd415bd1a9d73f
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: bbb631b7ff3bc67bcdfda2452defaaedaea85ba97ba286ddf71c17a462c0973ef57e21426f5e46b4e22be11d9df359b87678b18a499dbac64cee8f4bc6deda9d
|
7
|
+
data.tar.gz: 2014550736235ba4d7f9375af0d8ee463943b7481e13855d63d12b47116c2a79e21073c03fdf0b1b4f8de7565d5a73208016292276ab25a2d522070a20c78224
|
data/README.md
CHANGED
@@ -1,5 +1,13 @@
|
|
1
1
|
# Vident::Phlex
|
2
|
-
|
2
|
+
|
3
|
+
[Phlex](https://phlex.fun/) powered [Vident](https://github.com/stevegeek/vident) components.
|
4
|
+
|
5
|
+
```ruby
|
6
|
+
class ApplicationComponent < ::Vident::Phlex::HTML
|
7
|
+
end
|
8
|
+
```
|
9
|
+
|
10
|
+
For more details see [vident](https://github.com/stevegeek/vident).
|
3
11
|
|
4
12
|
## Usage
|
5
13
|
How to use my plugin.
|
@@ -0,0 +1,29 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Vident
|
4
|
+
module Phlex
|
5
|
+
class Core < ::Phlex::HTML
|
6
|
+
class << self
|
7
|
+
def inherited(subclass)
|
8
|
+
subclass.component_source_file_path = caller_locations(1, 10).reject { |l| l.label == "inherited" }[0].path
|
9
|
+
super
|
10
|
+
end
|
11
|
+
|
12
|
+
attr_accessor :component_source_file_path
|
13
|
+
|
14
|
+
# Caching support
|
15
|
+
def current_component_modified_time
|
16
|
+
path = component_source_file_path
|
17
|
+
raise StandardError, "No component source file exists #{path}" unless path && ::File.exist?(path)
|
18
|
+
::File.mtime(path).to_i.to_s
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
# Helper to create the main element
|
23
|
+
def parent_element(**options)
|
24
|
+
@parent_element ||= ::Vident::Phlex::RootComponent.new(**parent_element_attributes(options))
|
25
|
+
end
|
26
|
+
alias_method :root, :parent_element
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
data/lib/vident/phlex/html.rb
CHANGED
@@ -2,15 +2,10 @@
|
|
2
2
|
|
3
3
|
module Vident
|
4
4
|
module Phlex
|
5
|
-
class HTML <
|
5
|
+
class HTML < Core
|
6
6
|
include ::Vident::Component
|
7
7
|
|
8
8
|
class << self
|
9
|
-
def inherited(subclass)
|
10
|
-
subclass.component_source_file_path = caller_locations(1, 10).reject { |l| l.label == "inherited" }[0].path
|
11
|
-
super
|
12
|
-
end
|
13
|
-
|
14
9
|
# Phlex uses a DSL to define the document, and those methods could easily clash with our attribute
|
15
10
|
# accessors. Therefore in Phlex components we do not create attribute accessors, and instead use instance
|
16
11
|
# variables directly.
|
@@ -18,22 +13,7 @@ module Vident
|
|
18
13
|
options[:delegates] = false
|
19
14
|
super
|
20
15
|
end
|
21
|
-
|
22
|
-
attr_accessor :component_source_file_path
|
23
|
-
|
24
|
-
# Caching support
|
25
|
-
def current_component_modified_time
|
26
|
-
path = component_source_file_path
|
27
|
-
raise StandardError, "No component source file exists #{path}" unless path && ::File.exist?(path)
|
28
|
-
::File.mtime(path).to_i.to_s
|
29
|
-
end
|
30
|
-
end
|
31
|
-
|
32
|
-
# Helper to create the main element
|
33
|
-
def parent_element(**options)
|
34
|
-
@parent_element ||= RootComponent.new(**parent_element_attributes(options))
|
35
16
|
end
|
36
|
-
alias_method :root, :parent_element
|
37
17
|
end
|
38
18
|
end
|
39
19
|
end
|
@@ -23,7 +23,7 @@ module Vident
|
|
23
23
|
parsed = parse_targets(Array.wrap(targets))
|
24
24
|
options[:data] ||= {}
|
25
25
|
options[:data].merge!(build_target_data_attributes(parsed))
|
26
|
-
generate_tag(tag_name, **options, &block)
|
26
|
+
generate_tag(tag_name, nil, **options, &block)
|
27
27
|
end
|
28
28
|
|
29
29
|
# Build a tag with the attributes determined by this components properties and stimulus
|
@@ -33,18 +33,22 @@ module Vident
|
|
33
33
|
tag_type = @element_tag.presence&.to_sym || :div
|
34
34
|
raise ArgumentError, "Unsupported HTML tag name #{tag_type}" unless VALID_TAGS.include?(tag_type)
|
35
35
|
options = @html_options&.dup || {}
|
36
|
+
block_content = capture(&block) if block # Evaluate before generating the outer tag options to ensure DSL methods are executed
|
36
37
|
data_attrs = tag_data_attributes
|
37
38
|
data_attrs = options[:data].present? ? data_attrs.merge(options[:data]) : data_attrs
|
38
39
|
options = options.merge(id: @id) if @id
|
39
40
|
options.except!(:data)
|
40
41
|
options.merge!(data_attrs.transform_keys { |k| "data-#{k}" })
|
41
|
-
generate_tag(tag_type, **options
|
42
|
+
generate_tag(tag_type, block_content, **options)
|
42
43
|
end
|
43
44
|
|
44
45
|
private
|
45
46
|
|
46
|
-
def generate_tag(tag_type, **options, &block)
|
47
|
-
|
47
|
+
def generate_tag(tag_type, content, **options, &block)
|
48
|
+
# FIXME: Content was generated by the block, we assume its safe but that might not be true!
|
49
|
+
method_name = (tag_type == :template) ? :template_tag : tag_type
|
50
|
+
block = proc { unsafe_raw content } if !block && content
|
51
|
+
send(method_name, **options, &block)
|
48
52
|
end
|
49
53
|
end
|
50
54
|
end
|
data/lib/vident/phlex/version.rb
CHANGED
metadata
CHANGED
@@ -1,17 +1,17 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: vident-phlex
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.4.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Stephen Ierodiaconou
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2024-02-21 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
|
-
name:
|
14
|
+
name: railties
|
15
15
|
requirement: !ruby/object:Gem::Requirement
|
16
16
|
requirements:
|
17
17
|
- - ">="
|
@@ -19,7 +19,7 @@ dependencies:
|
|
19
19
|
version: '7'
|
20
20
|
- - "<"
|
21
21
|
- !ruby/object:Gem::Version
|
22
|
-
version: '8'
|
22
|
+
version: '8.0'
|
23
23
|
type: :runtime
|
24
24
|
prerelease: false
|
25
25
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -29,7 +29,27 @@ dependencies:
|
|
29
29
|
version: '7'
|
30
30
|
- - "<"
|
31
31
|
- !ruby/object:Gem::Version
|
32
|
-
version: '8'
|
32
|
+
version: '8.0'
|
33
|
+
- !ruby/object:Gem::Dependency
|
34
|
+
name: activesupport
|
35
|
+
requirement: !ruby/object:Gem::Requirement
|
36
|
+
requirements:
|
37
|
+
- - ">="
|
38
|
+
- !ruby/object:Gem::Version
|
39
|
+
version: '7'
|
40
|
+
- - "<"
|
41
|
+
- !ruby/object:Gem::Version
|
42
|
+
version: '8.0'
|
43
|
+
type: :runtime
|
44
|
+
prerelease: false
|
45
|
+
version_requirements: !ruby/object:Gem::Requirement
|
46
|
+
requirements:
|
47
|
+
- - ">="
|
48
|
+
- !ruby/object:Gem::Version
|
49
|
+
version: '7'
|
50
|
+
- - "<"
|
51
|
+
- !ruby/object:Gem::Version
|
52
|
+
version: '8.0'
|
33
53
|
- !ruby/object:Gem::Dependency
|
34
54
|
name: vident
|
35
55
|
requirement: !ruby/object:Gem::Requirement
|
@@ -101,6 +121,7 @@ files:
|
|
101
121
|
- Rakefile
|
102
122
|
- lib/tasks/vident/phlex_tasks.rake
|
103
123
|
- lib/vident/phlex.rb
|
124
|
+
- lib/vident/phlex/core.rb
|
104
125
|
- lib/vident/phlex/engine.rb
|
105
126
|
- lib/vident/phlex/html.rb
|
106
127
|
- lib/vident/phlex/root_component.rb
|
@@ -127,7 +148,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
127
148
|
- !ruby/object:Gem::Version
|
128
149
|
version: '0'
|
129
150
|
requirements: []
|
130
|
-
rubygems_version: 3.
|
151
|
+
rubygems_version: 3.5.3
|
131
152
|
signing_key:
|
132
153
|
specification_version: 4
|
133
154
|
summary: Vident with Phlex
|