The FSXABaseComponent is there to have a basic component to be able to implement further components. It provides different attributes and methods, which should simplify the development significantly. These are described in this section.
To use this base component a new class has to be created which extends the FSXABaseComponent
.
@Component
class Component extends FSXABaseComponent {}
If you want to have type support for your props you can provide an interface and pass it as a generic like the Props
interface in this example.
@Component
class Component extends FSXABaseComponent<Props> {}
If additionally you want type support for your events, you can pass a second interface.
@Component
class LayoutComponent extends FSXABaseComponent<Props, EventsWithOn> {}
Note: If you only want type support for your events and not the props you have to pass an empty interface {}
as the data generic.
To additionally have type support for your slots, you can pass a third interface.
@Component
class LayoutComponent extends FSXABaseComponent<Props, EventsWithOn, Slots> {}
Note: If you only want type support for your slots and not the props or events you have to pass empty interfaces {}
as the Props
and EventsWithOn
generics.
This property returns the NavigationItem that is matching the current path.
If null
is returned, no current route could be matched to the current path.
This property returns the globally configured project properties.
If no projectProperties are defined in your CaaS this will return null
.
This property returns true
if the app is delivering preview data.
It will return false
if it is released data.
This property returns the current locale abbreviation the content is displayed in, e.g. en_GB
.
getStoredItem<T>(key: string): T
This method returns the stored data which was set with the given key.
getUrlByPageId(pageId: string, locale?: string | undefined): string | null
This method returns the corresponding route for a given pageId
.
If no page was found null
will be returned.
setStoredItem<T>(key: string, value: T, ttl?: number): void
This method saves your data in the Vuex
-Store.
You can use this to store your data from 3rd party services that were fetched in the Server Side Rendering process to access it later in the client.
You can specify a time-to-live duration in ms, that determines how long the value will be valid. The default is `300000`ms.
triggerRouteChange(params: {pageId?:string, route?:string, locale?:string}): Promise<void>
This method will trigger a route change request. A pageId
, route
or locale
can be passed in.
If a corresponding page is found the route change will be triggered.
Since this is only available when javascript is enabled, make sure that some kind of fallback is provided.
With the triggerRouteChange
method you can also implement a language switch.
When implementing this you have to provide a valid locale abbreviation.
Make sure that you only pass the locale parameter.
Otherwise, undesirable side effects may occur.
Example:
triggerRouteChange({locale: 'en_GB'})