Skip to content
This repository has been archived by the owner on May 3, 2024. It is now read-only.

Latest commit

 

History

History
200 lines (131 loc) · 8 KB

State-Management.md

File metadata and controls

200 lines (131 loc) · 8 KB

👈 Return to Overview

State Management

Holocron Modules rely on one Store provided by Redux used primarily to cache the results of loaded data and Modules. Every Module may add their own Reducers to the shared Store (through Holocron Module Configuration) and may dispatch actions to transform the Store. Redux provides a simple way to store data on the Server and preload the store used by the Browser. This is commonly referred to as Server Side Rendering. One App employs the Ducks Specification design pattern for the logical grouping of Reducers, Action Creators, and Selectors (e.g. the error duck contains reducers, actions, and selectors for storing error data in the Redux Store).

Contents

Globals

global.BROWSER

Runs On

  • ✅ Server
  • ✅ Browser

Shape

global.BROWSER; // Boolean

global.BROWSER is provided in the Server and Browser environments to determine if the code is currently being executed on the Server or the Browser.

Holocron Module Configuration

Please see Holocron Module Configuration in the Holocron API.

Higher Order Components

Holocron Modules use Higher Order Components (HOC) to add behaviors regarding when a Module loads, connecting a Module with its Reducer(s) to a Redux Store (similar to Redux connect) and adding runtime validations for a Module.

Contents

holocronModule

holocronModule has been deprecated and will be removed in the next major version of Holocron. Please see Holocron Module Configuration.

Please see holocronModule in the Holocron API.

Shared Ducks

One App uses a default set of shared Redux Ducks (e.g. a design pattern for logical groupings of Reducers, Actions, and Selectors that depend on each other) to manage the state of core features (e.g. Loading Language Packs or Holocron Modules) on the Server and Browser environments.

The following is an overview of the shape One App provides:

{
  config,
  errorReporting,
  modules,
  error,
  browser,
  rendering,
  redirection,
  holocron,
  intl
}

The following API definitions describe the Ducks responsible for the state shape described above.

Contents

config Duck

The config Duck lists a subset of the environment variables set on the Server as well as all values set by provideStateConfig from the App Configuration API.

Contents:

State Shape

const state = new Map({
  config: new Map({
    // URL where the Browser sends client side errors to.
    reportingUrl: String,
    // URL where the One App static assets are located.
    cdnUrl: String,
    // The exact filename for the locale file used in the Browser.
    localeFilename: String,
    // Name of the Holocron Module that serves as the entry point to your application.
    rootModuleName: String,
    // ... Settings from provideStateConfig key values will land here.
    [provideStateConfigSettingName]: String,
  }),
  // ... Rest of Redux State
});

📘 More Information

Action Creators

setConfig

⚠️ For Internal Use by One App. Modules need not dispatch this action creator.

Shape

dispatch(setConfig(config));

Arguments

Argument Type Description
config Object An object with the properties listed in the Reducer below.

This config passed to setConfig replaces the contents of the config state object in the Redux Store.

errorReporting Duck

Please see the errorReporting Duck in the One App Ducks API.

error Duck

Please see the error Duck in the One App Ducks API.

browser Duck

Please see the browser Duck in the One App Ducks API.

rendering Duck

Please see the rendering Duck in the One App Ducks API.

redirection Duck

Please see the redirection Duck in the One App Ducks API.

holocron Duck

Please see the holocron Duck in the Holocron API.

intl Duck

Please see the intl Duck in the One App Ducks API.

☝️ Return To Top