UNPKG

@linid-dm/directory-manager-client-core

Version:

Core package by providing a set of angular components for the Directory Manager app.

218 lines 26.6 kB
import { __decorate } from "tslib"; /** * Copyright (C) 2020-2024 Linagora * * This program is free software: you can redistribute it and/or modify it under * the terms of the GNU Affero General Public License as published by the Free * Software Foundation, either version 3 of the License, or (at your option) any * later version, provided you comply with the Additional Terms applicable for * LinID Directory Manager software by LINAGORA pursuant to Section 7 of the GNU * Affero General Public License, subsections (b), (c), and (e), pursuant to * which these Appropriate Legal Notices must notably (i) retain the display of * the "LinID™" trademark/logo at the top of the interface window, the display * of the “You are using the Open Source and free version of LinID™, powered by * Linagora © 2009–2013. Contribute to LinID R&D by subscribing to an Enterprise * offer!” infobox and in the e-mails sent with the Program, notice appended to * any type of outbound messages (e.g. e-mail and meeting requests) as well as * in the LinID Directory Manager user interface, (ii) retain all hypertext * links between LinID Directory Manager and https://linid.org/, as well as * between LINAGORA and LINAGORA.com, and (iii) refrain from infringing LINAGORA * intellectual property rights over its trademarks and commercial brands. Other * Additional Terms apply, see <http://www.linagora.com/licenses/> for more * details. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more * details. * * You should have received a copy of the GNU Affero General Public License and * its applicable Additional Terms for LinID Directory Manager along with this * program. If not, see <http://www.gnu.org/licenses/> for the GNU Affero * General Public License version 3 and <http://www.linagora.com/licenses/> for * the Additional Terms applicable to the LinID Directory Manager software. */ import { Injectable } from '@angular/core'; import { Action, Selector, State } from '@ngxs/store'; import { distinctUntilChanged, map } from 'rxjs'; import * as Ui from './ui.actions'; import * as i0 from "@angular/core"; const _isLargeScreen = (ss) => ss === 'lg' || ss === 'gt-lg' || ss === 'xl' || ss === 'gt-md'; const _changeSidenavMode = (mode) => mode === 'sidebar' ? 'sidenav' : 'sidebar'; const _changeSidenavModeOnResize = (stateFixed, mode, ss) => !stateFixed ? mode === 'sidenav' && !_isLargeScreen(ss) ? 'sidebar' : mode === 'sidebar' && _isLargeScreen(ss) ? 'sidenav' : mode : mode; const _initSidenavMode = (ss) => _isLargeScreen(ss) ? 'sidenav' : 'sidebar'; const _changeSidenavStateFixed = (mode, ss) => (mode === 'sidenav' && _isLargeScreen(ss)) || (mode === 'sidebar' && !_isLargeScreen(ss)); const _sidenavCollapsed = (sidenavStateFixed, isSidenavCollapsed, ss) => (sidenavStateFixed ? isSidenavCollapsed : !_isLargeScreen(ss)); export const isLargeScreen = (store$) => { return store$ .select((state) => state.ui.screenSize) .pipe(map(_isLargeScreen), distinctUntilChanged()); }; export const isSmallScreen = (store$) => { return isLargeScreen(store$).pipe(map((b) => !b)); }; let UiState = class UiState { static getLanguage(state) { return state.language; } static getSidenavMode(state) { return state.sidenavMode; } static getSidenavStateFixed(state) { return state.sidenavStateFixed; } static getIsSidenavCollapsed(state) { return state.isSidenavCollapsed; } static getScreenSize(state) { return state.screenSize; } static getTheme(state) { return state.theme; } static getGenericAccessibility(state) { return state.genericAccessibility; } static getAdvancedSearchAccessibility(state) { return state.genericAccessibility.advancedSearch; } static getFormAccessibility(state) { return state.genericAccessibility.form; } static getFilterAccessibility(state) { return state.genericAccessibility.filter; } static getArrayAccessibility(state) { return state.genericAccessibility.array; } static getSearchBarAccessibility(state) { return state.genericAccessibility.searchBar; } static getDetailHeaderAccessibility(state) { return state.genericAccessibility.detailHeader; } static getNotFoundAccessibility(state) { return state.genericAccessibility.notFound; } setLanguage(ctx, action) { ctx.setState({ ...ctx.getState(), language: action.payload.language, }); } toggleSidenav(ctx) { ctx.setState({ ...ctx.getState(), sidenavStateFixed: _changeSidenavStateFixed(ctx.getState().sidenavMode, ctx.getState().screenSize), sidenavMode: _changeSidenavMode(ctx.getState().sidenavMode), isSidenavCollapsed: !ctx.getState().isSidenavCollapsed, }); } changeScreenSize(ctx, action) { ctx.setState({ ...ctx.getState(), screenSize: action.payload.screenSize, sidenavMode: ctx.getState().sidenavMode === '' ? _initSidenavMode(action.payload.screenSize) : _changeSidenavModeOnResize(ctx.getState().sidenavStateFixed, ctx.getState().sidenavMode, action.payload.screenSize), isSidenavCollapsed: _sidenavCollapsed(ctx.getState().sidenavStateFixed, ctx.getState().isSidenavCollapsed, action.payload.screenSize), }); } changeTheme(ctx, action) { ctx.setState({ ...ctx.getState(), theme: action.payload.theme, }); } setGenericAccessibility(ctx, action) { ctx.setState({ ...ctx.getState(), genericAccessibility: action.payload, }); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: UiState, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); } static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: UiState }); } }; __decorate([ Action(Ui.SetLanguage) ], UiState.prototype, "setLanguage", null); __decorate([ Action(Ui.ToggleSidenav) ], UiState.prototype, "toggleSidenav", null); __decorate([ Action(Ui.ChangeScreenSize) ], UiState.prototype, "changeScreenSize", null); __decorate([ Action(Ui.ChangeTheme) ], UiState.prototype, "changeTheme", null); __decorate([ Action(Ui.SetGenericAccessibility) ], UiState.prototype, "setGenericAccessibility", null); __decorate([ Selector() ], UiState, "getLanguage", null); __decorate([ Selector() ], UiState, "getSidenavMode", null); __decorate([ Selector() ], UiState, "getSidenavStateFixed", null); __decorate([ Selector() ], UiState, "getIsSidenavCollapsed", null); __decorate([ Selector() ], UiState, "getScreenSize", null); __decorate([ Selector() ], UiState, "getTheme", null); __decorate([ Selector() ], UiState, "getGenericAccessibility", null); __decorate([ Selector() ], UiState, "getAdvancedSearchAccessibility", null); __decorate([ Selector() ], UiState, "getFormAccessibility", null); __decorate([ Selector() ], UiState, "getFilterAccessibility", null); __decorate([ Selector() ], UiState, "getArrayAccessibility", null); __decorate([ Selector() ], UiState, "getSearchBarAccessibility", null); __decorate([ Selector() ], UiState, "getDetailHeaderAccessibility", null); __decorate([ Selector() ], UiState, "getNotFoundAccessibility", null); UiState = __decorate([ State({ name: 'ui', defaults: { language: '', sidenavStateFixed: false, sidenavMode: '', isSidenavCollapsed: false, screenSize: '', theme: '', genericAccessibility: null, }, }) ], UiState); export { UiState }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: UiState, decorators: [{ type: Injectable }], propDecorators: { setLanguage: [], toggleSidenav: [], changeScreenSize: [], changeTheme: [], setGenericAccessibility: [] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui.state.js","sourceRoot":"","sources":["../../../../../../../../../packages/libs/client-core/src/lib/shared/states/ui/ui.state.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright (C) 2020-2024 Linagora\n *\n * This program is free software: you can redistribute it and/or modify it under\n * the terms of the GNU Affero General Public License as published by the Free\n * Software Foundation, either version 3 of the License, or (at your option) any\n * later version, provided you comply with the Additional Terms applicable for\n * LinID Directory Manager software by LINAGORA pursuant to Section 7 of the GNU\n * Affero General Public License, subsections (b), (c), and (e), pursuant to\n * which these Appropriate Legal Notices must notably (i) retain the display of\n * the \"LinID™\" trademark/logo at the top of the interface window, the display\n * of the “You are using the Open Source and free version of LinID™, powered by\n * Linagora © 2009–2013. Contribute to LinID R&D by subscribing to an Enterprise\n * offer!” infobox and in the e-mails sent with the Program, notice appended to\n * any type of outbound messages (e.g. e-mail and meeting requests) as well as\n * in the LinID Directory Manager user interface, (ii) retain all hypertext\n * links between LinID Directory Manager and https://linid.org/, as well as\n * between LINAGORA and LINAGORA.com, and (iii) refrain from infringing LINAGORA\n * intellectual property rights over its trademarks and commercial brands. Other\n * Additional Terms apply, see <http://www.linagora.com/licenses/> for more\n * details.\n *\n * This program is distributed in the hope that it will be useful, but WITHOUT\n * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS\n * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more\n * details.\n *\n * You should have received a copy of the GNU Affero General Public License and\n * its applicable Additional Terms for LinID Directory Manager along with this\n * program. If not, see <http://www.gnu.org/licenses/> for the GNU Affero\n * General Public License version 3 and <http://www.linagora.com/licenses/> for\n * the Additional Terms applicable to the LinID Directory Manager software.\n */\n\nimport { Injectable } from '@angular/core';\nimport { Action, Selector, State, StateContext, Store } from '@ngxs/store';\nimport { distinctUntilChanged, map, Observable } from 'rxjs';\nimport {\n  IAdvancedSearchAccessibility,\n  IArrayGenericAccessibility,\n  IDetailHeaderAccessibility,\n  IFilterAccessibility,\n  IFormAccessibility,\n  IGenericAccessibilityConfig,\n  INotFoundAccessibility,\n  ISearchBarAccessibility,\n} from '../../interfaces/configs.interface';\nimport { ScreenSize } from '../../interfaces/ui.interface';\nimport * as Ui from './ui.actions';\n\nexport interface UiStateModel {\n  language: string;\n  sidenavStateFixed: boolean;\n  sidenavMode: string;\n  isSidenavCollapsed: boolean;\n  screenSize: ScreenSize;\n  theme: string;\n  genericAccessibility: IGenericAccessibilityConfig;\n}\n\nconst _isLargeScreen = (ss: ScreenSize) =>\n  ss === 'lg' || ss === 'gt-lg' || ss === 'xl' || ss === 'gt-md';\n\nconst _changeSidenavMode = (mode: string) =>\n  mode === 'sidebar' ? 'sidenav' : 'sidebar';\n\nconst _changeSidenavModeOnResize = (\n  stateFixed: boolean,\n  mode: string,\n  ss: ScreenSize\n) =>\n  !stateFixed\n    ? mode === 'sidenav' && !_isLargeScreen(ss)\n      ? 'sidebar'\n      : mode === 'sidebar' && _isLargeScreen(ss)\n        ? 'sidenav'\n        : mode\n    : mode;\n\nconst _initSidenavMode = (ss: ScreenSize) =>\n  _isLargeScreen(ss) ? 'sidenav' : 'sidebar';\n\nconst _changeSidenavStateFixed = (mode: string, ss: ScreenSize) =>\n  (mode === 'sidenav' && _isLargeScreen(ss)) ||\n  (mode === 'sidebar' && !_isLargeScreen(ss));\n\nconst _sidenavCollapsed = (\n  sidenavStateFixed: boolean,\n  isSidenavCollapsed: boolean,\n  ss: ScreenSize\n) => (sidenavStateFixed ? isSidenavCollapsed : !_isLargeScreen(ss));\n\nexport const isLargeScreen = (store$: Store): Observable<boolean> => {\n  return store$\n    .select((state) => state.ui.screenSize)\n    .pipe(map(_isLargeScreen), distinctUntilChanged());\n};\n\nexport const isSmallScreen = (store$: Store): Observable<boolean> => {\n  return isLargeScreen(store$).pipe(map((b: boolean) => !b));\n};\n\n@State<UiStateModel>({\n  name: 'ui',\n  defaults: {\n    language: '',\n    sidenavStateFixed: false,\n    sidenavMode: '',\n    isSidenavCollapsed: false,\n    screenSize: '',\n    theme: '',\n    genericAccessibility: null,\n  },\n})\n@Injectable()\nexport class UiState {\n  @Selector()\n  static getLanguage(state: UiStateModel): string {\n    return state.language;\n  }\n\n  @Selector()\n  static getSidenavMode(state: UiStateModel): string {\n    return state.sidenavMode;\n  }\n\n  @Selector()\n  static getSidenavStateFixed(state: UiStateModel): boolean {\n    return state.sidenavStateFixed;\n  }\n\n  @Selector()\n  static getIsSidenavCollapsed(state: UiStateModel): boolean {\n    return state.isSidenavCollapsed;\n  }\n\n  @Selector()\n  static getScreenSize(state: UiStateModel): ScreenSize {\n    return state.screenSize;\n  }\n\n  @Selector()\n  static getTheme(state: UiStateModel): string {\n    return state.theme;\n  }\n\n  @Selector()\n  static getGenericAccessibility(\n    state: UiStateModel\n  ): IGenericAccessibilityConfig {\n    return state.genericAccessibility;\n  }\n\n  @Selector()\n  static getAdvancedSearchAccessibility(\n    state: UiStateModel\n  ): IAdvancedSearchAccessibility {\n    return state.genericAccessibility.advancedSearch;\n  }\n\n  @Selector()\n  static getFormAccessibility(state: UiStateModel): IFormAccessibility {\n    return state.genericAccessibility.form;\n  }\n\n  @Selector()\n  static getFilterAccessibility(state: UiStateModel): IFilterAccessibility {\n    return state.genericAccessibility.filter;\n  }\n\n  @Selector()\n  static getArrayAccessibility(\n    state: UiStateModel\n  ): IArrayGenericAccessibility {\n    return state.genericAccessibility.array;\n  }\n\n  @Selector()\n  static getSearchBarAccessibility(\n    state: UiStateModel\n  ): ISearchBarAccessibility {\n    return state.genericAccessibility.searchBar;\n  }\n\n  @Selector()\n  static getDetailHeaderAccessibility(\n    state: UiStateModel\n  ): IDetailHeaderAccessibility {\n    return state.genericAccessibility.detailHeader;\n  }\n\n  @Selector()\n  static getNotFoundAccessibility(state: UiStateModel): INotFoundAccessibility {\n    return state.genericAccessibility.notFound;\n  }\n\n  @Action(Ui.SetLanguage)\n  setLanguage(ctx: StateContext<UiStateModel>, action: Ui.SetLanguage): void {\n    ctx.setState({\n      ...ctx.getState(),\n      language: action.payload.language,\n    });\n  }\n\n  @Action(Ui.ToggleSidenav)\n  toggleSidenav(ctx: StateContext<UiStateModel>): void {\n    ctx.setState({\n      ...ctx.getState(),\n      sidenavStateFixed: _changeSidenavStateFixed(\n        ctx.getState().sidenavMode,\n        ctx.getState().screenSize\n      ),\n      sidenavMode: _changeSidenavMode(ctx.getState().sidenavMode),\n      isSidenavCollapsed: !ctx.getState().isSidenavCollapsed,\n    });\n  }\n\n  @Action(Ui.ChangeScreenSize)\n  changeScreenSize(\n    ctx: StateContext<UiStateModel>,\n    action: Ui.ChangeScreenSize\n  ): void {\n    ctx.setState({\n      ...ctx.getState(),\n      screenSize: action.payload.screenSize,\n      sidenavMode:\n        ctx.getState().sidenavMode === ''\n          ? _initSidenavMode(action.payload.screenSize)\n          : _changeSidenavModeOnResize(\n              ctx.getState().sidenavStateFixed,\n              ctx.getState().sidenavMode,\n              action.payload.screenSize\n            ),\n      isSidenavCollapsed: _sidenavCollapsed(\n        ctx.getState().sidenavStateFixed,\n        ctx.getState().isSidenavCollapsed,\n        action.payload.screenSize\n      ),\n    });\n  }\n\n  @Action(Ui.ChangeTheme)\n  changeTheme(ctx: StateContext<UiStateModel>, action: Ui.ChangeTheme): void {\n    ctx.setState({\n      ...ctx.getState(),\n      theme: action.payload.theme,\n    });\n  }\n\n  @Action(Ui.SetGenericAccessibility)\n  setGenericAccessibility(\n    ctx: StateContext<UiStateModel>,\n    action: Ui.SetGenericAccessibility\n  ): void {\n    ctx.setState({\n      ...ctx.getState(),\n      genericAccessibility: action.payload,\n    });\n  }\n}\n"]}