Listings, Views
The Lupus Decoupled Views submodule provides support for Drupal's Views module. The Views module is Drupal's native way and very powerful way of creating listings of content. It provides a UI for configuring complex queries, searches and the rendering of results, including paging.
As alternative to Views-based listings, the frontend may create custom routes and listings by querying the backend, see JSON-API, GraphQL.
Usage
After enabling the sub-module, create a view, skip the wizard and follow the following steps:
- Add
Custom elements display page
to a view (not a regular page!). - Select
Custom elements
style as view format. - Select
Content
as row style. Choose the view-mode you want to use for the listed elements. - Configure filters and other options as suiting and set a path for the view.
- The Custom elements API of the view is available at
/ce-api/<view-path>
. Take note of the custom element name visible in the output, which will bedrupal-view-{ID}
. - On the frontend clone the
drupal-view--default
component and create a component using the noted custom element namedrupal-view-{ID}
. Test the view on the frontend at the configured path<view-path>
and customize the component as desired.
Note that the chosen view-mode is automatically rendered with custom elements within the view. It's not required to force rendering it via custom elements.
Video tutorial
In the following tutorial an example configuration can be followed:
Note: The tutorial is a year old and uses drupal-view
as custom element name. That changed meanwhile, use drupal-view-{ID}
as custom element name or stay with the default drupal-view--default
.
Status
- Support for Views is rather new and problems may arise with certain configurations. Please report any issues in the Lupus Decoupled Drupal issue queue.
- Atm there is no support for rendering exposed filter forms. So those need to be added manually in the frontend, when needed.
- The Row style
Fields
is not supported yet (see #3461874). - Items formatted as
Rendered entities
are supported. These are needed for Search API Index Views.