description |
---|
Inject a sub-items list into your back office customizations. |
The Sub-items List module is meant to be used as a part of the editorial interface of [[= product_name =]]. It provides an interface for listing the sub-items of any location.
!!! caution
If you want to load the Sub-items module, you need to load the JS code for it in your view, as it's not available by default.
With plain JS:
const containerNode = document.querySelector('#sub-items-container');
ReactDOM.render(
React.createElement(ibexa.modules.SubItems, {
parentLocationId: { Number },
restInfo: {
token: { String },
siteaccess: { String }
}
}),
containerNode
);
With JSX:
const attrs = {
parentLocationId: {Number},
restInfo: {
token: {String},
siteaccess: {String}
}
};
<SubItemsModule {...attrs}/>
The <SubItemsModule />
module can handle additional properties.
There are two types of properties: required and optional.
All of them are listed below.
Without all the following properties the Sub-items module cannot work.
- parentLocationId {Number} - parent location ID
- restInfo {Object} - backend config object:
- token {String} - CSRF token
- siteaccess {String} - SiteAccess identifier
- handleEditItem {Function} - callback to handle edit content action
- generateLink {Function} - callback to handle view content action
Optionally, Sub-items module can take a following list of props:
- loadContentInfo {Function} - loads content item info. Takes two params:
- contentIds {Array} - list of content IDs
- callback {Function} - a callback invoked when content info is loaded
- loadContentTypes {Function} - loads content types. Takes one param:
- callback {Function} - callback invoked when content types are loaded
- loadLocation {Function} - loads location. Takes four params:
- restInfo {Object} - REST info params:
- token {String} - the user token
- siteaccess {String} - the current SiteAccess
- queryConfig {Object} - query config:
- locationId {Number} - location ID
- limit {Number} - content item limit
- offset {Number} - items offset
- sortClauses {Object} - the Sort Clauses, for example, {LocationPriority: 'ascending'}
- callback {Function} - callback invoked when location is loaded
- restInfo {Object} - REST info params:
- updateLocationPriority - updates item location priority. Takes two params:
- params {Object} - parameters hash containing:
- priority {Number} - priority value
- location {String} - REST location ID
- token {String} - CSRF token
- siteaccess {String} - SiteAccess identifier
- callback {Function} - callback invoked when location priority is updated
- params {Object} - parameters hash containing:
- activeView {String} - active list view identifier
- extraActions {Array} - list of extra actions. Each action is an object containing:
- component {Element} - React component class
- attrs {Object} - additional component properties
- items {Array} - list of location's sub-items
- limit {Number} - items limit count
- offset {Number} - items limit offset
- labels {Object} - list of module labels, see sub.items.module.js for details. Contains definitions for sub components:
- subItems {Object} - list of sub-items module labels
- tableView {Object} - list of table view component labels
- tableViewItem {Object} - list of table item view component labels
- loadMore {Object} - list of load more component labels
- gridViewItem {Object} - list of grid item view component labels
- languageContainerSelector {String} - selector where the language selector should be rendered
To add a Sub-items list on a page that doesn't have the (right) action sidebar, you need to do one of the following things:
- add a
<div>
element with the.ibexa-extra-actions-container
selector - change the selector in the Sub-items settings by sending the
languageContainerSelector
prop which takes the selector for the element that renders thelanguageSelector
.