This module is integrating the FSXA-Pattern-Library.
The FirstSpirit Experience Accelerator (FSXA) is the hybrid solution of a digital experience platform, combining a headless approach with enterprise capabilities. If you are interested in the FSXA check this Overview. You can order a demo online.
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 major version changes.
# npm
npm install fsxa-nuxt-module
# yarn
yarn add fsxa-nuxt-module
npm run test
NOTE: Currently the tests in FSXA-Nuxt-Module are not compatible to windows environments. If you want to run the tests in windows environment, we recommend to use WSL.
In order for the FSXA module of the FSXA-Pattern-Library to be registered with the Vuex store, it is necessary that Nuxt initializes Vuex already.
So if you don't have a store/index.(js/ts)
file yet, create it.
In addition, it is necessary that in the nuxtServerInit action of the Vuex store, the FSXA module of the FSXA pattern library is populated with the data from the SSR context.
import { FSXAActions } from "fsxa-pattern-library";
nuxtServerInit(_, { store }) {
// if you do have your nextServerInit already in place make sure to include this line
this.dispatch(FSXAActions.hydrateClient, store.state.fsxa);
},
There are multiple ways to configure this module.
Provide your configuration by adding an fsxa-key to your nuxt.config.js or nuxt.config.ts.
...
fsxa: {
// your configuration
}
...
Provide your configuration by creating an fsxa.config.ts / fsxa.config.js in your root directory.
export default {
// your configuration
};
Key | Default | Description |
---|---|---|
components.sections | '~/components/sections' | The folder where all your section-components are located at. You can define an index-file which will directly map keys to section-components. If no index file exists the filenames will be transformed to snake_case and are matched against the key provided by FirstSpirit. |
components.richtext | '~/components/richtext' | The folder where all your richtext-components are located at. You can define an index-file which will directly map keys to richtext-components. If no index file exists the filenames will be transformed to snake_case and are matched against the key provided by FirstSpirit. |
components.layouts | '~/components/layouts' | The folder where all your layout-components are located at. You can define an index-file which will directly map keys to layout-components. If no index file exists the filenames will be transformed to snake_case and are matched against the key provided by FirstSpirit. |
components.appLayout | undefined | You can provide a component that will override the layout of the application. If you are using TypeScript you should make sure, that you extend the FSXABaseAppLayout that is provided by the fsxa-pattern-library |
components.loader | undefined | You can provide a component that will be used while loading. If no component is returned, no loading animation is displayed. |
components.page404 | undefined | You can provide a component that will be used when no matching route could be found. If no component is returned, nothing will be displayed. |
devMode | false | Enable devMode in the fsxa-pattern-library . See documentation of fsxa-pattern-library for more information about this topic. |
useErrorBoundaryWrapper | true | Enable useErrorBoundaryWrapper in the fsxa-pattern-library . See documentation of fsxa-pattern-library for more information about this topic. |
customRoutes | undefined | You can provide a path, where your custom routes are defined. |
logLevel | 3 | You can provide a level for the logging. 0 = Info, 1 = Log, 2 = Warning, 3 = Error, 4 = None. |
fsTppVersion | undefined | DEPRECATED: use FSXA_SNAP_URL instead You can provide a version for tpp-snap. Check this out for more details. |
enableEventStream | false | When enabled, events for insert , replace and delete CaaS documents can be observed and handled. It's currently used in preview mode, to sync updated data in FirstSpirit with the CaaS and the App State. |
The LogLevel can also be set by providing an env variable called FSXA_LOG_LEVEL
. This will be priorized over the configuration file option.
FSXA-Nuxt-Module is a product of Crownpeak Technology GmbH, Dortmund, Germany. The FSXA-Nuxt-Module is subject to the Apache-2.0 license.
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.