nested_array 2.2.1 → 2.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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 9e82939abe3e113f9ce8e54713fd52221362f5e68f5e510ec00153e5504c7198
4
- data.tar.gz: 7a854bb61bbb605396b154246b71f2c4e482c1356b37f1f6cb9c2bc4bda6e7f4
3
+ metadata.gz: 0b49067e4c7566810e2689fd293994ae2f8c8b5cb40dfab84e7eb73f440dccd6
4
+ data.tar.gz: 3cf05731a72c97d59486f916ac89ce33c3d8c32cd6775e14ceefad498ee11022
5
5
  SHA512:
6
- metadata.gz: 1dc59a5a4ae0393bc3f3ab1156273e5490b2ac9a3495595d9ff23a0d9d3dfd79f215f7762f7a361ab0c0827f4a7bbcd606b105dec23c2b22ec3d92e3faf7f2ac
7
- data.tar.gz: a0a0b98e8f8a3c440a8d8c56f1744352b0f94fbc626cb2380fe0b382fbbae2f52cd84ea05812fa2f03b1bda0402e9f7b6c9fc4139c58030c28307c21b55bb855
6
+ metadata.gz: c79be9c3ad75d6ee6c6d170fdc7116587e3bd0f0924e8a904ca74f2abb0486c9e748325e66173c1055622106ea6e10a20bd107f6e7e4c56398210d867afa46eb
7
+ data.tar.gz: ef2dc1b64710fe0a647f6fd81f0e05cd26ad68abda8a76fb6e4f27c05ccf3be38ca4e5d69bd2d241d692505e619f942df894601dbebdf8b4324ab4e2de7e901f
data/Gemfile CHANGED
@@ -2,4 +2,4 @@ source "https://rubygems.org"
2
2
 
3
3
  gemspec
4
4
 
5
- gem 'activesupport', '~> 5.0', '>= 5.0.0.1'
5
+ gem 'activesupport', '~> 6.0'
data/Gemfile.lock CHANGED
@@ -6,18 +6,19 @@ PATH
6
6
  GEM
7
7
  remote: https://rubygems.org/
8
8
  specs:
9
- activesupport (5.2.4.1)
9
+ activesupport (6.0.3.2)
10
10
  concurrent-ruby (~> 1.0, >= 1.0.2)
11
11
  i18n (>= 0.7, < 2)
12
12
  minitest (~> 5.1)
13
13
  tzinfo (~> 1.1)
14
+ zeitwerk (~> 2.2, >= 2.2.2)
14
15
  awesome_print (1.8.0)
15
16
  byebug (11.0.1)
16
- concurrent-ruby (1.1.5)
17
+ concurrent-ruby (1.1.6)
17
18
  diff-lcs (1.3)
18
- i18n (1.7.0)
19
+ i18n (1.8.3)
19
20
  concurrent-ruby (~> 1.0)
20
- minitest (5.13.0)
21
+ minitest (5.14.1)
21
22
  rake (10.5.0)
22
23
  rspec (3.9.0)
23
24
  rspec-core (~> 3.9.0)
@@ -33,14 +34,15 @@ GEM
33
34
  rspec-support (~> 3.9.0)
34
35
  rspec-support (3.9.0)
35
36
  thread_safe (0.3.6)
36
- tzinfo (1.2.6)
37
+ tzinfo (1.2.7)
37
38
  thread_safe (~> 0.1)
39
+ zeitwerk (2.3.0)
38
40
 
39
41
  PLATFORMS
40
42
  ruby
41
43
 
42
44
  DEPENDENCIES
43
- activesupport (~> 5.0, >= 5.0.0.1)
45
+ activesupport (~> 6.0)
44
46
  awesome_print (~> 1.8)
45
47
  bundler (~> 2.0)
46
48
  byebug (~> 11.0)
data/README-ru.md CHANGED
@@ -55,6 +55,7 @@ __Список методов__
55
55
  * [each_nested!](#each_nested) — перебирает вложенную стуктуру, предоставляя доступ к исходным данным;
56
56
  * [nested_to_html](#nested_to_html) — преобразует вложенную структуру в html вёрстку (многоуровневый список `<ul><li>…`);
57
57
  * [nested_to_options](#nested_to_options) — преобразует вложенную структуру в массив для формирования опций html-тега `<select>` с псевдографикой;
58
+ * [nested_to_collection_select](#nested_to_collection_select) — преобразует вложенную структуру в плоскую но добавляет псевдографику в тектовое поле для формирования тэга `<select>`;
58
59
  * [concat_nested](#concat_nested) — скеивание вложенных структур, ноды склеиваются если путь к ним одинаков.
59
60
 
60
61
 
@@ -199,6 +200,56 @@ option_text: 'name',
199
200
 
200
201
 
201
202
 
203
+ <a name="nested_to_collection_select"></a>
204
+ ### nested_to_collection_select [↑](#methods "К методам")
205
+
206
+ Преобразует вложенную структуру данных в плоскую, но добавляет в значение поля
207
+ отвечающего за текстовое представление (:name) псевдографику древовидной
208
+ структуры.
209
+
210
+ Это позволяет вывести тэг select в сносном виде для использования с вложенными
211
+ структурами.
212
+
213
+ Пример с хелпером `collection_select`
214
+
215
+ ```rb
216
+ <%= form.collection_select :catalog_ids,
217
+ Catalog.all.to_a.to_nested.nested_to_collection_select, :id, :name,
218
+ {
219
+ # prompt: true
220
+ # include_blank: true
221
+ },
222
+ {
223
+ multiple: true,
224
+ size: 10
225
+ }
226
+ %>
227
+ ```
228
+
229
+ Пример с хелпером `select` в сочетании с `options_from_collection_for_select`
230
+
231
+ ```erb
232
+ <% catalogs = Catalog.all.to_a %>
233
+ <%= form.select :catalog_ids,
234
+ options_from_collection_for_select(
235
+ catalogs.to_nested.nested_to_collection_select, :id, :name,
236
+ disabled: catalogs.select{|x| x.hidden?}.pluck(:id),
237
+ selected: form.object.catalog_ids
238
+ ),
239
+ {
240
+ # prompt: true
241
+ # include_blank: true
242
+ },
243
+ {
244
+ multiple: true,
245
+ size: 10
246
+ }
247
+ %>
248
+ ```
249
+
250
+
251
+
252
+
202
253
  <a name="concat_nested"></a>
203
254
  ### concat_nested [↑](#methods "К методам")
204
255
 
data/TODO.md ADDED
@@ -0,0 +1,29 @@
1
+ # Что реализовано, необходимо реализовать и почему
2
+
3
+ ## Почему
4
+
5
+ ### Почему возвращаем массив Hash
6
+
7
+ Когда хотим из плоской структуры получить древовидную, то на руках мы можем
8
+ иметь данные различного типа, например, массив Hash или массив ActiveRecord,
9
+ результатом обработки должен быть массив объектов у которых должно быть поле
10
+ children содержащее потомков. Именно поэтому мы не можем оставлять в результате
11
+ массив ActiveRecord, так как поле children будет конфликтовать с уже
12
+ существующим методом, например при использовании гема closure_tree. С другой
13
+ стороны мы моглибы внедрить поле nested_children во все объекты ActiveRecord,
14
+ но такой подход, мне кажется, похож на «Monkey patch».
15
+
16
+
17
+ ## TODO
18
+
19
+ + Хочу возвращать массив OpenStruct вместо массива Hash.
20
+
21
+ При возврате массива OpenStruct (всегда) пропадает смысл метода `each_nested!`
22
+ который должен отдавать в переменной node исходные данные (ну они не исходые
23
+ уже). Поэтому необходимо выпустить версию 3.0.0 с удалением метода
24
+ `each_nested!`.
25
+
26
+ Добавлен метод nested_to_collection_select, нужно пересмотреть метод
27
+ nested_to_options (возможно удалить в следующей версии).
28
+
29
+ Переработать README-ru и на английский доперевести в конце концов.
@@ -56,7 +56,7 @@ module NestedArray::Nested
56
56
  if node != nil
57
57
  is_last_children = cache[level][i[level]].blank?
58
58
 
59
- yield(node.clone, parents.clone, level, is_last_children)
59
+ yield(node.clone, parents.clone, level, is_last_children, node.origin)
60
60
 
61
61
  if !node[options[:children]].nil? && node[options[:children]].length > 0
62
62
  level+= 1
@@ -85,8 +85,9 @@ module NestedArray::Nested
85
85
  node = cache[level][i[level]]
86
86
  i[level]+= 1
87
87
  if node != nil
88
+ is_last_children = cache[level][i[level]].blank?
88
89
 
89
- yield(node, parents, level)
90
+ yield(node, parents, level, is_last_children, node.origin)
90
91
 
91
92
  if !node[options[:children]].nil? && node[options[:children]].length > 0
92
93
  level+= 1
@@ -115,13 +116,14 @@ module NestedArray::Nested
115
116
  nested = options[:hashed] ? {} : []
116
117
  # Перебираем элементы в любом порядке!
117
118
  self.each do |value|
119
+ origin = value
118
120
  value = value.serializable_hash if !value.is_a? Hash
119
121
  # 1. Если нет родителя текущего элемента, и текущий элемент не корневой, то:
120
122
  # 1.1 создадим родителя
121
123
  # 1.2 поместим в кэш
122
124
  if !(cache.key? value[fields[:parent_id]]) && (value[fields[:parent_id]] != options[:root_id])
123
125
  # 1.1
124
- temp = {}
126
+ temp = OpenStruct.new
125
127
  fields.each do |key, field|
126
128
  case key
127
129
  when :id
@@ -151,6 +153,7 @@ module NestedArray::Nested
151
153
  value.keys.each do |field|
152
154
  cache[value[fields[:id]]][field] = value[field] if !(field.in? fields)
153
155
  end
156
+ cache[value[fields[:id]]].origin = origin
154
157
  # 2.2
155
158
  # Если текущий элемент не корневой - поместим в родителя, беря его из кэш
156
159
  if value[fields[:parent_id]] != options[:root_id]
@@ -174,7 +177,7 @@ module NestedArray::Nested
174
177
  # 3.3 поместим в родителя
175
178
  else
176
179
  # 3.1
177
- temp = {}
180
+ temp = OpenStruct.new
178
181
  fields.each do |key, field|
179
182
  case key
180
183
  when :id
@@ -190,6 +193,7 @@ module NestedArray::Nested
190
193
  value.keys.each do |field|
191
194
  temp[field] = value[field] if !(field.in? fields)
192
195
  end
196
+ temp.origin = origin
193
197
  # 3.2
194
198
  cache[value[fields[:id]]] = temp
195
199
  # 3.3
@@ -309,6 +313,29 @@ module NestedArray::Nested
309
313
  ret
310
314
  end
311
315
 
316
+ # Преобразует вложенную структуру данных в плоскую, но добавляет в значение
317
+ # поля отвечающего за текстовое представление (:name) псевдографику
318
+ # древовидной структуры.
319
+ # Это позволяет вывести тэг select в сносном виде для использования с
320
+ # вложенными структурами.
321
+ def nested_to_collection_select(options={})
322
+ options = NESTED_OPTIONS.merge options
323
+ ret = []
324
+ last = []
325
+ each_nested do |node, parents, level, is_last, origin|
326
+ last[level+1] = is_last
327
+ node_text = node[options[:option_text]]
328
+ node_level = (1..level).map{|l| last[l] == true ? '&nbsp;' : '┃'}.join
329
+ node_last = is_last ? '┗' : '┣'
330
+ node_children = node[options[:children]].present? && node[options[:children]].length > 0 ? '┳' : '━'
331
+ option_text = "#{node_level}#{node_last}#{node_children}╸".html_safe + "#{node_text}"
332
+ option_value = node[options[:option_value]]
333
+ node[options[:option_text]] = option_text
334
+ ret.push node
335
+ end
336
+ ret
337
+ end
338
+
312
339
  # "Скеивание" вложенных структур
313
340
  # ноды склеиваются если путь к ним одинаков;
314
341
  # путь определяется из сложения Текстов (конфигурируемо через :path_key);
@@ -1,3 +1,3 @@
1
1
  module NestedArray
2
- VERSION = "2.2.1"
2
+ VERSION = "2.4.0"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: nested_array
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.2.1
4
+ version: 2.4.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - zlatov
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2023-01-14 00:00:00.000000000 Z
11
+ date: 2023-01-21 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler
@@ -96,6 +96,7 @@ files:
96
96
  - README-ru.md
97
97
  - README.md
98
98
  - Rakefile
99
+ - TODO.md
99
100
  - bash/build/gem.sh
100
101
  - bash/push/gem.sh
101
102
  - bash/test/gem.sh