isomorfeus-data 2.0.1 → 2.0.5
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:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 455e8b083641020d3d3dfa97b34d4144087fb19c11f551c240cdf4e946f60df0
|
4
|
+
data.tar.gz: 20f440fa635643a147bbcfb2571b9bcb0afcef57e57977de08725ac7cf732870
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 46f6c764a5d12fe8b46730ee1cc1b18d8a99a52c56fff668143abcd30a4961b55813f9bbc8840c7ca80a8bf365b8faa3f3a06a6a0d0fc802dc2f4037f2a6a406
|
7
|
+
data.tar.gz: e34bd37b4b16359a2cf14a863fefd327cac00568f9048c1466c6061cc922072046bca750fcd36be150fac6e7876c96671d7d5f71c4b3715610e773b37f910cc6
|
@@ -108,8 +108,10 @@ module LucidDocument
|
|
108
108
|
|
109
109
|
execute_load do |key:|
|
110
110
|
doc = self.ferret_accelerator.load_doc(key)
|
111
|
-
doc
|
112
|
-
|
111
|
+
if doc
|
112
|
+
doc.delete(:key)
|
113
|
+
self.new(key: key, fields: doc)
|
114
|
+
end
|
113
115
|
end
|
114
116
|
|
115
117
|
execute_save do
|
@@ -1,6 +1,10 @@
|
|
1
1
|
class LucidQueryResult
|
2
2
|
attr_reader :key
|
3
3
|
|
4
|
+
def [](accessor_name)
|
5
|
+
self.send(accessor_name.to_sym)
|
6
|
+
end
|
7
|
+
|
4
8
|
def sid
|
5
9
|
[@class_name, @key]
|
6
10
|
end
|
@@ -40,14 +44,18 @@ class LucidQueryResult
|
|
40
44
|
end
|
41
45
|
|
42
46
|
def method_missing(accessor_name, *args, &block)
|
43
|
-
|
47
|
+
sid_or_array = if @result_set
|
44
48
|
@result_set[accessor_name]
|
45
49
|
else
|
46
50
|
stored_results = Redux.fetch_by_path(:data_state, @class_name, @key)
|
47
51
|
stored_results.JS[accessor_name] if stored_results
|
48
52
|
end
|
49
|
-
Isomorfeus.raise_error(message: "#{@class_name}: no such thing '#{accessor_name}' in the results!") unless
|
50
|
-
|
53
|
+
Isomorfeus.raise_error(message: "#{@class_name}: no such thing '#{accessor_name}' in the results!") unless sid_or_array
|
54
|
+
if stored_results.JS['_is_array_']
|
55
|
+
sid_or_array.map { |sid| Isomorfeus.instance_from_sid(sid) }
|
56
|
+
else
|
57
|
+
Isomorfeus.instance_from_sid(sid_or_array)
|
58
|
+
end
|
51
59
|
end
|
52
60
|
else
|
53
61
|
def initialize(key: nil, result_set: {})
|
@@ -77,8 +85,13 @@ class LucidQueryResult
|
|
77
85
|
|
78
86
|
def to_transport
|
79
87
|
sids_hash = {}
|
80
|
-
@result_set.each do |key,
|
81
|
-
|
88
|
+
@result_set.each do |key, value_or_array|
|
89
|
+
if value_or_array.class == Array
|
90
|
+
sids_hash[key.to_s] = value_or_array.map(&:sid)
|
91
|
+
sids_hash[:_is_array_] = true
|
92
|
+
else
|
93
|
+
sids_hash[key.to_s] = value_or_array.sid
|
94
|
+
end
|
82
95
|
end
|
83
96
|
{ @class_name => { @key => sids_hash }}
|
84
97
|
end
|
@@ -86,9 +99,18 @@ class LucidQueryResult
|
|
86
99
|
def included_items_to_transport
|
87
100
|
data_hash = {}
|
88
101
|
@result_set.each_value do |value|
|
89
|
-
|
90
|
-
|
91
|
-
|
102
|
+
if value.class == Array
|
103
|
+
value.each do |v|
|
104
|
+
data_hash.deep_merge!(v.to_transport)
|
105
|
+
if v.respond_to?(:included_items_to_transport)
|
106
|
+
data_hash.deep_merge!(v.included_items_to_transport)
|
107
|
+
end
|
108
|
+
end
|
109
|
+
else
|
110
|
+
data_hash.deep_merge!(value.to_transport)
|
111
|
+
if value.respond_to?(:included_items_to_transport)
|
112
|
+
data_hash.deep_merge!(value.included_items_to_transport)
|
113
|
+
end
|
92
114
|
end
|
93
115
|
end
|
94
116
|
data_hash
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: isomorfeus-data
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.0.
|
4
|
+
version: 2.0.5
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Jan Biedermann
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2022-01-
|
11
|
+
date: 2022-01-22 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activesupport
|
@@ -86,14 +86,14 @@ dependencies:
|
|
86
86
|
requirements:
|
87
87
|
- - "~>"
|
88
88
|
- !ruby/object:Gem::Version
|
89
|
-
version: 0.12.
|
89
|
+
version: 0.12.3
|
90
90
|
type: :runtime
|
91
91
|
prerelease: false
|
92
92
|
version_requirements: !ruby/object:Gem::Requirement
|
93
93
|
requirements:
|
94
94
|
- - "~>"
|
95
95
|
- !ruby/object:Gem::Version
|
96
|
-
version: 0.12.
|
96
|
+
version: 0.12.3
|
97
97
|
- !ruby/object:Gem::Dependency
|
98
98
|
name: isomorfeus-hamster
|
99
99
|
requirement: !ruby/object:Gem::Requirement
|
@@ -142,28 +142,28 @@ dependencies:
|
|
142
142
|
requirements:
|
143
143
|
- - '='
|
144
144
|
- !ruby/object:Gem::Version
|
145
|
-
version: 2.0.
|
145
|
+
version: 2.0.5
|
146
146
|
type: :runtime
|
147
147
|
prerelease: false
|
148
148
|
version_requirements: !ruby/object:Gem::Requirement
|
149
149
|
requirements:
|
150
150
|
- - '='
|
151
151
|
- !ruby/object:Gem::Version
|
152
|
-
version: 2.0.
|
152
|
+
version: 2.0.5
|
153
153
|
- !ruby/object:Gem::Dependency
|
154
154
|
name: isomorfeus
|
155
155
|
requirement: !ruby/object:Gem::Requirement
|
156
156
|
requirements:
|
157
157
|
- - '='
|
158
158
|
- !ruby/object:Gem::Version
|
159
|
-
version: 2.0.
|
159
|
+
version: 2.0.5
|
160
160
|
type: :development
|
161
161
|
prerelease: false
|
162
162
|
version_requirements: !ruby/object:Gem::Requirement
|
163
163
|
requirements:
|
164
164
|
- - '='
|
165
165
|
- !ruby/object:Gem::Version
|
166
|
-
version: 2.0.
|
166
|
+
version: 2.0.5
|
167
167
|
- !ruby/object:Gem::Dependency
|
168
168
|
name: rake
|
169
169
|
requirement: !ruby/object:Gem::Requirement
|