aboutsummaryrefslogtreecommitdiffstats
path: root/sdnr/wt/odlux/framework/src
diff options
context:
space:
mode:
Diffstat (limited to 'sdnr/wt/odlux/framework/src')
-rw-r--r--sdnr/wt/odlux/framework/src/handlers/authenticationHandler.ts4
-rw-r--r--sdnr/wt/odlux/framework/src/services/applicationApi.ts21
2 files changed, 24 insertions, 1 deletions
diff --git a/sdnr/wt/odlux/framework/src/handlers/authenticationHandler.ts b/sdnr/wt/odlux/framework/src/handlers/authenticationHandler.ts
index 2abe82142..a159cb627 100644
--- a/sdnr/wt/odlux/framework/src/handlers/authenticationHandler.ts
+++ b/sdnr/wt/odlux/framework/src/handlers/authenticationHandler.ts
@@ -3,6 +3,8 @@ import { UpdateAuthentication } from '../actions/authentication';
import { User } from '../models/authentication';
+import { onLogin, onLogout } from '../services/applicationApi';
+
export interface IAuthenticationState {
user?: User;
}
@@ -19,8 +21,10 @@ export const authenticationStateHandler: IActionHandler<IAuthenticationState> =
const user = action.bearerToken && new User(action.bearerToken) || undefined;
if (user) {
localStorage.setItem("userToken", user.toString());
+ onLogin();
} else {
localStorage.removeItem("userToken");
+ onLogout();
}
state = {
diff --git a/sdnr/wt/odlux/framework/src/services/applicationApi.ts b/sdnr/wt/odlux/framework/src/services/applicationApi.ts
index bddfb24c6..b097b23b1 100644
--- a/sdnr/wt/odlux/framework/src/services/applicationApi.ts
+++ b/sdnr/wt/odlux/framework/src/services/applicationApi.ts
@@ -1,10 +1,21 @@
+import { Event } from '../common/event';
import { ApplicationStore } from '../store/applicationStore';
-
let resolveApplicationStoreInitialized: (store: ApplicationStore) => void;
let applicationStore: ApplicationStore | null = null;
const applicationStoreInitialized: Promise<ApplicationStore> = new Promise((resolve) => resolveApplicationStoreInitialized = resolve);
+const loginEvent = new Event();
+const logoutEvent = new Event();
+
+export const onLogin = () => {
+ loginEvent.invoke();
+}
+
+export const onLogout = () => {
+ logoutEvent.invoke();
+}
+
export const setApplicationStore = (store: ApplicationStore) => {
if (!applicationStore && store) {
applicationStore = store;
@@ -19,6 +30,14 @@ export const applicationApi = {
get applicationStoreInitialized(): Promise<ApplicationStore> {
return applicationStoreInitialized;
+ },
+
+ get loginEvent() {
+ return loginEvent;
+ },
+
+ get logoutEvent() {
+ return logoutEvent;
}
};