- declarative-option dependency replaced with trailblazer-option
- Ruby 3.4.0 support.
- Drop ruby versions below 2.5
Collection#join
can now be called without a block.
- Use
Declarative::Option
andDeclarative::Builder
instead ofuber
's. This allows removing theuber
version restriction.
- Fix a bug where nested calls of
cell(name, context: {...})
would ignore the new context elements, resulting in the old context being passed on. By addingContext::[]
the new elements are now properly merged into a new context hash. This means that adding elements to the child context won't leak up into the parent context anymore.
- Upgrading to Uber 0.1 which handles builders a bit differently.
- Load
Uber::InheritableAttr
inTesting
to fix a bug incells-rspec
.
- Testing with Rails 5 now works, by removing code the last piece of Rails-code (I know, it sounds bizarre).
- Fix rendering of
Collection
where in some environments (Rails), the overridden#call
method wouldn't work and strings would be escaped.
-
All Rails code removed. Make sure to use Cells-rails if you want the old Rails behavior.
-
The
builds
feature is now optional, you have to includeBuilder
in your cell.class CommentCell < Cell::ViewModel include Cell::Builder builds do |..|
-
A basic, rendering
#show
method is now provided automatically. -
ViewModel#render
now accepts a block that can beyield
ed in the view. -
Passing a block to
ViewModel#call
changed. Usetap
if you want the "old" behavior (which was never official or documented).Comment::Cell.new(comment).().tap { |cell| }
The new behavior is to pass that block to your state method. You can pass it on to
render
, and thenyield
it in the template.def show(&block) render &block # yield in show.haml end
Note that this happens automatically in the default
ViewModel#show
method. -
Concept#cell
now will resolve a concept cell (Song::Cell
), and not the old-style suffix cell (SongCell
). The same applies toConcept#concept
.concept("song/cell", song).cell("song/cell/composer") #=> resolves to Song::Cell::Composer
This decision has been made in regards of the upcoming Cells 5. It simplifies code dramatically, and we consider it unnatural to mix concept and suffix cells in applications.
-
In case you were using
@parent_controller
, this doesn't exist anymore (and was never documented, either). Usecontext[:controller]
. -
::self_contained!
is no longer included intoViewModel
. Please try usingTrailblazer::Cell
instead. If you still need it, here's how.class SongCell < Cell::ViewModel extend SelfContained self_contained!
-
Cell::Concept
is deprecated and you should be using the excellentTrailblazer::Cell
class instead, because that's what a concept cell tries to be in an awkward way. The latter is usable without Trailblazer.We are hereby dropping support for
Cell::Concept
(it still works). -
Deprecating
:collection_join
and:method
for collections.
-
Introduced the concept of a context object that is being passed to all nested cells. This object is supposed to contain dependencies such as
current_user
, in Rails it contains the "parent_controller" under thecontext[:controller]
key.Simple provide it as an option when rendering the cell.
cell(:song, song, context: { current_user: current_user })
The
#context
method allows to access this very hash.def role context[:current_user].admin? "Admin" : "A nobody" end
-
The
cell
helper now allows to pass in a constant, too.cell(Song::Cell, song)
-
New API for
:collection
. If used in views, this happens automatically, but here's how it works now.cell(:comment, collection: Comment.all).() # will invoke show. cell(:comment, collection: Comment.all).(:item) # will invoke item. cell(:comment, collection: Comment.all).join { |cell, i| cell.show(index: i) }
Basically, a
Collection
instance is returned that optionally allows to invoke each cell manually. -
Layout cells can now be injected to wrap the original content.
cell(:comment, Comment.find(1), layout: LayoutCell)
The LayoutCell will be instantiated and the
show
state invoked. The content cell's content is passed as a block, allowing the layout's view toyield
.This works with
:collection
, too.
- Fix
Testing
so you can use Capybara matchers oncell(:song, collection: [..])
.
Escaped::property
now properly escapes all passed properties. Thanks @xzo and @jlogsdon!
Cell::Partial
now does append the global partial path to itsview_paths
instead of usingunshift
and thereby removing possible custom paths.- Adding
Cell::Translation
which allows using the#t
helper. Thanks to @johnlane. - Performance improvement: when inflecting the view name (90% likely to be done) the
caller
is now limited to the data we need, saving memory. Thanks @timoschilling for implementing this. - In the
concept
helper, we no longer useclassify
, which means you can sayconcept("comment/data")
and it will instantiateComment::Data
and notComment::Datum
. Thanks @firedev!
- In Rails, include
ActionView::Helpers::FormHelper
intoViewModel
so we already have (and pollute our cell with)UrlHelper
andFormTagHelper
. Helpers, so much fun. - Concept cells will now infer their name properly even if the string
Cell
appears twice.
- Support forgery protection in
form_tag
.
- Rails Support: Rails 4.0+ is fully supported, in older versions some form helpers do not work. Let us know how you fixed this.
- State args: View models don't use state args. Options are passed into the constructor and saved there. That means that caching callbacks no longer receive arguments as everything is available via the instance itself.
ViewModel.new(song: song)
won't automatically create a reader#song
. You have to configure the cell to use a Struct twin {TODO: document}- HTML Escaping: Escaping only happens for defined
property
s whenEscaped
is included. - Template Engines: There's now one template engine (e.g. ERB or HAML) per cell class. It can be set by including the respective module (e.g.
Cell::Erb
) into the cell class. This happens automatically in Rails. - File Naming. The default filename just uses the engine suffix, e.g.
show.haml
. If you have two different engine formats (e.g.show.haml
andshow.erb
), use theformat:
option:render format: :erb
. If you need to render a specific mime type, provide the filename:render view: "show.html"
. - Builder blocks are no longer executed in controller context but in the context they were defined. This is to remove any dependencies to the controller. If you need e.g.
params
, pass them into the#cell(..)
call. - Builders are now defined using
::builds
, not::build
.
Cell::Rails
andCell::Base
got removed. Every cell isViewModel
orConcept
now.- All methods from
AbstractController
are gone. This might give you trouble in case you were usinghelper_method
. You don't need this anymore - every method included in the cell class is a "helper" in the view (it's one and the same method call).
- Include
#protect_from_forgery?
into Rails cells. It returns false currently. - Fix
Concept#cell
which now instantiates a cell, not a concept cell.
- Move delegations of
#url_options
etc. to the railtie, which makes it work.
- Removed
ViewModel::template_engine
. This is now done explicitly by includingCell::Erb
, etc. and happens automatically in a Rails environment.
-
Assets bundled in engine cells now work.
-
Directory change: Assets like
.css
,.coffee
and.js
, no longer have their ownassets/
directory but live inside the views directory of a cell. It turned out that two directoriesviews/
andassets/
was too noisy for most users. If you think you have a valid point for re-introducing it, email me, it is not hard to implement. -
When bundling your cell's assets into the asset pipeline, you have to specify the full name of your cell. The names will be constantized.
config.cells.with_assets = ["song/cell", "user_cell"] #=> Song::Cell, UserCell
-
ViewModel
is now completely decoupled from Rails and doesn't inherit from AbstractController anymore. -
API change: The controller dependency is now a second-class citizen being passed into the cell via options.
Cell.new(model, {controller: ..})
-
Removing
actionpack
from gemspec.
- Fixed a bug when rendering more than once with ERB, the output buffer was being reused.
- API change: ViewModel::_prefixes now returns the "fully qualified" pathes including the view paths, prepended to the prefixes. This allows multiple view paths and basically fixes cells in engines.
- The only public way to retrieve prefixes for a cell is
ViewModel::prefixes
. The result is cached.
- Introduce
Cell::Testing
for Rspec and MiniTest. - Add ViewModel::OutputBuffer to be used in Erbse and soon in Haml.
ViewModel#call
now accepts a block and yieldsself
(the cell instance) to it. This is handy to use withcontent_for
.= cell(:song, Song.last).call(:show) do |cell| content_for :footer, cell.footer
- Override
ActionView::Helpers::UrlHelper#url_for
in Rails 4.x as it is troublesome. That removes the annoyingarguments passed to url_for can't be handled. Please require routes or provide your own implementation
exception when using simple_form, form_for, etc with a view model.
- Deprecated
Cell::Rails::ViewModel
, please inherit:class SongCell < Cell::ViewModel
. ViewModel#call
is now the prefered way to invoke the rendering flow. Without any argument,call
will runrender_state(:show)
. Pass in any method name you want.- Added
Caching::Notifications
. - Added
cell(:song, collection: [song1, song2])
to render collections. This only works with ViewModel (and, of course, Concept, too). - Added
::inherit_views
to only inherit views whereas real class inheritance would inherit all the dark past of the class. ::build_for
removed/privatized/changed. UseCell::Base::cell_for
instead.Base::_parent_prefixes
is no longer used, if you override that somewhere in your cells it will break. We have our own implementation for computing the controller's prefixes inCell::Base::Prefixes
(simpler).#expire_cell_state
doesn't take symbols anymore, only the real cell class name.- Remove
Cell::Base.setup_view_paths!
andCell::Base::DEFAULT_VIEW_PATHS
and the associated Railtie. I don't know why this code survived 3 major versions, if you wanna set you own view paths just useCell::Base.view_paths=
. - Add
Base::self_contained!
. - Add
Base::inherit_views
.
#concept
helper is mixed into all views as an alternative to#cell
and#render_cell
. Let us know if we should do that conditionally, only.- Concept cells look for layouts in their self-contained views directory.
- Add generator for Concept cells:
rails g concept Comment
Allow packaging assets for Rails' asset pipeline into cells. This is still experimental but works great. I love it.
- API CHANGE: Blocks passed to
::cache
and::cache ... if:
no longer receive the cell instance as the first argument. Instead, they're executed in cell instance context. Change your code like this:
cache :show do |cell, options|
cell.version
end
# and
cache :show, if: lambda {|cell, options| .. }
should become
cache :show do |options|
version
end
# and
cache :show, if: lambda {|options| .. }
Since the blocks are run in cell context, self
will point to what was cell
before.
::cache
doesn't accept aProc
instance anymore, only blocks (was undocumented anyway).- Use
uber
gem for inheritable class attributes and dynamic options.
- Autoload
Cell::Rails::ViewModel
. - Implement dynamic cache options by allowing lambdas that are executed at render-time - Thanks to @bibendi for this idea.
- Runs with Rails 4.1 now.
- Internal changes on
Layouts
to prepare 4.1 compat.
- Cells in engines are now recognized under Rails 4.0.
- Introducing @#cell@ and @#cell_for@ to instantiate cells in ActionController and ActionView.
- Adding @Cell::Rails::ViewModel@ as a new "dialect" of working with cells.
- Add @Cell::Base#process_args@ which is called in the initializer to handle arguments passed into the constructor.
- Setting @controller in your @Cell::TestCase@ no longer get overridden by us.
- Maintenance release.
- Cells runs with Rails 4.
- @cell/base@ can now be required without trouble.
- Generated test files now respect namespaced cells.
- Added @Cell::Rails::HelperAPI@ module to provide the entire Rails view "API" (quotes on purpose!) in cells running completely outside of Rails. This makes it possible to use gems like simple_form in any Ruby environment, especially interesting for people using Sinatra, webmachine, etc.
- Moved @Caching.expire_cache_key@ to @Rails@. Use @Caching.expire_cache_key_for(key, cache_store, ..)@ if you want to expire caches outside of Rails.
- Added @Cell::Rack@ for request-dependent Cells. This is also the new base class for @Cells::Rails@.
- Removed deprecation warning from @TestCase#cell@ as it's signature is not deprecated.
- Added the @base_cell_class@ config option to generator for specifying an alternative base class.
- Added @Engines.existent_directories_for@ to prevent Rails 3.0 from crashing when it detects engines.
- Engines should work in Rails 3.0 now, too.
- Make it work with Rails 3.2 by removing deprecated stuff.
- @Cell::Base@ got rid of the controller dependency. If you want the @ActionController@ instance around in your cell, use @Cell::Rails@ - this should be the default in a standard Rails setup. However, if you plan on using a Cell in a Rack middleware or don't need the controller, use @Cell::Base@.
- New API (note that @controller@ isn't the first argument anymore): ** @Rails.create_cell_for(name, controller)@ ** @Rails.render_cell_for(name, state, controller, *args)@
- Moved builder methods to @Cell::Builder@ module.
- @DEFAULT_VIEW_PATHS@ is now in @Cell::Base@.
- Removed the monkey-patch that made state-args work in Rails <= 3.0.3. Upgrade to +3.0.4.
- Works with Rails 3.2, too. Hopefully.
h3. Changes
- Cache settings using @Base.cache@ are now inherited.
- Removed
@opts
. - Removed @#options@ in favor of state-args. If you still want the old behaviour, include the @Deprecations@ module in your cell.
- The build process is now instantly delegated to Base.build_for on the concrete cell class.
h3. Changes
- Removed
@opts
. - Deprecated @#options@ in favour of state-args.
h3. Changes
- Added @view_assigns@ to TestCase.
h3. Changes
- Added the @:format@ option for @#render@ which should be used with caution. Sorry for that.
- Removed the useless @layouts/@ view path from Cell::Base.
h3. Bugfixes
Cell::TestCase#invoke
now properly accepts state-args.
h3. Changes
- Added the
:if
option toBase.cache
which allows adding a conditional proc or instance method to the cache definition. If it doesn't return true, caching for that state is skipped.
h3. Bugfixes
- Fixes @ArgumentError: wrong number of arguments (1 for 0)@ in @#render_cell@ for Ruby 1.8.
h3. Bugfixes
- [Rails 3.0] Helpers are now properly included (only once). Thanks to [paneq] for a fix.
#url_options
in the Metal module is now delegated toparent_controller
which propagates global URL setting like relative URLs to your cells.
h3. Changes
cells/test_case
is no longer required as it should be loaded automatically.
h3. Bugfixes
- Fixed cells.gemspec to allow Rails 3.x.
h3. Changes
- Added the @:format@ option allowing @#render@ to set different template types, e.g. @render :format => :json@.
h3. Changes
- Cells runs with Rails 3.0 and 3.1.
h3. Changes
- Added a generator for slim. Use it with
-e slim
when generating.
h3. Bugfixes
- The generator now places views of namespaced cells into the correct directory. E.g.
rails g Blog::Post display
puts views toapp/cells/blog/post/display.html.erb
.
h3. Changes
- Gem dependencies changed, we now require @actionpack@ and @railties@ >= 3.0.0 instead of @rails@.
h3. Bugfixes
- state-args work even if your state method receives optional arguments or default values, like @def show(user, age=18)@.
h3. Changes
- Cell::Base.view_paths is now setup in an initializer. If you do scary stuff with view_paths this might lead to scary problems.
- Cells::DEFAULT_VIEW_PATHS is now Cell::Base::DEFAULT_VIEW_PATHS. Note that Cells will set its view_paths to DEFAULT_VIEW_PATHS at initialization time. If you want to alter the view_paths, use Base.append_view_path and friends in a separate initializer.
h3. Bugfixes
- Controller#render_cell now accepts multiple args as options.
h3. Changes
- Caching versioners now can accept state-args or options from the #render_cell call. This way, you don't have to access #options at all anymore.
- No longer pass an explicit Proc but a versioner block to @Cell.Base.cache@. Example: @cache :show do "v1" end@
- Caching.cache_key_for now uses @ActiveSupport::Cache.expand_cache_key@. Consequently, a key which used to be like @"cells/director/count/a=1/b=2"@ now is @cells/director/count/a=1&b=2@ and so on. Be warned that this might break your home-made cache expiry.
- Controller#expire_cell_state now expects the cell class as first arg. Example: @expire_cell_state(DirectorCell, :count)@
h3. Bugfixes
- Passing options to @render :state@ in views finally works: @render({:state => :list_item}, item, i)@
h3. Changes
- Deprecated @opts, use #options now.
- Added state-args. State methods can now receive the options as method arguments. This should be the prefered way of parameter exchange with the outer world.
- #params, #request, and #config is now delegated to @parent_controller.
- The generator now is invoked as @rails g cell ...@
- The
--haml
option is no longer available. - The
-t
option now is compatible with the rest of rails generators, now it is used as alias for--test-framework
. Use the-e
option as an alias of--template-engine
Thanks to Jorge Calás Lozano calas@qvitta.net for patching this in the most reasonable manner i could imagine.
- The
- Privatized @#find_family_view_for_state@, @#render_view_for@, and all *ize methods in Cell::Rails.
- New signature: @#render_view_for(state, *args)@
h3. Changes
- Cells.setup now yields Cell::Base, so you can really call append_view_path and friends here.
- added Cell::Base.build for streamlining the process of deciders around #render_cell, "see here":http://nicksda.apotomo.de/2010/12/pragmatic-rails-thoughts-on-views-inheritance-view-inheritance-and-rails-304
- added TestCase#in_view to test helpers in a real cell view.
h3. Changes
- #render_cell now accepts a block which yields the cell instance before rendering.
h3. Bugfixes
- We no longer use TestTaskWithoutDescription in our rake tasks.