getChildPagesByParentUrl
Getting child pages with product information by parent page url as an array.
Description
Returns all created pages as an array of objects or an empty array [] (if there is no data) for the selected parent. It returns a Promise that resolves to an array of IPagesEntity objects.
Pages.getChildPagesByParentUrl(
url*,
langCode
);
Parameters schema
Schema
url(required): string
The URL of the parent page for which child pages are to be fetched
example: "about/our-team"
langCode: string
Language code. Default: "en_US"
example: "en_US"
Examples
Minimal example
const response = await Pages.getChildPagesByParentUrl('shop');
Example with attributes
const response = await Pages.getChildPagesByParentUrl('shop', 'en_US');
Example response
[
{
"id": 9,
"config": {},
"depth": 1,
"parentId": 8,
"pageUrl": "blog1",
"attributeSetIdentifier": null,
"localizeInfos": {
"title": "Blog 1",
"htmlContent": "",
"plainContent": "",
"menuTitle": "Blog 1"
},
"isVisible": true,
"products": 0,
"childrenCount": 0,
"type": "common_page",
"position": 1,
"templateIdentifier": null,
"isSync": false,
"categoryPath": "blog/blog1",
"rating": {},
"attributeValues": {},
"moduleFormConfigs": []
},
{
"id": 49,
"config": {},
"depth": 1,
"parentId": 8,
"pageUrl": "blog2",
"attributeSetIdentifier": null,
"localizeInfos": {
"title": "Blog 2",
"htmlContent": "",
"plainContent": "",
"menuTitle": "Blog 2"
},
"isVisible": true,
"products": 0,
"childrenCount": 0,
"type": "common_page",
"position": 2,
"templateIdentifier": null,
"isSync": false,
"categoryPath": "blog2",
"rating": {},
"attributeValues": {},
"moduleFormConfigs": []
}
]
Response schema
Schema: IPagesEntity
id: number
The identifier of the object.
example: 8
parentId: number | null
The id of the parent page, if it contains null, then it is the top-level page.
example: 10
pageUrl: string
Unique page Url.
example: "blog"
depth: number
Page nesting depth relative to parentId.
example: 10
localizeInfos: ILocalizeInfo
The name of the page, taking into account localization.
example:
{
"title": "Blog",
"menuTitle": "Blog",
"htmlContent": "",
"plainContent": ""
}
isVisible: boolean
A sign of page visibility.
example: true
type: PageType
Page type.
example: "common_page"
templateIdentifier: string | null
User id of the linked template.
example: "template"
attributeSetIdentifier: string | null
Set of attributes id.
example: "page"
attributeValues: IAttributeValues
Map of attribute values keyed by marker; empty object when none.
example:
{
"text": {
"type": "string",
"value": "some text",
"position": 0,
"additionalFields": []
}
}
isSync: boolean
Indication of page indexing.
example: true
template: object
Template object.
example:
{}
position: number
Item number (for sorting).
example: 2
config: Record<string, number>
Output settings for catalog pages.
example:
{
"rowsPerPage": 1,
"productsPerRow": 1
}
products: number
The number of products linked to the page.
example: 0
childrenCount: number
Children count.
example: 1
blocks: IBlockEntity[] | string[]
blocks.
example:
{
"id": 4,
"attributeSetIdentifier": null,
"title": "Template",
"generalTypeId": 4,
"identifier": "template",
"version": 0,
"generalTypeName": "catalog_page",
"attributeValues": {},
"position": 1
}
blocks.attributeValues: IAttributeValues
Map of attribute values keyed by marker; empty object when none.
example:
{
"block-text": {
"type": "string",
"value": "some text",
"isIcon": false,
"position": 0,
"additionalFields": [],
"isProductPreview": false
}
}
blocks.id: number
Unique identifier of the block.
example: 1234
blocks.localizeInfos: ILocalizeInfo
Localization information for the block.
example:
{
"key": "value"
}
blocks.version: number
Version of the block entity.
example: 1
blocks.identifier: string
Unique string identifier for the block.
example: "block1"
blocks.type: BlockType
Type of the block.
example: "product"
blocks.position: number
Position of the block for sorting.
example: 1
blocks.templateIdentifier: string | null
Identifier for the template used by the block, or null if not applicable.
example: "template1"
blocks.isVisible: boolean
Indicates whether the block is visible.
example: true
blocks.countElementsPerRow: number
Number of elements displayed per row in the block, if applicable.
example: 3
blocks.quantity: number
Quantity of items in the block, if applicable.
example: 5
blocks.similarProducts: IProductsResponse
Response containing similar products associated with the block.
example:
{
"total": 10,
"items": []
}
blocks.products: IProductsEntity[]
Array of product entities associated with the block.
example:
[
{
"id": 1,
"name": "Product 1"
},
{
"id": 2,
"name": "Product 2"
}
]
moduleFormConfigs: Array<IFormConfig>
Module form configurations linked to the page.
rating: IRating
Rating data.
total: string
Total number of products linked to the page.
example: "10"
categoryPath: string | null
Category path string; null for nested pages that have no own category path.
example: "catalog"