README.md in supa-0.1.4 vs README.md in supa-0.2.0
- old
+ new
@@ -1,13 +1,13 @@
# Supa
Ruby object → JSON serialization.
-[data:image/s3,"s3://crabby-images/6073a/6073af3d8ee201b67198a816d1e8445cfb0515c8" alt="Build Status"](https://travis-ci.org/dasnotme/supa)
-[data:image/s3,"s3://crabby-images/6ed6a/6ed6a1c465caa6b9adea0431b55aae06f0b301fc" alt="Code Climate"](https://codeclimate.com/github/dasnotme/supa)
-[data:image/s3,"s3://crabby-images/da978/da9781b98b5293fc905db76bce9d9ee2d4187c67" alt="Test Coverage"](https://codeclimate.com/github/dasnotme/supa/coverage)
-[data:image/s3,"s3://crabby-images/bbbd0/bbbd0f448c2081b30bc4aafc332d352d6cf27702" alt="Issue Count"](https://codeclimate.com/github/dasnotme/supa)
+[data:image/s3,"s3://crabby-images/869e3/869e3030b9f3b0b30a9eb86344d1103b2f55c484" alt="Build Status"](https://travis-ci.org/distribusion/supa)
+[data:image/s3,"s3://crabby-images/d64fe/d64fe94727f7631cfc41aeaca65573a521320aca" alt="Code Climate"](https://codeclimate.com/repos/587387071c36ea7203000e0d/feed)
+[data:image/s3,"s3://crabby-images/f6272/f627262b92fcb98de499ce146ce0dbec27b3d1c9" alt="Test Coverage"](https://codeclimate.com/repos/587387071c36ea7203000e0d/coverage)
+[data:image/s3,"s3://crabby-images/fd558/fd5588314e10d789951f4eede563c391634a1f4a" alt="Issue Count"](https://codeclimate.com/repos/587387071c36ea7203000e0d/feed)
## Introduction
## Installation
@@ -81,21 +81,21 @@
end
end
end
end
- polymorphic :included, getter: proc { [self.author] } do
+ collection :included, getter: proc { [self.author] } do
attribute :id
attribute :type, getter: proc { 'authors' }
namespace :attributes do
attribute :first_name
attribute :last_name
end
end
- polymorphic :included, getter: proc { self.comments } do
+ collection :included, getter: proc { self.comments }, squash: true do
attribute :id
attribute :type, getter: proc { 'comments' }
namespace :attributes do
attribute :text
@@ -175,12 +175,57 @@
### `object`
### `collection`
-### `polymorphic`
+#### `:squash` option
+Passing `true` to `:squash` option results in merging collection with the previous one
+
+```ruby
+class AnimalsRepresenter
+ include Supa::Representable
+
+ define do
+ collection :animals, getter: -> { [{name: 'Rex', type: 'dogs'}] } do
+ attribute :name
+ attribute :type
+ end
+
+ collection :animals, getter: -> { [{name: 'Tom', type: 'cats'}] }, squash: true do
+ attribute :name
+ attribute :type
+ end
+ end
+end
+```
+
+```ruby
+ AnimalsRepresenter.new(nil).to_hash
+```
+
+```ruby
+{
+ animals: [
+ {name: 'Rex', type: 'dogs'},
+ {name: 'Tom', type: 'cats'}
+ ]
+}
+```
+
+### `:getter` option
+
+Avoid passing Proc objects to `:getter` option because this is little slower than method name passing
+
+```ruby
+# Bad
+attribute :name, getter: -> { fetch_name }
+
+# Good
+attribute :name, getter: :fetch_name
+```
+
## Development
To install dependencies
```shell
bin/setup
@@ -201,12 +246,11 @@
bin/console
```
## Contributing
-Bug reports and pull requests are welcome on GitHub at https://github.com/dasnotme/supa. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](http://contributor-covenant.org) code of conduct.
+Bug reports and pull requests are welcome on GitHub at https://github.com/distribusion/supa.
+This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](http://contributor-covenant.org) code of conduct.
-
## License
The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
-