This repository has been archived by the owner on May 16, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 4
Feature architecture
Dima Vyshniakov edited this page Oct 8, 2022
·
1 revision
Feature is a minimal working set of code capable of performing business logic task (e.g., event tracking, shopping basket etc.). From the architectural point of view, the feature is ES Module. Exports of the module (see index.js
in each folder) define the feature's public interface.
Features live in the src/features
folder.
All possible exports from the feature module can be divided in two groups:
- Selectors return data from the feature state or external source.
- Action creators mutate data inside feature state or perform externally applied actions (AJAX requests, web socket messages etc.).
Both groups are implemented as React hooks.
- Each folder has
index.js
file which contains allpublic
methods of this feature. Please do not import directly from feature files. They considered to beprivate
methods. - In order to avoid circular dependencies, don't use own
index.js
defined exports inside module, use relative imports instead. - Features may depend on other features existing using public interface.
- Features' hooks may and should be used in React components. Please avoid making React components too smart in terms of business logic. Use features instead.
- Some features may require internal state. State management is provided by Redux.
- Though Redux state is not mandatory for the feature. Some features may only depend on external sources (AJAX endpoints, URL parameters etc.).