@myrtex-org/form 1.0.41 → 1.0.42

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.
@@ -20,6 +20,7 @@ export class InputFileComponent extends BaseFieldComponent {
20
20
  this._changeFileSubject$ = new Subject();
21
21
  this._fileSubscriptions$ = [];
22
22
  this._isFileCheckRequired = false;
23
+ this._isFileCanEditObject = false;
23
24
  this.applicationId$ = this._store.select(objectFormSelectors.selectObjectId);
24
25
  this.files = [];
25
26
  }
@@ -33,6 +34,11 @@ export class InputFileComponent extends BaseFieldComponent {
33
34
  this._isFileCheckRequired = result;
34
35
  this._detector.detectChanges();
35
36
  }));
37
+ this._subscriptions$.push(this._store.select(objectFormSelectors.selectCanEditObject)
38
+ .subscribe(result => {
39
+ this._isFileCanEditObject = result;
40
+ this._detector.detectChanges();
41
+ }));
36
42
  if (this.valueMode === 'auto') {
37
43
  this._subscriptions$.push(this._store.select(objectFormSelectors.selectValueModel(this.settings))
38
44
  .subscribe((result) => {
@@ -60,6 +66,9 @@ export class InputFileComponent extends BaseFieldComponent {
60
66
  return false;
61
67
  }
62
68
  }
69
+ get disabled() {
70
+ return !this.settings.options.canEdit || !this._isFileCanEditObject;
71
+ }
63
72
  ngOnDestroy() {
64
73
  this._fileSubscriptions$.forEach((subscription) => subscription.unsubscribe());
65
74
  }
@@ -87,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
87
96
  type: Component,
88
97
  args: [{ selector: 'app-input-file', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (settings) {\r\n <div class=\"input-file-content\">\r\n @if (settings.options.label) {\r\n <mrx-label\r\n [required]=\"settings.options.required\"\r\n [tooltip]=\"settings.options.tooltip || ''\"\r\n >\r\n {{ settings.options.label }}\r\n </mrx-label>\r\n }\r\n\r\n <mrx-input-file\r\n [files]=\"files\"\r\n [allowedExtensions]=\"settings.options.allowedExtensions\"\r\n [maxFiles]=\"!!settings.options.maxFiles ? settings.options.maxFiles : 9999\"\r\n [minFiles]=\"1\"\r\n [maxSize]=\"!!settings.options.maxSize ? settings.options.maxSize : 52428800\"\r\n [uploadEndPoint]=\"apiUrl + '/' + (applicationId$ | async) + '/upload-temp-file'\"\r\n [deleteConfirm]=\"deleteFile.bind(this)\"\r\n [disabled]=\"disabled\"\r\n [invalid]=\"getInvalid\"\r\n [invalidMessage]=\"'\u041F\u043E\u043B\u0435 \u043E\u0431\u044F\u0437\u0430\u0442\u0435\u043B\u044C\u043D\u043E \u0434\u043B\u044F \u0437\u0430\u043F\u043E\u043B\u043D\u0435\u043D\u0438\u044F'\"\r\n (filesChanged)=\"filesChanged($event)\"\r\n ></mrx-input-file>\r\n\r\n @if(!!settings.options.maxFiles) {\r\n <mrx-hint-error-message\r\n message=\"\u041C\u0430\u043A\u0441\u0438\u043C\u0430\u043B\u044C\u043D\u043E\u0435 \u043A\u043E\u043B\u0438\u0447\u0435\u0441\u0442\u0432\u043E \u0444\u0430\u0439\u043B\u043E\u0432 \u2014 {{ settings.options.maxFiles }}\"\r\n [maxValue]=\"settings.options.maxFiles\"\r\n ></mrx-hint-error-message>\r\n }\r\n </div>\r\n}\r\n" }]
89
98
  }] });
90
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-file.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/file/input-file.component.ts","../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/file/input-file.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, inject, OnDestroy, OnInit } from '@angular/core';\r\nimport { ComponentType } from '../../../../../shared-form/enums';\r\nimport { FileModel } from '../../../../../shared-form/models';\r\nimport { Store } from '@ngrx/store';\r\nimport { cloneDeep } from 'lodash-es';\r\nimport { Observable, Subject, Subscription } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { BaseFieldComponent } from '../../base';\r\nimport { ComponentValueModel } from '../../../../models';\r\nimport { objectFormActions, objectFormSelectors } from '../../../../store';\r\nimport { InputFileModel } from '@myrtex-org/ui';\r\nimport { InputFileModel as InputFileBaseModel } from '../../../../models/elemets/inputs';\r\nimport { ObjectFormService } from '../../../../services';\r\n\r\n@Component({\r\n  selector: 'app-input-file',\r\n  templateUrl: './input-file.component.html',\r\n  styleUrls: ['./input-file.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class InputFileComponent extends BaseFieldComponent<InputFileBaseModel, {\r\n  id: string,\r\n  value: InputFileModel[]\r\n}> implements OnInit, OnDestroy {\r\n  type = ComponentType.InputFile;\r\n\r\n  override _store: Store = inject(Store);\r\n  override _detector: ChangeDetectorRef = inject(ChangeDetectorRef);\r\n\r\n  private _objectFormService: ObjectFormService = inject(ObjectFormService)\r\n\r\n  private _changeFileSubject$: Subject<ComponentValueModel> = new Subject<ComponentValueModel>();\r\n  private _fileSubscriptions$: Subscription[] = [];\r\n\r\n  private _isFileCheckRequired: boolean = false;\r\n\r\n  public applicationId$: Observable<string> = this._store.select(objectFormSelectors.selectObjectId);\r\n\r\n  public files: any[] = [];\r\n\r\n  override ngOnInit(): void {\r\n    this._initModel();\r\n\r\n    this._changeFileSubject$.pipe(\r\n      debounceTime(700),\r\n    ).subscribe(model => {\r\n      this._store.dispatch(objectFormActions.updateValues({value: cloneDeep(this.model)}));\r\n    });\r\n\r\n    this._fileSubscriptions$.push(this._store.select(objectFormSelectors.selectIsCheckRequired)\r\n      .subscribe(result => {\r\n        this._isFileCheckRequired = result;\r\n        this._detector.detectChanges();\r\n      }));\r\n\r\n    if (this.valueMode === 'auto') {\r\n      this._subscriptions$.push(this._store.select(objectFormSelectors.selectValueModel(this.settings))\r\n        .subscribe((result: ComponentValueModel | null | (ComponentValueModel | null)[]) => {\r\n          if (result && !Array.isArray(result)) {\r\n            this.model.value = result.value;\r\n\r\n            this._customInit();\r\n          }\r\n        }));\r\n    }\r\n\r\n    this._fileSubscriptions$.push(\r\n      this._store.select(objectFormSelectors.selectSectionFiles)\r\n        .subscribe((sectionFiles: FileModel[]) => {\r\n          if (sectionFiles.length) {\r\n            this._initFiles(sectionFiles);\r\n          }\r\n        }),\r\n    );\r\n  }\r\n\r\n  public get apiUrl(): string {\r\n    return this._objectFormService.apiUrl\r\n  }\r\n\r\n  override get getInvalid(): boolean {\r\n    if (this._isFileCheckRequired) {\r\n      return this.settings.options.required && !this.model.value?.length;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  override ngOnDestroy(): void {\r\n    this._fileSubscriptions$.forEach((subscription) => subscription.unsubscribe());\r\n  }\r\n\r\n  public filesChanged(files: InputFileModel[]) {\r\n    this.files = files;\r\n    this.model.value = this.files.map(f => f.id);\r\n    this.dispatchModify();\r\n  }\r\n\r\n  public deleteFile(file: InputFileModel): void {\r\n    this.files = this.files.filter((f: InputFileModel) => f.id !== file.id);\r\n    this.model.value = this.files.map(f => f.id);\r\n    this.dispatchModify();\r\n  }\r\n\r\n  override dispatchModify() {\r\n    this._changeFileSubject$.next(this.model);\r\n  }\r\n\r\n  private _initFiles(sectionFiles: FileModel[]) {\r\n    this.files = sectionFiles.filter(f => this.model.value.includes(f.id)).map(f => (\r\n      {uuid: f.id, name: f.name, size: f.length}\r\n    ));\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n}\r\n","@if (settings) {\r\n  <div class=\"input-file-content\">\r\n    @if (settings.options.label) {\r\n      <mrx-label\r\n        [required]=\"settings.options.required\"\r\n        [tooltip]=\"settings.options.tooltip || ''\"\r\n      >\r\n        {{ settings.options.label }}\r\n      </mrx-label>\r\n    }\r\n\r\n    <mrx-input-file\r\n      [files]=\"files\"\r\n      [allowedExtensions]=\"settings.options.allowedExtensions\"\r\n      [maxFiles]=\"!!settings.options.maxFiles ? settings.options.maxFiles : 9999\"\r\n      [minFiles]=\"1\"\r\n      [maxSize]=\"!!settings.options.maxSize ? settings.options.maxSize : 52428800\"\r\n      [uploadEndPoint]=\"apiUrl + '/' + (applicationId$ | async) + '/upload-temp-file'\"\r\n      [deleteConfirm]=\"deleteFile.bind(this)\"\r\n      [disabled]=\"disabled\"\r\n      [invalid]=\"getInvalid\"\r\n      [invalidMessage]=\"'Поле обязательно для заполнения'\"\r\n      (filesChanged)=\"filesChanged($event)\"\r\n    ></mrx-input-file>\r\n\r\n    @if(!!settings.options.maxFiles) {\r\n      <mrx-hint-error-message\r\n        message=\"Максимальное количество файлов — {{ settings.options.maxFiles }}\"\r\n        [maxValue]=\"settings.options.maxFiles\"\r\n      ></mrx-hint-error-message>\r\n    }\r\n  </div>\r\n}\r\n"]}
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-file.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/file/input-file.component.ts","../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/file/input-file.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, inject, OnDestroy, OnInit } from '@angular/core';\r\nimport { ComponentType } from '../../../../../shared-form/enums';\r\nimport { FileModel } from '../../../../../shared-form/models';\r\nimport { Store } from '@ngrx/store';\r\nimport { cloneDeep } from 'lodash-es';\r\nimport { Observable, Subject, Subscription } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { BaseFieldComponent } from '../../base';\r\nimport { ComponentValueModel } from '../../../../models';\r\nimport { objectFormActions, objectFormSelectors } from '../../../../store';\r\nimport { InputFileModel } from '@myrtex-org/ui';\r\nimport { InputFileModel as InputFileBaseModel } from '../../../../models/elemets/inputs';\r\nimport { ObjectFormService } from '../../../../services';\r\n\r\n@Component({\r\n  selector: 'app-input-file',\r\n  templateUrl: './input-file.component.html',\r\n  styleUrls: ['./input-file.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class InputFileComponent extends BaseFieldComponent<InputFileBaseModel, {\r\n  id: string,\r\n  value: InputFileModel[]\r\n}> implements OnInit, OnDestroy {\r\n  type = ComponentType.InputFile;\r\n\r\n  override _store: Store = inject(Store);\r\n  override _detector: ChangeDetectorRef = inject(ChangeDetectorRef);\r\n\r\n  private _objectFormService: ObjectFormService = inject(ObjectFormService)\r\n\r\n  private _changeFileSubject$: Subject<ComponentValueModel> = new Subject<ComponentValueModel>();\r\n  private _fileSubscriptions$: Subscription[] = [];\r\n\r\n  private _isFileCheckRequired: boolean = false;\r\n  private _isFileCanEditObject: boolean = false;\r\n\r\n  public applicationId$: Observable<string> = this._store.select(objectFormSelectors.selectObjectId);\r\n\r\n  public files: any[] = [];\r\n\r\n  override ngOnInit(): void {\r\n    this._initModel();\r\n\r\n    this._changeFileSubject$.pipe(\r\n      debounceTime(700),\r\n    ).subscribe(model => {\r\n      this._store.dispatch(objectFormActions.updateValues({value: cloneDeep(this.model)}));\r\n    });\r\n\r\n    this._fileSubscriptions$.push(this._store.select(objectFormSelectors.selectIsCheckRequired)\r\n      .subscribe(result => {\r\n        this._isFileCheckRequired = result;\r\n        this._detector.detectChanges();\r\n      }));\r\n\r\n    this._subscriptions$.push(this._store.select(objectFormSelectors.selectCanEditObject)\r\n      .subscribe(result => {\r\n        this._isFileCanEditObject = result;\r\n        this._detector.detectChanges();\r\n      }));\r\n\r\n    if (this.valueMode === 'auto') {\r\n      this._subscriptions$.push(this._store.select(objectFormSelectors.selectValueModel(this.settings))\r\n        .subscribe((result: ComponentValueModel | null | (ComponentValueModel | null)[]) => {\r\n          if (result && !Array.isArray(result)) {\r\n            this.model.value = result.value;\r\n\r\n            this._customInit();\r\n          }\r\n        }));\r\n    }\r\n\r\n    this._fileSubscriptions$.push(\r\n      this._store.select(objectFormSelectors.selectSectionFiles)\r\n        .subscribe((sectionFiles: FileModel[]) => {\r\n          if (sectionFiles.length) {\r\n            this._initFiles(sectionFiles);\r\n          }\r\n        }),\r\n    );\r\n  }\r\n\r\n  public get apiUrl(): string {\r\n    return this._objectFormService.apiUrl\r\n  }\r\n\r\n  override get getInvalid(): boolean {\r\n    if (this._isFileCheckRequired) {\r\n      return this.settings.options.required && !this.model.value?.length;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  override get disabled(): boolean {\r\n    return !this.settings.options.canEdit || !this._isFileCanEditObject;\r\n  }\r\n\r\n  override ngOnDestroy(): void {\r\n    this._fileSubscriptions$.forEach((subscription) => subscription.unsubscribe());\r\n  }\r\n\r\n  public filesChanged(files: InputFileModel[]) {\r\n    this.files = files;\r\n    this.model.value = this.files.map(f => f.id);\r\n    this.dispatchModify();\r\n  }\r\n\r\n  public deleteFile(file: InputFileModel): void {\r\n    this.files = this.files.filter((f: InputFileModel) => f.id !== file.id);\r\n    this.model.value = this.files.map(f => f.id);\r\n    this.dispatchModify();\r\n  }\r\n\r\n  override dispatchModify() {\r\n    this._changeFileSubject$.next(this.model);\r\n  }\r\n\r\n  private _initFiles(sectionFiles: FileModel[]) {\r\n    this.files = sectionFiles.filter(f => this.model.value.includes(f.id)).map(f => (\r\n      {uuid: f.id, name: f.name, size: f.length}\r\n    ));\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n}\r\n","@if (settings) {\r\n  <div class=\"input-file-content\">\r\n    @if (settings.options.label) {\r\n      <mrx-label\r\n        [required]=\"settings.options.required\"\r\n        [tooltip]=\"settings.options.tooltip || ''\"\r\n      >\r\n        {{ settings.options.label }}\r\n      </mrx-label>\r\n    }\r\n\r\n    <mrx-input-file\r\n      [files]=\"files\"\r\n      [allowedExtensions]=\"settings.options.allowedExtensions\"\r\n      [maxFiles]=\"!!settings.options.maxFiles ? settings.options.maxFiles : 9999\"\r\n      [minFiles]=\"1\"\r\n      [maxSize]=\"!!settings.options.maxSize ? settings.options.maxSize : 52428800\"\r\n      [uploadEndPoint]=\"apiUrl + '/' + (applicationId$ | async) + '/upload-temp-file'\"\r\n      [deleteConfirm]=\"deleteFile.bind(this)\"\r\n      [disabled]=\"disabled\"\r\n      [invalid]=\"getInvalid\"\r\n      [invalidMessage]=\"'Поле обязательно для заполнения'\"\r\n      (filesChanged)=\"filesChanged($event)\"\r\n    ></mrx-input-file>\r\n\r\n    @if(!!settings.options.maxFiles) {\r\n      <mrx-hint-error-message\r\n        message=\"Максимальное количество файлов — {{ settings.options.maxFiles }}\"\r\n        [maxValue]=\"settings.options.maxFiles\"\r\n      ></mrx-hint-error-message>\r\n    }\r\n  </div>\r\n}\r\n"]}
@@ -1600,6 +1600,7 @@ class InputFileComponent extends BaseFieldComponent {
1600
1600
  this._changeFileSubject$ = new Subject();
1601
1601
  this._fileSubscriptions$ = [];
1602
1602
  this._isFileCheckRequired = false;
1603
+ this._isFileCanEditObject = false;
1603
1604
  this.applicationId$ = this._store.select(selectObjectId);
1604
1605
  this.files = [];
1605
1606
  }
@@ -1613,6 +1614,11 @@ class InputFileComponent extends BaseFieldComponent {
1613
1614
  this._isFileCheckRequired = result;
1614
1615
  this._detector.detectChanges();
1615
1616
  }));
1617
+ this._subscriptions$.push(this._store.select(selectCanEditObject)
1618
+ .subscribe(result => {
1619
+ this._isFileCanEditObject = result;
1620
+ this._detector.detectChanges();
1621
+ }));
1616
1622
  if (this.valueMode === 'auto') {
1617
1623
  this._subscriptions$.push(this._store.select(selectValueModel(this.settings))
1618
1624
  .subscribe((result) => {
@@ -1640,6 +1646,9 @@ class InputFileComponent extends BaseFieldComponent {
1640
1646
  return false;
1641
1647
  }
1642
1648
  }
1649
+ get disabled() {
1650
+ return !this.settings.options.canEdit || !this._isFileCanEditObject;
1651
+ }
1643
1652
  ngOnDestroy() {
1644
1653
  this._fileSubscriptions$.forEach((subscription) => subscription.unsubscribe());
1645
1654
  }