fjdsdjjxsa-proxy-api
TypeScript icon, indicating that this package has built-in type declarations

10.21.1-alpha.0 • Public • Published

JavaScript Content API Library · Dedicated Client Package

The JavaScript Content API Library a.k.a. Content API is an interface handling data coming from the FirstSpirit CaaS and the Navigation Service. The data is processed and transformed so that it can be used in any JavaScript project.

SubPackage This package holds the compiled client part of the Content API. It is intended to be shipped in client environments, such as the users' browser. It is optimized to hold only necessary parts needed for execution in a client context. The main functionality is to talk to a backend service, implementing the FSXARemoteApi class.

Attention We would like to inform you that the project previously known as "FSXA-API" has recently undergone a name change. The project is now called "JavaScript Content API Library", but please note that this change solely affects the project's name, repository, and associated branding elements. The core code and functionality of the library remain unchanged. The purpose and scope of the library, as well as its intended usage and compatibility, remain consistent. The decision to change the name was made as the term "fsxa" no longer accurately represents the project's current scope, as other components beyond the fjdsdjjxsa-api are now discontinued. The name change aims to align the project's branding with its refined purpose and to avoid any confusion regarding its functionality.

Experimental features

Features marked as experimental are subject to change as long as they remain in the experimental state. Breaking changes to experimental features are not reflected in a major version changes.

Legal Notices

JavaScript Content API Library is a product of Crownpeak Technology GmbH, Dortmund, Germany. The JavaScript Content API Library is subject to the Apache-2.0 license.

Methods

In this section all available methods will be explained using examples.

Constructor

To be able to use the Content API, a new object must be created.

If you want to use the information provided by the CaaS in your frontend, you can use the FSXAProxyApi provided with this package. It proxies the requested resources to a middleware Rest Api, that does not expose secrets. If you want to use it in your server, you can use the FSXARemoteApi. This is not supported by this package. You have to implement all backend related code with the parent package fjdsdjjxsa-api. It then can be registered as a Rest Api that can be called from a FSXAProxyApi instance you can implement with this package (fjdsdjjxsa-proxy-api).

However, to have a fully running application, we recommend using the Content API in your server as well as in your frontend.

The log level can be: 0 = Info 1 = Log 2 = Warning 3 = Error 4 = None. The default is set to 3.

Here is an example of how the FSXAProxyApi could be used backend. Make sure you have fjdsdjjxsa-proxy-api installed.

import { FSXAProxyApi, LogLevel } from 'fjdsdjjxsa-proxy-api'

const locale = 'de_DE'
const proxyAPI = new FSXAProxyApi(
  'http://localhost:3002/api',
  LogLevel.INFO
)

// you can also fetch navigation from proxyAPI
const navigationResponse = await proxyAPI.fetchNavigation({
  locale,
  initialPath: '/'
})

fetchNavigation

This method fetches the navigation from the configured navigation service. You need to pass a FetchNavigationParams object.

Example:

proxyAPI.fetchNavigation({
  locale: 'en_EN',
  initialPath: '/',
})

fetchElement

This method fetches an element from the configured CaaS. The FetchElementParams object defines options to specify your request. Check FSXARemoteApi.buildCaaSUrl from the fjdsdjjxsa-api package to know which URL will be used.

proxyAPI.fetchElement({
  id: 'xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx',
  locale: 'de_DE',
})

Note
The 'raw' CaaS data might be helpful when you want to know the key names that you can filter for. It is possible to access that data directly with the authorization header and the CaaS Url when working with the fjdsdjjxsa-api package.

fetchByFilter

Returns the matching CaaS data entries. It maps the given entries to a more frontend-friendly format. Unnecessary fields will be omitted and the structure is simpler.

Expects as input parameter an array of filters and a language abbreviation. Optionally a page number, page size, sort and additional parameters can be passed.
Optionally, a remoteProject can be passed. If one is passed, the element will be fetched from this project instead of the default one.

Several filter objects can be specified in the filter array, the results will then correspond to all specified filters.

One filter object must have a:
field which specifies the searched key,
operator which specifies the search operation,
value which specifies the value that is looked for.

More information to the filters

In this example we search for all elements with the fsType equals Example. We want the 2nd page with a maximum of 50 entries. The results should be sorted by fsType descending. However, we do not want the identifier to appear:

proxyApi.fetchByFilter({
  filters: [
    {
      field: 'fsType',
      operator: ComparisonQueryOperatorEnum.EQUALS,
      value: 'Example',
    },
  ],
  locale: 'en',
  page: 2,
  pagesize: 50,
  additionalParams: { keys: { identifier: 0 } },
  sort: [{ name: 'fsType', order: 'desc' }],
})

The default sorting is by the id descending. MultiSort is possible and the first sort param is prioritized over subsequent. The sorting is happening on the raw data.

Attention
The keys names which are passed to the fetchByFilter method (e.g. in the filters or the additionalParams) have to match the key names that are present in the CaaS data.

fetchProjectProperties

Returns the project properties of the given language.

Expects a parameter object with the locale.

ATTENTION: Works only with CaaSConnect module version 3 onwards.

Example:

proxyApi.fetchProjectProperties({
  locale: 'de_DE',
})

Filter

You can customize your queries in the fetchByFilter method with these operations. For more information please refer to the MongoDB documentation. Links are provided in each section.

Helpers

There are also some additional helper methods which can be used for different purposes.

type AvailableLocaleParams = {
  navigationServiceURL: string
  projectId: string
  contentMode: string | ('preview' | 'release')
}
getAvailableLocales({
  projectId: 'xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx',
  navigationServiceURL: 'https://your.navigation-service.url/navigation',
  contentMode: 'preview',
})

This method provides a list of available locales configured in your FirstSpirit project. It is recommended that the configuration matches the ISO format. E.g. ["en_GB", "de_DE"]

  Promise<string[]>

Logical Query Operators

These operators can also be found in the MongoDB Documentation

Enum Operation
LogicalQueryOperatorEnum.AND $and
LogicalQueryOperatorEnum.NOT $not
LogicalQueryOperatorEnum.NOR $nor
LogicalQueryOperatorEnum.OR $or

Comparison Query Operators

These operators can also be found in the MongoDB Documentation

Enum Operation
ComparisonQueryOperatorEnum.GREATER_THAN_EQUALS $gte
ComparisonQueryOperatorEnum.GREATER_THAN $gt
ComparisonQueryOperatorEnum.EQUALS $eq
ComparisonQueryOperatorEnum.IN $in
ComparisonQueryOperatorEnum.LESS_THAN $lt
ComparisonQueryOperatorEnum.LESS_THAN_EQUALS $lte
ComparisonQueryOperatorEnum.NOT_EQUALS $ne
ComparisonQueryOperatorEnum.NOT_IN $nin

Evaluation Query Operators

These operators can also be found in the MongoDB Documentation

Enum Operation
EvaluationQueryOperatorEnum.REGEX $regex

Array Query Operators

These operators can also be found in the MongoDB Documentation

Enum Operation
ArrayQueryOperatorEnum.ALL $all

Type Mapping

Input Components

This table gives an overview of the FirstSpirit input components, which can be defined in the "Form" tab of the FirstSpirit templates. Each input component has a (Java) data type, which has a representation in the CaaS. Those values are mapped to an interface of the Content API.

FirstSpirit Input Component CaaS Representation Content API Value
FS_CATALOG
Catalog<Catalog$Card>
= CaaSApi_FSCatalog
= CaaSApi_Card[]
Section[]
CMS_INPUT_CHECKBOX
Set<Option>
= CaaSApi_CMSInputCheckbox
= CaaSApi_Option[]
Option[]
CMS_INPUT_COMBOBOX
Option
= CaaSApi_CMSInputCombobox
= CaaSApi_Option|null
Option
FS_DATASET
DatasetContainer
= CaaSApi_FSDataset
= CaaSApi_Dataset|CaaSApi_DataEntry[]|null
Dataset
CMS_INPUT_DATE
Date
= CaaSApi_CMSInputDate
= string(ISO_8601)|null
Date
CMS_INPUT_DOM
DomElement
= CaaSApi_CMSInputDOM
= string (FS-XML)
RichTextElement[]
CMS_INPUT_DOMTABLE
Table
= CaaSApi_CMSInputDOMTable
= string (FS-XML)
RichTextElement[]
CMS_INPUT_IMAGEMAP
MappingMedium
= CaaSApi_CMSImageMap
= CaaSApi_CMSImageMap
ImageMap
FS_INDEX
Index<Index$Record>
= CaaSApi_FSIndex
= CaaSApi_Record[]
DataEntries[]
CMS_INPUT_LINK
Link
= CaaSApi_CMSInputLink
= Object
Link
CMS_INPUT_LIST
Set<Option>
= CaaSApi_CMSInputList
= any[]
Option[]
CMS_INPUT_NUMBER
Number
= CaaSApi_CMSInputNumber
= number
number
CMS_INPUT_PERMISSION
Permissions
= CaaSApi_CMSInputPermission
= CaaSAPI_PermissionActivity[][]
Permission
CMS_INPUT_RADIOBUTTON
Option
= CaaSApi_CMSInputRadioButton
= CaaSApi_Option|null
Option
FS_REFERENCE
TargetReference
= CaaSApi_FSReference
= CaaSApi_BaseRef|CaaSApi_PageRefRef|CaaSApi_GCARef|CaaSApi_MediaRef|null
CMS_INPUT_TEXT
String
= CaaSApi_CMSInputText
= string
string
CMS_INPUT_TEXTAREA
String
= CaaSApi_CMSInputTextArea
= string
string
CMS_INPUT_TOGGLE
Boolean
= CaaSApi_CMSInputToggle
= boolean|null
boolean

Disclaimer

This document is provided for information purposes only. Crownpeak Technology may change the contents hereof without notice. This document is not warranted to be error-free, nor subject to any other warranties or conditions, whether expressed orally or implied in law, including implied warranties and conditions of merchantability or fitness for a particular purpose. Crownpeak Technology specifically disclaims any liability with respect to this document and no contractual obligations are formed either directly or indirectly by this document. The technologies, functionality, services, and processes described herein are subject to change without notice.

Readme

Keywords

none

Package Sidebar

Install

npm i fjdsdjjxsa-proxy-api

Weekly Downloads

1

Version

10.21.1-alpha.0

License

Apache-2.0

Unpacked Size

723 kB

Total Files

68

Last publish

Collaborators

  • mrj-cp