New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@bloomreach/spa-sdk

Package Overview
Dependencies
Maintainers
12
Versions
87
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@bloomreach/spa-sdk

Bloomreach SPA SDK

  • 14.0.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
8.1K
decreased by-30.82%
Maintainers
12
Weekly downloads
 
Created
Source

Bloomreach SPA SDK

NPM License

Bloomreach SPA SDK provides simplified headless integration with Bloomreach Experience Manager for JavaScript-based applications. This library interacts with the Page Model API and exposes a simplified and framework-agnostic interface over the page model.

What is Bloomreach Experience Manager?

Bloomreach Experience Manager (brXM) is an open and flexible CMS designed for developers and marketers. As the original headless CMS, brXM allows developers to build quickly and integrate with the systems. While it’s built for speed, it also provides top-notch personalization and channel management capabilities for marketers to drive results.

Features

  • Page Model API client;
  • Page Model parser;
  • URL generator;
  • brXM integration.

Get Started

Installation

To get the SDK into your project with NPM:

npm install @bloomreach/spa-sdk

And with Yarn:

yarn add @bloomreach/spa-sdk

Usage

The following code snippet requests a related page model and shows the page's title.

import axios from 'axios';
import { initialize } from '@bloomreach/spa-sdk';

async function showPage(path) {
  const page = await initialize({
    httpClient: axios,
    options: {
      live: {
        cmsBaseUrl: 'http://localhost:8080/site',
        spaBaseUrl: '',
      },
      preview: {
        cmsBaseUrl: 'http://localhost:8080/site/_cmsinternal',
        spaBaseUrl: '/site/_cmsinternal?bloomreach-preview=true',
      },
    },
    request: { path },
  });

  document.querySelector('#title').innerText = page.getTitle();
}

showPage(`${window.location.pathname}${window.location.search}`);

Configuration

The initialize function supports several options you may use to customize page initialization.

OptionRequiredDefaultDescription
httpClientyesnoneThe HTTP client that will be used to fetch the page model. Signature is similar to Axios client.
optionsyesnoneThe CMS URL options.
options.liveyesnoneThe CMS URL options for the live site.
options.live.apiBaseUrlnooptions.live.cmsBaseUrl + "/resourceapi"Base URL of the Page Model API for the live site (e.g. http://localhost:8080/site/resourceapi or http://localhost:8080/site/channel/resourceapi).
options.live.cmsBaseUrlyesnoneBase URL of the live site (e.g. http://localhost:8080/site or http://localhost:8080/site/channel).
options.live.spaBaseUrlno""Base URL of the live SPA (e.g. /account or //www.example.com).
options.previewyesnoneThe CMS URL options for the preview site.
options.preview.apiBaseUrlnooptions.preview.cmsBaseUrl + "/resourceapi"Base URL of the Page Model API for the preview site (e.g. http://localhost:8080/site/_cmsinternal/resourceapi or http://localhost:8080/site/_cmsinternal/channel/resourceapi).
options.preview.cmsBaseUrlyesnoneBase URL of the live site (e.g. http://localhost:8080/site/_cmsinternal or http://localhost:8080/site/_cmsinternal/channel).
options.preview.spaBaseUrlno""Base URL of the live SPA (e.g. /site/_cmsinternal?bloomreach-preview=true or /site/_cmsinternal/channel?bloomreach-preview=true). This path and query string parameters will be used to detect whether it is a preview mode or not.
requestyesnoneCurrent user's request.
request.pathyesnoneThe path part of the URL, including a query string if present (e.g. /path/to/page?foo=1).
request.headersno{}An object holding request headers. It should contain a Cookie header if rendering is happening on the server-side.
windownowindowA window object reference will be used to interact with brXM. It needs to be set when initialize is being called within an iframe or worker process.

Reference

The complete API reference can be found here.

Functions
FunctionDescription
initialize(config, model?): Promise<Page>This function accepts a configuration object as an argument and returns a promisified JavaScript object representing the page model. In case, when the page model has already been fetched, you can pass this JSON blob as a second parameter.
destroy(page: Page): voidDestroys the integration with the SPA page object.
isPage(value): booleanChecks whether a value is a page.
isComponent(value): booleanChecks whether a value is a page component.
isContainer(value): booleanChecks whether a value is a page container.
isContainerItem(value): booleanChecks whether a value is a page container item.
isMeta(value): booleanChecks whether a value is a meta-data object.
isMetaComment(value): booleanChecks whether a value is a meta-data comment.
isLink(value): booleanChecks whether a value is a link.
isReference(value): booleanChecks whether a value is a content reference.
Constants
ConstantDescription
META_POSITION_BEGINMeta-data following before a page component.
META_POSITION_ENDMeta-data following after a page component.
TYPE_CONTAINER_BOXA blocked container with blocked items.
TYPE_CONTAINER_INLINEA blocked container with inline items.
TYPE_CONTAINER_NO_MARKUPA container without surrounding markup.
TYPE_CONTAINER_ORDERED_LISTAn ordered list container.
TYPE_CONTAINER_UNORDERED_LISTAn unordered list container.
TYPE_LINK_EXTERNALLink to a page outside the current application.
TYPE_LINK_INTERNALLink to a page inside the current application.
TYPE_LINK_RESOURCELink to a CMS resource.
Objects
Page

The Page class represents the brXM page to render. This is the main entry point to the page model.

MethodDescription
getComponent(...componentNames): Component | undefinedGets a component in the page (e.g. getComponent('main', 'right')). If componentNames is omitted, then the page root component will be returned.
getContent(reference: Reference | string): Content | undefinedGets a content item used on the page.
getMeta(meta): Meta[]Generates a meta-data from the provided meta model.
getTitle(): string | undefinedGets the title of the page, or undefined if not configured.
getUrl(link?: Link): stringGenerates a URL for a link object.
- If the link object type is internal or external, then it will prepend spaBaseUrl. In case when the link starts with the same path as in cmsBaseUrl, this part will be removed.
- If it is a resource link, then it will prepend the origin part from the cmsBaseUrl option.
- If the link parameter is omitted, then the link to the current page will be returned.
- In other cases, the link will be returned as-is.
getUrl(path: string): stringGenerates an SPA URL for the path.
- If it is a relative path, then it will prepend spaBaseUrl.
- If it is an absolute path, then the behavior will be similar to internal and external link generation.
isPreview(): booleanReturns whether the page is in the preview mode.
rewriteLinks(content: string, type?: string): stringRewrite links to pages and resources in the HTML content. This method looks up for a tags with data-type and href attributes and img tags with src attribute. Links will be updated according to the configuration used to initialize the page. The type parameter is similar to mimeType parameter of the DOMParser.
sync(): voidSynchronizes the brXM integration state (UI elements positions).
toJSON(): objectA plain JavaScript object of the page model.
Component

The Component class corresponds to page nodes, and it may hold other components inside.

MethodDescription
getId(): stringReturns the component id.
getMeta(): Meta[]Returns the component meta-data collection.
getModels(): objectReturns the map of the component models.
getUrl(): string | undefinedReturns the link to the partial component model.
getName(): stringReturns the name of the component.
getParameters(): objectReturns the parameters of the component.
getChildren(): Component[]Returns the direct children of the component.
getComponent(...componentNames: string[]): Component | undefinedLooks up for a nested component.
getComponentById(id: string): Component | undefinedLooks up for a nested component by its id.
Container

The Container class represents a page node that is actually present in the DOM but as an element surrounding its children. Container extends the Component class, and therefore, all the Component methods are applicable here.

MethodDescription
getType(): string | undefinedReturns the type of a container.
Container Item

The ContainerItem objects are usually visible on the page and interact with the user. Container Item extends the Component class, and therefore, all the Component methods are applicable here.

MethodDescription
getType(): string | undefinedReturns the type of a container item. The available types depend on which container items have been configured in the backend (e.g. "Banner").
isHidden(): booleanReturns whether the component should not render anything. Hiding components is only possible with the Relevance feature.
on(eventName: string, listener: Function): FunctionSubscribes for an event and returns the unsubscribe function.
off(eventName: string, listener: Function): voidUnsubscribes from an event.
Content

The Content object holds document data that is used by the page components.

MethodDescription
getId(): stringReturns the content id.
getLocale(): string | undefinedReturns the content locale.
getMeta(): Meta[]Returns the content meta-data collection.
getName(): stringReturns the content name.
getData(): objectReturns the content data as it is returned in the Page Model API.
getUrl(): string | undefinedReturns the link to the content.
Meta

The Meta objects are being used by the brXM to page and its components.

MethodDescription
getData(): stringReturns the meta-data.
getPosition(): stringReturns the meta-data position relative to the related element.

FAQ

License

Published under Apache 2.0 license.

Keywords

FAQs

Package last updated on 25 Nov 2019

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc