From 3231d5fe6811eb124ee763cf8ea5587bfc61b8e6 Mon Sep 17 00:00:00 2001 From: Denys Vuika Date: Thu, 28 Feb 2019 18:35:11 +0000 Subject: [PATCH] support repository info with app state (#984) --- src/app/app.component.ts | 4 ++-- src/app/extensions/app.interface.ts | 5 +++-- .../extensions/evaluators/repository.evaluators.ts | 2 +- src/app/extensions/extension.service.ts | 4 ++-- src/app/store/actions/repository.actions.ts | 11 +++++------ src/app/store/reducers/app.reducer.ts | 12 +++++------- src/app/store/selectors/app.selectors.ts | 2 +- src/app/store/states/app.state.ts | 12 +++++++----- 8 files changed, 26 insertions(+), 26 deletions(-) diff --git a/src/app/app.component.ts b/src/app/app.component.ts index 074cb5b995..4ca77dd141 100644 --- a/src/app/app.component.ts +++ b/src/app/app.component.ts @@ -40,7 +40,7 @@ import { SetCurrentUrlAction, SetInitialStateAction, CloseModalDialogsAction, - SetRepositoryStatusAction, + SetRepositoryInfoAction, SetUserProfileAction } from './store/actions'; import { @@ -136,7 +136,7 @@ export class AppComponent implements OnInit, OnDestroy { .getRepositoryInformation() .subscribe((response: DiscoveryEntry) => { this.store.dispatch( - new SetRepositoryStatusAction(response.entry.repository.status) + new SetRepositoryInfoAction(response.entry.repository) ); }); } diff --git a/src/app/extensions/app.interface.ts b/src/app/extensions/app.interface.ts index dfae10563d..4068c8475b 100644 --- a/src/app/extensions/app.interface.ts +++ b/src/app/extensions/app.interface.ts @@ -23,10 +23,11 @@ * along with Alfresco. If not, see . */ -import { RuleContext, RepositoryState } from '@alfresco/adf-extensions'; +import { RuleContext } from '@alfresco/adf-extensions'; import { AuthenticationService } from '@alfresco/adf-core'; +import { RepositoryInfo } from '@alfresco/js-api'; export interface AppRuleContext extends RuleContext { - repository: RepositoryState; + repository: RepositoryInfo; auth: AuthenticationService; } diff --git a/src/app/extensions/evaluators/repository.evaluators.ts b/src/app/extensions/evaluators/repository.evaluators.ts index 4799146ab5..b03cb9a55e 100644 --- a/src/app/extensions/evaluators/repository.evaluators.ts +++ b/src/app/extensions/evaluators/repository.evaluators.ts @@ -30,5 +30,5 @@ export function hasQuickShareEnabled( context: AppRuleContext, ...args: RuleParameter[] ): boolean { - return context.repository.isQuickShareEnabled; + return context.repository.status.isQuickShareEnabled; } diff --git a/src/app/extensions/extension.service.ts b/src/app/extensions/extension.service.ts index cbd2636608..1333b205bc 100644 --- a/src/app/extensions/extension.service.ts +++ b/src/app/extensions/extension.service.ts @@ -48,7 +48,6 @@ import { ExtensionService, ProfileState, mergeObjects, - RepositoryState, ExtensionRef } from '@alfresco/adf-extensions'; import { AppConfigService, AuthenticationService } from '@alfresco/adf-core'; @@ -56,6 +55,7 @@ import { DocumentListPresetRef } from './document-list.extensions'; import { BehaviorSubject, Observable } from 'rxjs'; import { IconRef } from './icon.extensions'; import { AppRuleContext } from './app.interface'; +import { RepositoryInfo } from '@alfresco/js-api'; @Injectable({ providedIn: 'root' @@ -103,7 +103,7 @@ export class AppExtensionService implements AppRuleContext { selection: SelectionState; navigation: NavigationState; profile: ProfileState; - repository: RepositoryState; + repository: RepositoryInfo; references$: Observable; diff --git a/src/app/store/actions/repository.actions.ts b/src/app/store/actions/repository.actions.ts index cbe368047a..698bc6d8a7 100644 --- a/src/app/store/actions/repository.actions.ts +++ b/src/app/store/actions/repository.actions.ts @@ -24,12 +24,11 @@ */ import { Action } from '@ngrx/store'; -import { RepositoryState } from '@alfresco/adf-extensions'; +import { RepositoryInfo } from '@alfresco/js-api'; -export const SET_REPOSITORY_STATUS = 'SET_REPOSITORY_STATUS'; -export const GET_REPOSITORY_STATUS = 'GET_REPOSITORY_STATUS'; +export const SET_REPOSITORY_INFO = 'SET_REPOSITORY_INFO'; -export class SetRepositoryStatusAction implements Action { - readonly type = SET_REPOSITORY_STATUS; - constructor(public payload: RepositoryState) {} +export class SetRepositoryInfoAction implements Action { + readonly type = SET_REPOSITORY_INFO; + constructor(public payload: RepositoryInfo) {} } diff --git a/src/app/store/reducers/app.reducer.ts b/src/app/store/reducers/app.reducer.ts index 518397ab2f..289f175a33 100644 --- a/src/app/store/reducers/app.reducer.ts +++ b/src/app/store/reducers/app.reducer.ts @@ -30,8 +30,8 @@ import { SetSelectedNodesAction, SET_USER_PROFILE, SetUserProfileAction, - SET_REPOSITORY_STATUS, - SetRepositoryStatusAction, + SET_REPOSITORY_INFO, + SetRepositoryInfoAction, SET_LANGUAGE_PICKER, SetLanguagePickerAction, SET_CURRENT_FOLDER, @@ -86,10 +86,8 @@ export function appReducer( action )); break; - case SET_REPOSITORY_STATUS: - newState = updateRepositoryStatus(state, ( - action - )); + case SET_REPOSITORY_INFO: + newState = updateRepositoryStatus(state, action); break; default: newState = Object.assign({}, state); @@ -241,7 +239,7 @@ function setInfoDrawer(state: AppState, action: SetInfoDrawerStateAction) { function updateRepositoryStatus( state: AppState, - action: SetRepositoryStatusAction + action: SetRepositoryInfoAction ) { const newState = Object.assign({}, state); newState.repository = action.payload; diff --git a/src/app/store/selectors/app.selectors.ts b/src/app/store/selectors/app.selectors.ts index 91478d5a40..0030b73541 100644 --- a/src/app/store/selectors/app.selectors.ts +++ b/src/app/store/selectors/app.selectors.ts @@ -90,7 +90,7 @@ export const repositoryStatus = createSelector( export const isQuickShareEnabled = createSelector( repositoryStatus, - status => status.isQuickShareEnabled + info => info.status.isQuickShareEnabled ); export const isAdmin = createSelector( diff --git a/src/app/store/states/app.state.ts b/src/app/store/states/app.state.ts index dd2455ab21..ea85c82095 100644 --- a/src/app/store/states/app.state.ts +++ b/src/app/store/states/app.state.ts @@ -26,9 +26,9 @@ import { SelectionState, ProfileState, - NavigationState, - RepositoryState + NavigationState } from '@alfresco/adf-extensions'; +import { RepositoryInfo } from '@alfresco/js-api'; export interface AppState { appName: string; @@ -41,7 +41,7 @@ export interface AppState { navigation: NavigationState; infoDrawerOpened: boolean; documentDisplayMode: string; - repository: RepositoryState; + repository: RepositoryInfo; } export const INITIAL_APP_STATE: AppState = { @@ -67,8 +67,10 @@ export const INITIAL_APP_STATE: AppState = { }, infoDrawerOpened: false, documentDisplayMode: 'list', - repository: { - isQuickShareEnabled: true + repository: { + status: { + isQuickShareEnabled: true + } } };