diff options
author | Herbert Eiselt <herbert.eiselt@highstreet-technologies.com> | 2019-02-11 14:54:12 +0100 |
---|---|---|
committer | Herbert Eiselt <herbert.eiselt@highstreet-technologies.com> | 2019-02-11 14:54:53 +0100 |
commit | 3d202a04b99f0e61b6ccf8b7a5610e1a15ca58e7 (patch) | |
tree | ab756cfa8de5eced886d3947423d198be8c0ce62 /sdnr/wt/odlux/framework/src/handlers | |
parent | 12a8c669f52c0e84d580c078cee849b25133b585 (diff) |
Add sdnr wt odlux
Add complete sdnr wireless transport app odlux core and apps
Change-Id: I5dcbfb8f3b790e3bda7c8df67bd69d81958f65e5
Issue-ID: SDNC-576
Signed-off-by: Herbert Eiselt <herbert.eiselt@highstreet-technologies.com>
Diffstat (limited to 'sdnr/wt/odlux/framework/src/handlers')
4 files changed, 145 insertions, 0 deletions
diff --git a/sdnr/wt/odlux/framework/src/handlers/applicationRegistryHandler.ts b/sdnr/wt/odlux/framework/src/handlers/applicationRegistryHandler.ts new file mode 100644 index 000000000..b30512cbb --- /dev/null +++ b/sdnr/wt/odlux/framework/src/handlers/applicationRegistryHandler.ts @@ -0,0 +1,14 @@ +import { IActionHandler } from '../flux/action'; + +import { ApplicationInfo } from '../models/applicationInfo'; +import { applicationManager } from '../services/applicationManager'; + +export interface IApplicationRegistration { + [name: string]: ApplicationInfo; +} + +const applicationRegistrationInit: IApplicationRegistration = applicationManager.applications; + +export const applicationRegistryHandler: IActionHandler<IApplicationRegistration> = (state = applicationRegistrationInit, action) => { + return state; +}; diff --git a/sdnr/wt/odlux/framework/src/handlers/applicationStateHandler.ts b/sdnr/wt/odlux/framework/src/handlers/applicationStateHandler.ts new file mode 100644 index 000000000..2a952b61e --- /dev/null +++ b/sdnr/wt/odlux/framework/src/handlers/applicationStateHandler.ts @@ -0,0 +1,70 @@ +import { IActionHandler } from '../flux/action'; +import { SetTitleAction } from '../actions/titleActions'; + +import { AddSnackbarNotification, RemoveSnackbarNotification } from '../actions/snackbarActions'; +import { AddErrorInfoAction, RemoveErrorInfoAction, ClearErrorInfoAction } from '../actions/errorActions'; + +import { IconType } from '../models/iconDefinition'; + +import { ErrorInfo } from '../models/errorInfo'; +import { SnackbarItem } from '../models/snackbarItem'; + +export interface IApplicationState { + title: string; + icon?: IconType; + + errors: ErrorInfo[]; + snackBars: SnackbarItem[]; +} + +const applicationStateInit: IApplicationState = { title: "Loading ...", errors: [], snackBars:[] }; + +export const applicationStateHandler: IActionHandler<IApplicationState> = (state = applicationStateInit, action) => { + if (action instanceof SetTitleAction) { + state = { + ...state, + title: action.title, + icon: action.icon + }; + } else if (action instanceof AddErrorInfoAction) { + state = { + ...state, + errors: [ + ...state.errors, + action.errorInfo + ] + }; + } else if (action instanceof RemoveErrorInfoAction) { + const index = state.errors.indexOf(action.errorInfo); + if (index > -1) { + state = { + ...state, + errors: [ + ...state.errors.slice(0, index), + ...state.errors.slice(index + 1) + ] + }; + } + } else if (action instanceof ClearErrorInfoAction) { + if (state.errors && state.errors.length) { + state = { + ...state, + errors: [] + }; + } + } else if (action instanceof AddSnackbarNotification) { + state = { + ...state, + snackBars: [ + ...state.snackBars, + action.notification + ] + }; + } else if (action instanceof RemoveSnackbarNotification) { + state = { + ...state, + snackBars: state.snackBars.filter(s => s.key !== action.key) + }; + } + return state; +}; diff --git a/sdnr/wt/odlux/framework/src/handlers/authenticationHandler.ts b/sdnr/wt/odlux/framework/src/handlers/authenticationHandler.ts new file mode 100644 index 000000000..e0ae1aa8d --- /dev/null +++ b/sdnr/wt/odlux/framework/src/handlers/authenticationHandler.ts @@ -0,0 +1,33 @@ +import { IActionHandler } from '../flux/action'; +import { UpdateAuthentication } from '../actions/authentication'; + +import { User } from '../models/authentication'; + +export interface IAuthenticationState { + user?: User; +} + +const initialToken = localStorage.getItem("userToken"); + +const authenticationStateInit: IAuthenticationState = { + user: initialToken && new User(initialToken) || undefined +}; + +export const authenticationStateHandler: IActionHandler<IAuthenticationState> = (state = authenticationStateInit, action) => { + if (action instanceof UpdateAuthentication) { + + if (action.bearerToken) { + localStorage.setItem("userToken", action.bearerToken); + } else { + localStorage.removeItem("userToken"); + } + + const user = action.bearerToken && new User(action.bearerToken) || undefined; + state = { + ...state, + user + }; + } + + return state; +}; diff --git a/sdnr/wt/odlux/framework/src/handlers/navigationStateHandler.ts b/sdnr/wt/odlux/framework/src/handlers/navigationStateHandler.ts new file mode 100644 index 000000000..d9036000a --- /dev/null +++ b/sdnr/wt/odlux/framework/src/handlers/navigationStateHandler.ts @@ -0,0 +1,28 @@ +import { IActionHandler } from '../flux/action'; +import { LocationChanged } from '../actions/navigationActions'; + + +export interface INavigationState { + pathname: string; + search: string; + hash: string; +} + +const navigationStateInit: INavigationState = { + pathname: '/', + search: '', + hash: '', +}; + + +export const navigationStateHandler: IActionHandler<INavigationState> = (state = navigationStateInit, action) => { + if (action instanceof LocationChanged) { + state = { + ...state, + pathname: action.pathname, + search: action.search, + hash: action.hash + } + } + return state; +}
\ No newline at end of file |