239 lines
9.6 KiB
Markdown
239 lines
9.6 KiB
Markdown
# Hanami::View
|
||
View layer for Hanami
|
||
|
||
## v2.0.0.alpha8 - 2022-05-19
|
||
|
||
### Added
|
||
- [Tim Riley] Access a hash of template locals via accessing `locals` inside any template
|
||
|
||
### Changed
|
||
- [Tim Riley] Removed automatic integration of `Hanami::View` subclasses with their surrounding Hanami application. View base classes within Hanami apps should inherit from `Hanami::Application::View` instead.
|
||
|
||
## v2.0.0.alpha7 - 2022-03-08
|
||
|
||
### Added
|
||
- [Luca Guidi] Automatically inject the app's `settings` and `assets` components (if present) into instances of `Hanami::View::ApplicationContext`
|
||
- [Luca Guidi] Temporarily added to `Hanami::View::ApplicationContext` the `#content_for`, `#current_path` `#csrf_token` helpers, ported from the hanami-2-application-template. Some of those helpers will be moved to `hanami-helpers` gem in a later release.
|
||
|
||
### Changed
|
||
- [Sean Collins] For views within an Hanami application, changed default location for templates from "web/templates" to "templates"
|
||
- [Luca Guidi] For views within an Hanami application, the default `part_namespace` is now `"view/parts"` (previously `"views/parts"`)
|
||
|
||
## Fixed
|
||
- [Luca Guidi] Application-level configuration is now applied to `Hanami::View` subclasses, no matter how deep their inheritance chain (e.g. app base view -> slice base view -> slice view)
|
||
|
||
## v2.0.0.alpha6 - 2022-02-10
|
||
### Added
|
||
- [Luca Guidi] Official support for Ruby: MRI 3.0 and 3.1
|
||
|
||
### Changed
|
||
- [Luca Guidi] Drop support for Ruby: MRI 2.3, 2.4, 2.5, 2.6, and 2.7.
|
||
|
||
## v2.0.0.alpha5 - 2022-01-12
|
||
### Added
|
||
- [Marc Busqué] Automatically provide access to Hanami application routes helper as `routes` in default application view context (`Hanami::View::ApplicationContext`)
|
||
|
||
## v2.0.0.alpha3 - 2021-11-09
|
||
### Added
|
||
- [Pablo Vicente] Raise `LayoutNotFoundError` exception with friendlier, more specific error message when layouts cannot be found
|
||
|
||
### Changed
|
||
- [Tim Riley] (Internal) Updated settings to use updated dry-configurable `setting` 0.13.0 API
|
||
|
||
## v2.0.0.alpha2 - 2021-05-04
|
||
### Changed
|
||
- [Tim Riley] Replaced entire gem with dry-view (now renamed to hanami-view). See [dry-view's documentation](https://dry-rb.org/gems/dry-view/) for its capabilities and [the dry-view changelog](CHANGELOG.dry-view.md) for its history.
|
||
|
||
## v1.3.1 - 2019-01-18
|
||
### Added
|
||
- [Luca Guidi] Official support for Ruby: MRI 2.6
|
||
- [Luca Guidi] Support `bundler` 2.0+
|
||
|
||
## v1.3.0 - 2018-10-24
|
||
|
||
## v1.3.0.beta1 - 2018-08-08
|
||
### Fixed
|
||
- [Ferdinand Niedermann] Ensure to set `:disable_escape` option only for Slim and don't let Tilt to emit a warning for other template engines.
|
||
- [glaszig] Ensure partial rendering to respect `format` overriding
|
||
|
||
## v1.2.1 - 2018-10-16
|
||
### Added
|
||
- [Luca Guidi] Introduced new, backward compatible, signature to render a layout for testing purposes (eg. `ApplicationLayout.new({ format: :html }, "contents").render`)
|
||
|
||
### Fixed
|
||
- [Luca Guidi] Ensure layout to be rendered when using HAML 5
|
||
- [Luca Guidi] Ensure to raise `NoMethodError` when an unknown method is invoked by a view/template
|
||
|
||
## v1.2.0 - 2018-04-06
|
||
|
||
## v1.2.0.rc2 - 2018-04-06
|
||
|
||
## v1.2.0.rc1 - 2018-03-30
|
||
|
||
## v1.2.0.beta2 - 2018-03-23
|
||
|
||
## v1.2.0.beta1 - 2018-02-28
|
||
|
||
## v1.1.2 - 2018-04-10
|
||
### Fixed
|
||
- [Luca Guidi] Ensure to be able to use `exposures` even when they aren't duplicable objects
|
||
|
||
## v1.1.1 - 2018-02-27
|
||
### Added
|
||
- [Luca Guidi] Official support for Ruby: MRI 2.5
|
||
|
||
### Fixed
|
||
- [Alfonso Uceda] Ensure that `exposures` are properly overwritten for partials when `locals:` option is used
|
||
|
||
## v1.1.0 - 2017-10-25
|
||
|
||
## v1.1.0.rc1 - 2017-10-16
|
||
|
||
## v1.1.0.beta3 - 2017-10-04
|
||
|
||
## v1.1.0.beta2 - 2017-10-03
|
||
### Added
|
||
- [Luca Guidi] Added `Hanami::Layout#local` to safely access locals from layouts
|
||
|
||
## v1.1.0.beta1 - 2017-08-11
|
||
### Fixed
|
||
- [yjukaku] Raise `Hanami::View::UnknownRenderTypeError` when an argument different from `:template` or `:partial` is passed to `render`
|
||
|
||
## v1.0.1 - 2017-08-04
|
||
### Added
|
||
- [Luca Guidi] Compatibility with `haml` 5.0
|
||
|
||
## v1.0.0 - 2017-04-06
|
||
|
||
## v1.0.0.rc1 - 2017-03-31
|
||
|
||
## v1.0.0.beta2 - 2017-03-17
|
||
### Changed
|
||
- [Luca Guidi] Remove deprecated `Hanami::View::Rendering::LayoutScope#content`
|
||
|
||
## v1.0.0.beta1 - 2017-02-14
|
||
### Added
|
||
- [Luca Guidi] Official support for Ruby: MRI 2.4
|
||
- [Vladimir Dralo] Allow `View#initialize` to splat keyword arguments
|
||
|
||
## v0.8.0 - 2016-11-15
|
||
### Fixed
|
||
- [Luca Guidi] Ensure `Rendering::NullLocal` to work with HAML templates
|
||
|
||
### Changed
|
||
- [Luca Guidi] Official support for Ruby: MRI 2.3+ and JRuby 9.1.5.0+
|
||
|
||
## v0.7.0 - 2016-07-22
|
||
### Added
|
||
- [Luca Guidi] Introduced `#local` for views, layouts and templates. It allows to safely access locals without raising errors in case the referenced local is missing.
|
||
|
||
### Fixed
|
||
- [nessur] Find the correct partial in case of deeply nested templates.
|
||
- [Marcello Rocha] Ensure `Hanami::Presenter` to respect method visibility of wrapped object.
|
||
- [Luca Guidi] Ensure to use new registry when loading the framework
|
||
|
||
### Changed
|
||
– [Luca Guidi] Drop support for Ruby 2.0 and 2.1. Official support for JRuby 9.0.5.0+.
|
||
– [Luca Guidi] Deprecate `#content` in favor of `#local`.
|
||
|
||
## v0.6.1 - 2016-02-05
|
||
### Changed
|
||
- [Steve Hook] Preload partial templates in order to boost performances for partials rendering (2x faster)
|
||
|
||
### Fixed
|
||
- [Luca Guidi] Disable Slim autoescape to use `Hanami::View`'s feature
|
||
|
||
## v0.6.0 - 2016-01-22
|
||
### Changed
|
||
- [Luca Guidi] Renamed the project
|
||
|
||
## v0.5.0 - 2016-01-12
|
||
### Added
|
||
- [Luca Guidi] Added `Lotus::View::Configuration#default_encoding` to set the encoding for templates
|
||
|
||
### Fixed
|
||
- [Luca Guidi] Let exceptions to be raised as they occur in rendering context. This fixes misleading backtraces for exceptions.
|
||
- [Martin Rubi] Raise a `Lotus::View::MissingTemplateError` when rendering a missing partial from a template
|
||
- [Luca Guidi] Fix for `template.erb is not valid US-ASCII (Encoding::InvalidByteSequenceError)` when system encoding is not set
|
||
|
||
### Changed
|
||
- [Liam Dawson] Introduced `Lotus::View::Error` and let all the framework exceptions to inherit from it.
|
||
|
||
## v0.4.4 - 2015-09-30
|
||
### Added
|
||
- [Luca Guidi] Autoescape for layout helpers.
|
||
|
||
## v0.4.3 - 2015-07-10
|
||
### Fixed
|
||
- [Farrel Lifson] Force partial finder to be explicit when to templates have the same name.
|
||
|
||
## v0.4.2 - 2015-06-23
|
||
### Fixed
|
||
- [Tom Kadwill] Ensure views to use methods defined by the associated layout.
|
||
|
||
## v0.4.1 - 2015-05-22
|
||
### Added
|
||
- [Luca Guidi] Introduced `#content` to render optional contents in a different context (eg. a view sets a page specific javascript in the application template footer).
|
||
|
||
## v0.4.0 - 2015-03-23
|
||
### Changed
|
||
- [Luca Guidi] Autoescape concrete and virtual methods from presenters
|
||
- [Luca Guidi] Autoescape concrete and virtual methods from views
|
||
|
||
### Fixed
|
||
- [Tom Kadwill] Improve error message for undefined method in view
|
||
- [Luca Guidi] Ensure that layouts will include modules from `Configuration#prepare`
|
||
|
||
## v0.3.0 - 2014-12-23
|
||
### Added
|
||
- [Trung Lê] When duplicate the framework, also duplicate `Presenter`
|
||
- [Benny Klotz] Introduced `Scope#class`, `#inspect`, `LayoutScope#class` and `#inspect`
|
||
- [Alfonso Uceda Pompa & Trung Lê] Introduced `Configuration#prepare`
|
||
- [Luca Guidi] Implemented "respond to" logic for `Lotus::View::Scope` (`respond_to?` and `respond_to_missing?`)
|
||
- [Luca Guidi] Implemented "respond to" logic for `Lotus::Layout` (`respond_to?` and `respond_to_missing?`)
|
||
- [Jeremy Stephens] Allow view concrete methods that accept a block to be invoked from templates
|
||
- [Peter Suschlik] Implemented "respond to" logic for `Lotus::Presenter` (`respond_to?` and `respond_to_missing?`)
|
||
- [Luca Guidi] Official support for Ruby 2.2
|
||
|
||
### Changed
|
||
- [Alfonso Uceda Pompa] Raise an exception when a layout doesn't have an associated template
|
||
|
||
### Fixed
|
||
- [Luca Guidi] Ensure that concrete methods in layouts are available in templates
|
||
- [Luca Guidi] Ensure to associate the right layout to a view in case fo duplicated framework
|
||
- [Luca Guidi] Safe override of Ruby's top level methods in Scope. (Eg. use `select` from a view, not from `::Kernel`)
|
||
|
||
## v0.2.0 - 2014-06-23
|
||
### Added
|
||
- [Luca Guidi] Introduced `Configuration#duplicate`
|
||
- [Luca Guidi] Introduced `Configuration#layout` to define the layout that all the views will use
|
||
- [Luca Guidi] Introduced `Configuration#load_paths` to define several sources where to lookup for templates
|
||
- [Luca Guidi] Introduced `Configuration#root` to define the root path where to find templates
|
||
- [Luca Guidi] Introduced `Lotus::View::Configuration`
|
||
- [Grant Ammons] Allow view concrete methods with arity > 0 to be invoked from templates
|
||
- [Luca Guidi] Official support for Ruby 2.1
|
||
|
||
### Changed
|
||
- [Luca Guidi] `Rendering::TemplatesFinder` now look recursively for templates, starting from the root.
|
||
- [Luca Guidi] Removed `View.layout=`
|
||
- [Luca Guidi] Removed `View.root=`
|
||
|
||
### Fixed
|
||
- [Luca Guidi] Ensure outermost locals to not shadow innermost inside templates/partials
|
||
|
||
## v0.1.0 - 2014-03-23
|
||
### Added
|
||
- [Luca Guidi] Allow custom rendering policy via `Action#render` override. This bypasses the template lookup and rendering.
|
||
- [Luca Guidi] Introduced `Lotus::Presenter`
|
||
- [Luca Guidi] Introduced templates rendering from templates and layouts
|
||
- [Luca Guidi] Introduced partials rendering from templates and layouts
|
||
- [Luca Guidi] Introduced layouts support
|
||
- [Luca Guidi] Introduced `Lotus::View.load!` as entry point to load views and templates
|
||
- [Luca Guidi] Allow to setup template name via `View.template`
|
||
- [Luca Guidi] Rendering context also considers locals passed to the constructor
|
||
- [Luca Guidi] Introduced `View.format` as DSL to declare which format to handle
|
||
- [Luca Guidi] Introduced view subclasses as way to handle different formats (mime types)
|
||
- [Luca Guidi] Introduced multiple templates per each View
|
||
- [Luca Guidi] Implemented basic rendering with templates
|
||
- [Luca Guidi] Official support for Ruby 2.0
|