nested_array

Convert a flat array into a nested one in 1 pass and another…


License
MIT
Install
gem install nested_array -v 2.4.0

Documentation

NestedArray

It is intended for transformation into a tree structure of flat data described by the “Adjacency List” pattern, that is, the ancestor is specified in the nodes by the field parent_id. For instance:

[
  {id: 1, parent_id: nil, name: 'first', },
  {id: 2, parent_id:   1, name: 'second', },
  {id: 3, parent_id:   1, name: 'third', }
]
# ↓ ↓ ↓
[
  {id: 1, parent_id: nil, name: 'first', children: [
    {id: 2, parent_id:   1, name: 'second', },
    {id: 3, parent_id:   1, name: 'third', }
  ], }
]

Installation

Add this line to your application's Gemfile:

gem 'nested_array', '~> 1.0.0'
gem 'nested_array', '~> 2.0.0'

And then execute: bundle.

Or install it yourself as gem install nested_array.

Usage

  <ul>
    <%= Catalogs.all.to_a.to_nested.nested_to_html do |node| %>
      <% link_to "#{node['name']}", catalog_view_path(node['slug']) %>
    <% end %>
  </ul>

Development

After checking out the repo, run bin/setup to install dependencies. You can also run bin/console for an interactive prompt that will allow you to experiment.

To install this gem onto your local machine, run bundle exec rake install. To release a new version, update the version number in version.rb, and then run bundle exec rake release, which will create a git tag for the version, push git commits and tags, and push the .gem file to rubygems.org.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/Zlatov/nested_array.

License

The gem is available as open source under the terms of the MIT License.