auth.selectors.ts
3.44 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
///
/// Copyright © 2016-2024 The Thingsboard Authors
///
/// Licensed under the Apache License, Version 2.0 (the "License");
/// you may not use this file except in compliance with the License.
/// You may obtain a copy of the License at
///
/// http://www.apache.org/licenses/LICENSE-2.0
///
/// Unless required by applicable law or agreed to in writing, software
/// distributed under the License is distributed on an "AS IS" BASIS,
/// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
/// See the License for the specific language governing permissions and
/// limitations under the License.
///
import { createFeatureSelector, createSelector, select, Store } from '@ngrx/store';
import { AppState } from '../core.state';
import { AuthState } from './auth.models';
import { take } from 'rxjs/operators';
import { AuthUser } from '@shared/models/user.model';
import { UserSettings } from '@shared/models/user-settings.models';
import { getDescendantProp } from '@core/utils';
export const selectAuthState = createFeatureSelector< AuthState>(
'auth'
);
export const selectAuth = createSelector(
selectAuthState,
(state: AuthState) => state
);
export const selectIsAuthenticated = createSelector(
selectAuthState,
(state: AuthState) => state.isAuthenticated
);
export const selectIsUserLoaded = createSelector(
selectAuthState,
(state: AuthState) => state.isUserLoaded
);
export const selectAuthUser = createSelector(
selectAuthState,
(state: AuthState) => state.authUser
);
export const selectUserDetails = createSelector(
selectAuthState,
(state: AuthState) => state.userDetails
);
export const selectUserTokenAccessEnabled = createSelector(
selectAuthState,
(state: AuthState) => state.userTokenAccessEnabled
);
export const selectHasRepository = createSelector(
selectAuthState,
(state: AuthState) => state.hasRepository
);
export const selectTbelEnabled = createSelector(
selectAuthState,
(state: AuthState) => state.tbelEnabled
);
export const selectPersistDeviceStateToTelemetry = createSelector(
selectAuthState,
(state: AuthState) => state.persistDeviceStateToTelemetry
);
export const selectUserSettings = createSelector(
selectAuthState,
(state: AuthState) => state.userSettings
);
export const selectUserSettingsProperty = (path: NestedKeyOf<UserSettings>) => createSelector(
selectAuthState,
(state: AuthState) => getDescendantProp(state.userSettings, path)
);
export const selectOpenedMenuSections = createSelector(
selectAuthState,
(state: AuthState) => state.userSettings.openedMenuSections
);
export const getCurrentAuthState = (store: Store<AppState>): AuthState => {
let state: AuthState;
store.pipe(select(selectAuth), take(1)).subscribe(
val => state = val
);
return state;
};
export const getCurrentAuthUser = (store: Store<AppState>): AuthUser => {
let authUser: AuthUser;
store.pipe(select(selectAuthUser), take(1)).subscribe(
val => authUser = val
);
return authUser;
};
export const getCurrentUserSettings = (store: Store<AppState>): UserSettings => {
let userSettings: UserSettings;
store.pipe(select(selectUserSettings), take(1)).subscribe(
val => userSettings = val
);
return userSettings;
};
export const getCurrentOpenedMenuSections = (store: Store<AppState>): string[] => {
let openedMenuSections: string[];
store.pipe(select(selectOpenedMenuSections), take(1)).subscribe(
val => openedMenuSections = val
);
return openedMenuSections;
};