ngx-register-base 1.2.2 → 1.2.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -2,7 +2,9 @@
2
2
 
3
3
  Эта библиотека была создана с помощью [Angular CLI](https://github.com/angular/angular-cli) версия 18.2.0.
4
4
 
5
- ## Иконки
5
+ ## Подключение иконок
6
+
7
+ angular.json:
6
8
 
7
9
  ```json
8
10
  {
@@ -17,10 +19,56 @@
17
19
  }
18
20
  ```
19
21
 
20
- ## Стили
22
+ ## Подключение стилей
23
+
24
+ angular.json:
21
25
 
22
26
  ```json
23
27
  {
24
28
  "styles": [ ... , "ngx-register-base/styles/styles.less"]
25
29
  }
26
30
  ```
31
+
32
+ ## Сервисы
33
+
34
+ ### Сервис для управления аутентификацией пользователя:
35
+
36
+ ```ts
37
+ export enum EUserPermissions {}
38
+
39
+ @Injectable({
40
+ providedIn: 'root',
41
+ })
42
+ export class UserProfileService implements IUserProfileLoader {
43
+ // Имплементация методов IUserProfileLoader
44
+ }
45
+
46
+ // Подключение глобально в app.config.ts
47
+ { provide: USER_PROFILE_LOADER, useExisting: UserProfileService }
48
+ ```
49
+
50
+ ### Сервис управления пользовательскими настройками:
51
+
52
+ ```ts
53
+ @Injectable()
54
+ export class SmaTpUserSettingsStore implements IUserSettingsLoader {
55
+ // Имплементация методов IUserSettingsLoader
56
+ }
57
+
58
+ // Подключение по месту использования (компонент реестра)
59
+ { provide: USER_SETTINGS_LOADER, useClass: SmaTpUserSettingsStore }
60
+ ```
61
+
62
+ ### Сервис управления состоянием навигационного меню:
63
+
64
+ ```ts
65
+ @Injectable({
66
+ providedIn: 'root',
67
+ })
68
+ export class MenuStateService extends SprocAbstractMenuConstructorStore {
69
+ // Имплементация методов SprocAbstractMenuConstructorStore
70
+ }
71
+
72
+ // Подключение глобально в app.config.ts
73
+ { provide: PAGE_MENU_STATE, useExisting: MenuStateService }
74
+ ```
@@ -1,5 +1,3 @@
1
1
  export { RegisterTableFilterComponent } from './register-table-filter.component';
2
2
  export { RegisterTableFilterModule } from './register-table-filter.module';
3
- export * from './register-table-filter.consts';
4
- export * from './register-table-filter.types';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcmVnaXN0ZXItYmFzZS9zcmMvbGliL2NvbXBvbmVudHMvZmlsdGVycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUNqRixPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUMzRSxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsK0JBQStCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBSZWdpc3RlclRhYmxlRmlsdGVyQ29tcG9uZW50IH0gZnJvbSAnLi9yZWdpc3Rlci10YWJsZS1maWx0ZXIuY29tcG9uZW50JztcbmV4cG9ydCB7IFJlZ2lzdGVyVGFibGVGaWx0ZXJNb2R1bGUgfSBmcm9tICcuL3JlZ2lzdGVyLXRhYmxlLWZpbHRlci5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWdpc3Rlci10YWJsZS1maWx0ZXIuY29uc3RzJztcbmV4cG9ydCAqIGZyb20gJy4vcmVnaXN0ZXItdGFibGUtZmlsdGVyLnR5cGVzJztcbiJdfQ==
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcmVnaXN0ZXItYmFzZS9zcmMvbGliL2NvbXBvbmVudHMvZmlsdGVycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUNqRixPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IFJlZ2lzdGVyVGFibGVGaWx0ZXJDb21wb25lbnQgfSBmcm9tICcuL3JlZ2lzdGVyLXRhYmxlLWZpbHRlci5jb21wb25lbnQnO1xuZXhwb3J0IHsgUmVnaXN0ZXJUYWJsZUZpbHRlck1vZHVsZSB9IGZyb20gJy4vcmVnaXN0ZXItdGFibGUtZmlsdGVyLm1vZHVsZSc7XG4iXX0=
@@ -1,7 +1,7 @@
1
1
  import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output, } from '@angular/core';
2
2
  import { combineLatest, debounceTime, map, Subject, takeUntil, of } from 'rxjs';
3
3
  import { EInputsAction, EInputsState, } from '../../types';
4
- import { MENU_STATE_SERVICE } from './register-table-filter.consts';
4
+ import { PAGE_MENU_STATE } from '../page-menu';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "../../core";
7
7
  import * as i2 from "../../services";
@@ -28,7 +28,7 @@ export class RegisterTableFilterComponent {
28
28
  this.filterListHeaderTitle = 'Фильтр';
29
29
  this.footerApplyButtonLabel = 'Применить';
30
30
  this.clickApplyButton = new EventEmitter();
31
- this._menuState = inject(MENU_STATE_SERVICE);
31
+ this._menuState = inject(PAGE_MENU_STATE);
32
32
  this._unsubscribe$ = new Subject();
33
33
  this.FilterState = EInputsState;
34
34
  this.filterState$ = this._filterStateService.state$.pipe(map((filterState) => filterState.state));
@@ -152,4 +152,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
152
152
  }], clickApplyButton: [{
153
153
  type: Output
154
154
  }] } });
155
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"register-table-filter.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-register-base/src/lib/components/filters/register-table-filter.component.ts","../../../../../../projects/ngx-register-base/src/lib/components/filters/register-table-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport { combineLatest, debounceTime, map, Subject, takeUntil, of } from 'rxjs';\nimport {\n  EInputsAction,\n  EInputsState,\n  GqlFields,\n  IInputsState,\n  ITpUserSettings,\n  ITpUserSettingsSettingsFilter,\n} from '../../types';\nimport { FiltersService, FiltersStateService } from '../../services';\nimport { RegisterBaseStore } from '../../core';\nimport { MENU_STATE_SERVICE } from './register-table-filter.consts';\n\n@Component({\n  selector: 'sproc-register-table-filter',\n  templateUrl: './register-table-filter.component.html',\n  styleUrls: ['./register-table-filter.component.less'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class RegisterTableFilterComponent<Type extends Record<string, any>>\n  implements OnInit, AfterViewInit, OnDestroy\n{\n  /** Высота всего компонента фильтров */\n  @Input() height: string | undefined;\n  @Input() showTotal = true;\n  @Input() showPin = true;\n  @Input() showCloseButton = true;\n  @Input() acceptButtonDisabled = false;\n  @Input() applyButtonDisabled = false;\n  /** Доп. отступ для вычисления высоты панели (в пикселях) */\n  @Input() subOffsetHeight = 0;\n  @Input() filterListHeaderTitle = 'Фильтр';\n  @Input() footerApplyButtonLabel = 'Применить';\n\n  @Output() clickApplyButton = new EventEmitter<void>();\n\n  private readonly _menuState = inject(MENU_STATE_SERVICE);\n\n  private readonly _unsubscribe$: Subject<void> = new Subject<void>();\n\n  public readonly FilterState = EInputsState;\n  public readonly filterState$ = this._filterStateService.state$.pipe(\n    map((filterState) => filterState.state)\n  );\n  public readonly isOpen$ = this.filterState$.pipe(map((state) => state !== EInputsState.HIDDEN));\n  public readonly total$ = this._store.total$ ?? of(0);\n\n  private _currentFilters: ITpUserSettingsSettingsFilter[] = [];\n  private _previousState: IInputsState = {\n    state: EInputsState.HIDDEN,\n    action: EInputsAction.CANCEL,\n  };\n\n  constructor(\n    private readonly _store: RegisterBaseStore<Type>,\n    private readonly _filterStateService: FiltersStateService<Type>,\n    private readonly _filterListService: FiltersService<Type>\n  ) {}\n\n  public ngOnInit(): void {\n    combineLatest([this._filterStateService.state$, this._filterStateService.selectedSavedFilter])\n      .pipe(takeUntil(this._unsubscribe$))\n      .subscribe({\n        next: ([state, selected]) => {\n          if (state.state === EInputsState.SAVED_LIST) {\n            this.acceptButtonDisabled = !selected;\n            return;\n          }\n\n          if (state.state === EInputsState.ON_EDIT_FILTER) {\n            this.acceptButtonDisabled = false;\n            return;\n          }\n\n          if (state.state === EInputsState.ON_SAVE_FILTER) {\n            this.acceptButtonDisabled = false;\n            return;\n          }\n          this.acceptButtonDisabled = true;\n        },\n      });\n\n    if (this._filterStateService.isPin) {\n      this._filterStateService.setState({\n        state: EInputsState.FILTER_LIST,\n        action: EInputsAction.OPEN,\n      });\n    }\n  }\n\n  protected closeMenu(isPin: boolean): void {\n    if (isPin) {\n      this._menuState.setOpen(false);\n    }\n  }\n\n  public onApplyFilter(gqlFilter: GqlFields, savePage?: boolean): void {\n    if (!savePage) {\n      this._filterStateService.setOffset(0);\n      this._filterStateService.setPage(1);\n    }\n    this._filterStateService.setGqlValues(gqlFilter);\n    this.clickApplyButton.next();\n  }\n\n  public ngAfterViewInit(): void {\n    this._subscribeOnState();\n  }\n\n  private _subscribeOnState(): void {\n    combineLatest([this._filterStateService.state$, this._filterStateService.selectedSavedFilter])\n      .pipe(debounceTime(500), takeUntil(this._unsubscribe$))\n      .subscribe(([state, settings]) => {\n        this._setFilters(state, settings);\n      });\n  }\n\n  private _setFilters(state: IInputsState, settings: ITpUserSettings | null): void {\n    const { state: currentState, action: currentAction } = state;\n    const { state: previousState } = this._previousState;\n\n    switch (currentState) {\n      case EInputsState.ON_EDIT_FILTER:\n        if (previousState !== EInputsState.ON_EDIT_FILTER) {\n          this._filterListService.setUserSettingsFilterValues(settings?.settings?.filter ?? []);\n        }\n        break;\n      case EInputsState.SAVED_LIST:\n        if (\n          previousState !== EInputsState.SAVED_LIST &&\n          previousState !== EInputsState.ON_EDIT_FILTER &&\n          previousState !== EInputsState.ON_SAVE_FILTER\n        ) {\n          this._currentFilters = this._filterListService.userSettingsFilter;\n        }\n        break;\n      case EInputsState.FILTER_LIST:\n        if (previousState !== EInputsState.FILTER_LIST) {\n          if (currentAction === EInputsAction.CANCEL) {\n            this._filterListService.setUserSettingsFilterValues(this._currentFilters);\n          } else if (currentAction === EInputsAction.APPLY_SAVED_FILTER) {\n            this._currentFilters = settings?.settings?.filter ?? [];\n          }\n        }\n        break;\n      default:\n        console.warn('Состояние фильтра', currentState);\n        break;\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this._unsubscribe$.next();\n    this._unsubscribe$.complete();\n  }\n}\n","<sproc-sliding-panel [isOpen]=\"isOpen$ | async\" [subOffsetHeight]=\"subOffsetHeight\">\n  <sproc-filter-list-header\n    header\n    [showTotal]=\"showTotal\"\n    [showPin]=\"showPin\"\n    [showCloseButton]=\"showCloseButton\"\n    [total]=\"total$ | async\"\n    [acceptButtonDisabled]=\"acceptButtonDisabled\"\n    [applyButtonDisabled]=\"applyButtonDisabled\"\n    [filterListHeaderTitle]=\"filterListHeaderTitle\"\n    (pinnedChange)=\"closeMenu($event)\"\n    (applyFilter)=\"onApplyFilter($event)\"\n  ></sproc-filter-list-header>\n\n  <ng-container [ngSwitch]=\"filterState$ | async\">\n    <ng-container *ngSwitchCase=\"FilterState.FILTER_LIST\" [ngTemplateOutlet]=\"filtersTemplate\">\n    </ng-container>\n\n    <div *ngSwitchCase=\"FilterState.SAVED_LIST\">\n      <sproc-filter-list-saved></sproc-filter-list-saved>\n    </div>\n\n    <div *ngSwitchCase=\"FilterState.ON_EDIT_FILTER\">\n      <sproc-filter-edit></sproc-filter-edit>\n\n      <sproc-divider></sproc-divider>\n\n      <ng-container [ngTemplateOutlet]=\"filtersTemplate\"></ng-container>\n    </div>\n\n    <div *ngSwitchCase=\"FilterState.ON_SAVE_FILTER\">\n      <sproc-filter-edit></sproc-filter-edit>\n    </div>\n\n    <ng-template #filtersTemplate>\n      @defer (on viewport) {\n        <ng-content />\n      } @loading (minimum 1s) {\n        <tui-loader size=\"m\" class=\"loader\"></tui-loader>\n      } @placeholder {\n        <span>...</span>\n      }\n    </ng-template>\n  </ng-container>\n\n  <sproc-filter-list-footer\n    footer\n    [acceptButtonDisabled]=\"acceptButtonDisabled\"\n    [applyButtonDisabled]=\"applyButtonDisabled\"\n    (apply)=\"onApplyFilter($event)\"\n    [footerApplyButtonLabel]=\"footerApplyButtonLabel\"\n  ></sproc-filter-list-footer>\n</sproc-sliding-panel>\n"]}
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"register-table-filter.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-register-base/src/lib/components/filters/register-table-filter.component.ts","../../../../../../projects/ngx-register-base/src/lib/components/filters/register-table-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport { combineLatest, debounceTime, map, Subject, takeUntil, of } from 'rxjs';\nimport {\n  EInputsAction,\n  EInputsState,\n  GqlFields,\n  IInputsState,\n  ITpUserSettings,\n  ITpUserSettingsSettingsFilter,\n} from '../../types';\nimport { FiltersService, FiltersStateService } from '../../services';\nimport { RegisterBaseStore } from '../../core';\nimport { PAGE_MENU_STATE } from '../page-menu';\n\n@Component({\n  selector: 'sproc-register-table-filter',\n  templateUrl: './register-table-filter.component.html',\n  styleUrls: ['./register-table-filter.component.less'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class RegisterTableFilterComponent<Type extends Record<string, any>>\n  implements OnInit, AfterViewInit, OnDestroy\n{\n  /** Высота всего компонента фильтров */\n  @Input() height: string | undefined;\n  @Input() showTotal = true;\n  @Input() showPin = true;\n  @Input() showCloseButton = true;\n  @Input() acceptButtonDisabled = false;\n  @Input() applyButtonDisabled = false;\n  /** Доп. отступ для вычисления высоты панели (в пикселях) */\n  @Input() subOffsetHeight = 0;\n  @Input() filterListHeaderTitle = 'Фильтр';\n  @Input() footerApplyButtonLabel = 'Применить';\n\n  @Output() clickApplyButton = new EventEmitter<void>();\n\n  private readonly _menuState = inject(PAGE_MENU_STATE);\n\n  private readonly _unsubscribe$: Subject<void> = new Subject<void>();\n\n  public readonly FilterState = EInputsState;\n  public readonly filterState$ = this._filterStateService.state$.pipe(\n    map((filterState) => filterState.state)\n  );\n  public readonly isOpen$ = this.filterState$.pipe(map((state) => state !== EInputsState.HIDDEN));\n  public readonly total$ = this._store.total$ ?? of(0);\n\n  private _currentFilters: ITpUserSettingsSettingsFilter[] = [];\n  private _previousState: IInputsState = {\n    state: EInputsState.HIDDEN,\n    action: EInputsAction.CANCEL,\n  };\n\n  constructor(\n    private readonly _store: RegisterBaseStore<Type>,\n    private readonly _filterStateService: FiltersStateService<Type>,\n    private readonly _filterListService: FiltersService<Type>\n  ) {}\n\n  public ngOnInit(): void {\n    combineLatest([this._filterStateService.state$, this._filterStateService.selectedSavedFilter])\n      .pipe(takeUntil(this._unsubscribe$))\n      .subscribe({\n        next: ([state, selected]) => {\n          if (state.state === EInputsState.SAVED_LIST) {\n            this.acceptButtonDisabled = !selected;\n            return;\n          }\n\n          if (state.state === EInputsState.ON_EDIT_FILTER) {\n            this.acceptButtonDisabled = false;\n            return;\n          }\n\n          if (state.state === EInputsState.ON_SAVE_FILTER) {\n            this.acceptButtonDisabled = false;\n            return;\n          }\n          this.acceptButtonDisabled = true;\n        },\n      });\n\n    if (this._filterStateService.isPin) {\n      this._filterStateService.setState({\n        state: EInputsState.FILTER_LIST,\n        action: EInputsAction.OPEN,\n      });\n    }\n  }\n\n  protected closeMenu(isPin: boolean): void {\n    if (isPin) {\n      this._menuState.setOpen(false);\n    }\n  }\n\n  public onApplyFilter(gqlFilter: GqlFields, savePage?: boolean): void {\n    if (!savePage) {\n      this._filterStateService.setOffset(0);\n      this._filterStateService.setPage(1);\n    }\n    this._filterStateService.setGqlValues(gqlFilter);\n    this.clickApplyButton.next();\n  }\n\n  public ngAfterViewInit(): void {\n    this._subscribeOnState();\n  }\n\n  private _subscribeOnState(): void {\n    combineLatest([this._filterStateService.state$, this._filterStateService.selectedSavedFilter])\n      .pipe(debounceTime(500), takeUntil(this._unsubscribe$))\n      .subscribe(([state, settings]) => {\n        this._setFilters(state, settings);\n      });\n  }\n\n  private _setFilters(state: IInputsState, settings: ITpUserSettings | null): void {\n    const { state: currentState, action: currentAction } = state;\n    const { state: previousState } = this._previousState;\n\n    switch (currentState) {\n      case EInputsState.ON_EDIT_FILTER:\n        if (previousState !== EInputsState.ON_EDIT_FILTER) {\n          this._filterListService.setUserSettingsFilterValues(settings?.settings?.filter ?? []);\n        }\n        break;\n      case EInputsState.SAVED_LIST:\n        if (\n          previousState !== EInputsState.SAVED_LIST &&\n          previousState !== EInputsState.ON_EDIT_FILTER &&\n          previousState !== EInputsState.ON_SAVE_FILTER\n        ) {\n          this._currentFilters = this._filterListService.userSettingsFilter;\n        }\n        break;\n      case EInputsState.FILTER_LIST:\n        if (previousState !== EInputsState.FILTER_LIST) {\n          if (currentAction === EInputsAction.CANCEL) {\n            this._filterListService.setUserSettingsFilterValues(this._currentFilters);\n          } else if (currentAction === EInputsAction.APPLY_SAVED_FILTER) {\n            this._currentFilters = settings?.settings?.filter ?? [];\n          }\n        }\n        break;\n      default:\n        console.warn('Состояние фильтра', currentState);\n        break;\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this._unsubscribe$.next();\n    this._unsubscribe$.complete();\n  }\n}\n","<sproc-sliding-panel [isOpen]=\"isOpen$ | async\" [subOffsetHeight]=\"subOffsetHeight\">\n  <sproc-filter-list-header\n    header\n    [showTotal]=\"showTotal\"\n    [showPin]=\"showPin\"\n    [showCloseButton]=\"showCloseButton\"\n    [total]=\"total$ | async\"\n    [acceptButtonDisabled]=\"acceptButtonDisabled\"\n    [applyButtonDisabled]=\"applyButtonDisabled\"\n    [filterListHeaderTitle]=\"filterListHeaderTitle\"\n    (pinnedChange)=\"closeMenu($event)\"\n    (applyFilter)=\"onApplyFilter($event)\"\n  ></sproc-filter-list-header>\n\n  <ng-container [ngSwitch]=\"filterState$ | async\">\n    <ng-container *ngSwitchCase=\"FilterState.FILTER_LIST\" [ngTemplateOutlet]=\"filtersTemplate\">\n    </ng-container>\n\n    <div *ngSwitchCase=\"FilterState.SAVED_LIST\">\n      <sproc-filter-list-saved></sproc-filter-list-saved>\n    </div>\n\n    <div *ngSwitchCase=\"FilterState.ON_EDIT_FILTER\">\n      <sproc-filter-edit></sproc-filter-edit>\n\n      <sproc-divider></sproc-divider>\n\n      <ng-container [ngTemplateOutlet]=\"filtersTemplate\"></ng-container>\n    </div>\n\n    <div *ngSwitchCase=\"FilterState.ON_SAVE_FILTER\">\n      <sproc-filter-edit></sproc-filter-edit>\n    </div>\n\n    <ng-template #filtersTemplate>\n      @defer (on viewport) {\n        <ng-content />\n      } @loading (minimum 1s) {\n        <tui-loader size=\"m\" class=\"loader\"></tui-loader>\n      } @placeholder {\n        <span>...</span>\n      }\n    </ng-template>\n  </ng-container>\n\n  <sproc-filter-list-footer\n    footer\n    [acceptButtonDisabled]=\"acceptButtonDisabled\"\n    [applyButtonDisabled]=\"applyButtonDisabled\"\n    (apply)=\"onApplyFilter($event)\"\n    [footerApplyButtonLabel]=\"footerApplyButtonLabel\"\n  ></sproc-filter-list-footer>\n</sproc-sliding-panel>\n"]}