@myrtex-org/form 1.0.18 → 1.0.20

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.
Files changed (23) hide show
  1. package/esm2022/lib/modules/object-form/components/elements/base/base-field/base-field.component.mjs +15 -2
  2. package/esm2022/lib/modules/object-form/components/elements/input/number/input-number.component.mjs +13 -3
  3. package/esm2022/lib/modules/object-form/components/elements/input/table/input-table.component.mjs +38 -8
  4. package/esm2022/lib/modules/object-form/components/elements/input/text/input-text.component.mjs +12 -3
  5. package/esm2022/lib/modules/object-form/components/elements/input/textarea/input-textarea.component.mjs +12 -3
  6. package/esm2022/lib/modules/object-form/components/object-form-content/object-form-content.component.mjs +2 -9
  7. package/esm2022/lib/modules/object-form/models/elemets/inputs/input-table.model.mjs +1 -1
  8. package/esm2022/lib/modules/object-form/models/elemets/inputs/input-textarea.model.mjs +1 -1
  9. package/esm2022/lib/modules/object-form/object-form.module.mjs +8 -5
  10. package/esm2022/lib/modules/object-form/store/object-form.reducers.mjs +1 -2
  11. package/fesm2022/myrtex-org-form.mjs +90 -25
  12. package/fesm2022/myrtex-org-form.mjs.map +1 -1
  13. package/lib/modules/object-form/components/elements/base/base-field/base-field.component.d.ts +2 -0
  14. package/lib/modules/object-form/components/elements/input/number/input-number.component.d.ts +4 -0
  15. package/lib/modules/object-form/components/elements/input/table/input-table.component.d.ts +1 -1
  16. package/lib/modules/object-form/components/elements/input/text/input-text.component.d.ts +4 -0
  17. package/lib/modules/object-form/components/elements/input/textarea/input-textarea.component.d.ts +4 -0
  18. package/lib/modules/object-form/components/object-form-content/object-form-content.component.d.ts +1 -4
  19. package/lib/modules/object-form/models/elemets/inputs/input-table.model.d.ts +1 -0
  20. package/lib/modules/object-form/models/elemets/inputs/input-textarea.model.d.ts +2 -2
  21. package/lib/modules/object-form/object-form.module.d.ts +1 -1
  22. package/lib/modules/object-form/store/object-form.effects.d.ts +3 -3
  23. package/package.json +1 -1
@@ -1,16 +1,19 @@
1
1
  import { ChangeDetectorRef, EventEmitter, inject, Injectable, Input, Output } from '@angular/core';
2
+ import { Subject } from 'rxjs';
2
3
  import { Store } from '@ngrx/store';
3
4
  import { cloneDeep } from 'lodash-es';
4
5
  import { ValueType } from '../../../../../shared-form/enums';
5
6
  import { AutoSaveStore } from '@myrtex-org/ui';
6
7
  import { defaultValueModel, getValueModel } from '../../../../helpers';
7
8
  import { objectFormSelectors } from '../../../../store';
9
+ import { debounceTime } from 'rxjs/operators';
8
10
  import * as i0 from "@angular/core";
9
11
  export class BaseFieldComponent {
10
12
  constructor() {
11
13
  this._store = inject(Store);
12
14
  this._detector = inject(ChangeDetectorRef);
13
15
  this._subscriptions$ = [];
16
+ this._changeSubject$ = new Subject();
14
17
  this._autoSaveStore = inject(AutoSaveStore);
15
18
  this._isCheckRequired = false;
16
19
  this.manualValues = [];
@@ -29,6 +32,13 @@ export class BaseFieldComponent {
29
32
  }
30
33
  ngOnInit() {
31
34
  this._initModel();
35
+ this._changeSubject$
36
+ .pipe(debounceTime(500))
37
+ .subscribe(model => {
38
+ if (this._customValidate(this.model)) {
39
+ this.changed.emit(this._transformOutputValue());
40
+ }
41
+ });
32
42
  this._subscriptions$.push(this._store.select(objectFormSelectors.selectIsCheckRequired)
33
43
  .subscribe(result => {
34
44
  this._isCheckRequired = result;
@@ -88,7 +98,7 @@ export class BaseFieldComponent {
88
98
  }));
89
99
  }
90
100
  _updateValue() {
91
- this.changed.emit(this._transformOutputValue());
101
+ this._changeSubject$.next(this._transformOutputValue());
92
102
  }
93
103
  _transformOutputValue() {
94
104
  return cloneDeep(this.model);
@@ -98,6 +108,9 @@ export class BaseFieldComponent {
98
108
  _customInit() {
99
109
  this.model = this.model || defaultValueModel(this.settings);
100
110
  }
111
+ _customValidate(model) {
112
+ return true;
113
+ }
101
114
  _initModel() {
102
115
  if (this.valueMode === 'manual') {
103
116
  this.model = cloneDeep(getValueModel(this.settings, this.manualValues)) || defaultValueModel(this.settings);
@@ -125,4 +138,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
125
138
  }], changed: [{
126
139
  type: Output
127
140
  }] } });
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-field.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/base/base-field/base-field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, EventEmitter, inject, Injectable, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { Store } from '@ngrx/store';\r\nimport { cloneDeep } from 'lodash-es';\r\nimport { ValueType } from '../../../../../shared-form/enums';\r\nimport { ComponentModelBase } from '../../../../../shared-form/models';\r\nimport { AutoSaveStore, Field } from '@myrtex-org/ui';\r\nimport { ComponentValueModel, ValueModel } from '../../../../models';\r\nimport { defaultValueModel, getValueModel } from '../../../../helpers';\r\nimport { objectFormSelectors } from '../../../../store';\r\n\r\n@Injectable()\r\nexport abstract class BaseFieldComponent<TModel extends ComponentModelBase, TOutputEvent extends {\r\n  id: string,\r\n  value: any\r\n}> implements OnInit, OnDestroy {\r\n  protected _store: Store = inject(Store)\r\n  protected _detector: ChangeDetectorRef = inject(ChangeDetectorRef)\r\n  protected _subscriptions$: Subscription[] = [];\r\n\r\n  private _autoSaveStore = inject(AutoSaveStore)\r\n  private _isCheckRequired: boolean = false;\r\n\r\n  public model!: ComponentValueModel;\r\n  public settings!: TModel;\r\n  public manualValues: ValueModel[] = [];\r\n\r\n  @Input() set values(value: ValueModel[]) {\r\n    if (this.valueMode === 'manual') {\r\n      this.manualValues = value;\r\n    }\r\n  }\r\n\r\n  @Input() valueMode: 'auto' | 'manual' = 'auto';\r\n\r\n  @Input() set data(settings: ComponentModelBase) {\r\n    this.settings = settings as TModel;\r\n\r\n    this._customInit();\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  @Output() public changed = new EventEmitter<ComponentValueModel | ComponentValueModel[]>();\r\n\r\n  ngOnInit(): void {\r\n    this._initModel();\r\n\r\n    this._subscriptions$.push(this._store.select(objectFormSelectors.selectIsCheckRequired)\r\n      .subscribe(result => {\r\n        this._isCheckRequired = result;\r\n        this._detector.detectChanges();\r\n      }));\r\n\r\n    if (this.valueMode === 'auto') {\r\n      this._initSubscriptionForValue();\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._subscriptions$.forEach((subscription) => subscription.unsubscribe());\r\n  }\r\n\r\n  get autosaveFields(): Field[] {\r\n    return this._autoSaveStore.fields()\r\n  }\r\n\r\n  get getInvalid(): boolean {\r\n    if (this._isCheckRequired) {\r\n      return this.settings.options.required && !this._requiredValidate(this.model.valueType);\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  get getInvalidMessage(): string {\r\n    if (this._isCheckRequired) {\r\n      return 'Поле обязательно для заполнения';\r\n    } else {\r\n      return '';\r\n    }\r\n  }\r\n\r\n  private _requiredValidate(type: ValueType) {\r\n    switch (type) {\r\n      case (ValueType.String):\r\n      case (ValueType.DateTime):\r\n        return !!this.model.value?.trim();\r\n      case (ValueType.Decimal):\r\n        return !!this.model.value;\r\n      case (ValueType.Boolean):\r\n        return !!this.model.value;\r\n      case (ValueType.StringArray):\r\n      case (ValueType.GuidArray):\r\n        return !!this.model.value?.length;\r\n      default:\r\n        return true;\r\n    }\r\n  }\r\n\r\n  protected _initSubscriptionForValue() {\r\n    this._subscriptions$.push(this._store.select(objectFormSelectors.selectValueModel(this.settings))\r\n      .subscribe((result: ComponentValueModel | null | (ComponentValueModel | null)[]) => {\r\n        if (result) {\r\n          if (!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\r\n  protected _updateValue() {\r\n    this.changed.emit(this._transformOutputValue());\r\n  }\r\n\r\n  protected _transformOutputValue(): ComponentValueModel | ComponentValueModel[] {\r\n    return cloneDeep(this.model);\r\n  }\r\n\r\n  protected _customModelModify(event: TOutputEvent) {\r\n  }\r\n\r\n  protected _customInit() {\r\n    this.model = this.model || defaultValueModel(this.settings);\r\n  }\r\n\r\n  protected _initModel() {\r\n    if (this.valueMode === 'manual') {\r\n      this.model = cloneDeep(getValueModel(this.settings, this.manualValues) as ComponentValueModel) || defaultValueModel(this.settings);\r\n    } else {\r\n      this.model = defaultValueModel(this.settings);\r\n    }\r\n  }\r\n\r\n  dispatchModify(event: TOutputEvent) {\r\n    this._autoSaveStore.addId(event.id)\r\n\r\n    this._customModelModify(event);\r\n\r\n    setTimeout(() =>  this._updateValue())\r\n  }\r\n}\r\n"]}
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-field.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/base/base-field/base-field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, EventEmitter, inject, Injectable, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { Store } from '@ngrx/store';\r\nimport { cloneDeep } from 'lodash-es';\r\nimport { ValueType } from '../../../../../shared-form/enums';\r\nimport { ComponentModelBase } from '../../../../../shared-form/models';\r\nimport { AutoSaveStore, Field } from '@myrtex-org/ui';\r\nimport { ComponentValueModel, ValueModel } from '../../../../models';\r\nimport { defaultValueModel, getValueModel } from '../../../../helpers';\r\nimport { objectFormActions, objectFormSelectors } from '../../../../store';\r\nimport { debounceTime } from 'rxjs/operators';\r\n\r\n@Injectable()\r\nexport abstract class BaseFieldComponent<TModel extends ComponentModelBase, TOutputEvent extends {\r\n  id: string,\r\n  value: any\r\n}> implements OnInit, OnDestroy {\r\n  protected _store: Store = inject(Store);\r\n  protected _detector: ChangeDetectorRef = inject(ChangeDetectorRef);\r\n  protected _subscriptions$: Subscription[] = [];\r\n  private _changeSubject$: Subject<ComponentValueModel | ComponentValueModel[]> = new Subject<ComponentValueModel | ComponentValueModel[]>();\r\n\r\n  private _autoSaveStore = inject(AutoSaveStore);\r\n  private _isCheckRequired: boolean = false;\r\n\r\n  public model!: ComponentValueModel;\r\n  public settings!: TModel;\r\n  public manualValues: ValueModel[] = [];\r\n\r\n  @Input() set values(value: ValueModel[]) {\r\n    if (this.valueMode === 'manual') {\r\n      this.manualValues = value;\r\n    }\r\n  }\r\n\r\n  @Input() valueMode: 'auto' | 'manual' = 'auto';\r\n\r\n  @Input() set data(settings: ComponentModelBase) {\r\n    this.settings = settings as TModel;\r\n\r\n    this._customInit();\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  @Output() public changed = new EventEmitter<ComponentValueModel | ComponentValueModel[]>();\r\n\r\n  ngOnInit(): void {\r\n    this._initModel();\r\n\r\n    this._changeSubject$\r\n      .pipe(debounceTime(500))\r\n      .subscribe(model => {\r\n        if (this._customValidate(this.model)) {\r\n          this.changed.emit(this._transformOutputValue());\r\n        }\r\n      });\r\n\r\n    this._subscriptions$.push(this._store.select(objectFormSelectors.selectIsCheckRequired)\r\n      .subscribe(result => {\r\n        this._isCheckRequired = result;\r\n        this._detector.detectChanges();\r\n      }));\r\n\r\n    if (this.valueMode === 'auto') {\r\n      this._initSubscriptionForValue();\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._subscriptions$.forEach((subscription) => subscription.unsubscribe());\r\n  }\r\n\r\n  get autosaveFields(): Field[] {\r\n    return this._autoSaveStore.fields();\r\n  }\r\n\r\n  get getInvalid(): boolean {\r\n    if (this._isCheckRequired) {\r\n      return this.settings.options.required && !this._requiredValidate(this.model.valueType);\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  get getInvalidMessage(): string {\r\n    if (this._isCheckRequired) {\r\n      return 'Поле обязательно для заполнения';\r\n    } else {\r\n      return '';\r\n    }\r\n  }\r\n\r\n  private _requiredValidate(type: ValueType) {\r\n    switch (type) {\r\n      case (ValueType.String):\r\n      case (ValueType.DateTime):\r\n        return !!this.model.value?.trim();\r\n      case (ValueType.Decimal):\r\n        return !!this.model.value;\r\n      case (ValueType.Boolean):\r\n        return !!this.model.value;\r\n      case (ValueType.StringArray):\r\n      case (ValueType.GuidArray):\r\n        return !!this.model.value?.length;\r\n      default:\r\n        return true;\r\n    }\r\n  }\r\n\r\n  protected _initSubscriptionForValue() {\r\n    this._subscriptions$.push(this._store.select(objectFormSelectors.selectValueModel(this.settings))\r\n      .subscribe((result: ComponentValueModel | null | (ComponentValueModel | null)[]) => {\r\n        if (result) {\r\n          if (!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\r\n  protected _updateValue() {\r\n    this._changeSubject$.next(this._transformOutputValue());\r\n  }\r\n\r\n  protected _transformOutputValue(): ComponentValueModel | ComponentValueModel[] {\r\n    return cloneDeep(this.model);\r\n  }\r\n\r\n  protected _customModelModify(event: TOutputEvent) {\r\n  }\r\n\r\n  protected _customInit() {\r\n    this.model = this.model || defaultValueModel(this.settings);\r\n  }\r\n\r\n  protected _customValidate(model: ComponentValueModel) {\r\n    return true;\r\n  }\r\n\r\n  protected _initModel() {\r\n    if (this.valueMode === 'manual') {\r\n      this.model = cloneDeep(getValueModel(this.settings, this.manualValues) as ComponentValueModel) || defaultValueModel(this.settings);\r\n    } else {\r\n      this.model = defaultValueModel(this.settings);\r\n    }\r\n  }\r\n\r\n  dispatchModify(event: TOutputEvent) {\r\n    this._autoSaveStore.addId(event.id);\r\n\r\n    this._customModelModify(event);\r\n\r\n    setTimeout(() => this._updateValue());\r\n\r\n  }\r\n}\r\n"]}
@@ -8,15 +8,25 @@ export class InputNumberComponent extends BaseFieldComponent {
8
8
  constructor() {
9
9
  super(...arguments);
10
10
  this.type = ComponentType.InputNumber;
11
+ this.validateValue = 0;
11
12
  }
12
13
  get isReadonly() {
13
14
  return this.settings.options.inputState === InputState.Formula;
14
15
  }
16
+ onChangeInput() {
17
+ this.validateValue = this.model.value;
18
+ }
19
+ _customValidate(model) {
20
+ this.validateValue = model.value;
21
+ this._detector.markForCheck();
22
+ return !(this.settings.options.minValue && model.value && this.settings.options.minValue > model.value ||
23
+ this.settings.options.maxValue && model.value && this.settings.options.maxValue < model.value);
24
+ }
15
25
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputNumberComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
16
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: InputNumberComponent, selector: "app-input-number", usesInheritance: true, ngImport: i0, template: "@if (settings) {\r\n <div class=\"input-number-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 [customClasses]=\"'mt-2'\"\r\n >\r\n {{ settings.options.label }}\r\n </mrx-label>\r\n }\r\n\r\n <mrx-input-number\r\n [(ngModel)]=\"model.value\"\r\n [fields]=\"autosaveFields\"\r\n [readonly]=\"isReadonly\"\r\n [placeholder]=\"settings.options.placeholder || ''\"\r\n [minValue]=\"settings.options.minValue || 0\"\r\n [maxValue]=\"settings.options.maxValue || 0\"\r\n [invalid]=\"getInvalid\"\r\n [invalidMessage]=\"getInvalidMessage\"\r\n (modelChange)=\"dispatchModify($event)\"\r\n ></mrx-input-number>\r\n </div>\r\n}\r\n", styles: [""], dependencies: [{ kind: "component", type: i1.LabelComponent, selector: "mrx-label", inputs: ["requiredHidden", "required", "boldLabel", "disabled", "placeholder", "label", "customClasses", "triggerTextPosition", "isPublicInfo", "publicInfoTooltip", "isSwitch", "switchLabel", "switchValue", "isCheckbox", "checkboxLabel", "checkboxValue", "counter", "linkText", "linkPrevent", "linkType", "linkMonochrome", "href", "triggerType", "tooltip", "tooltipInitialVisible", "isSaveToStorage"], outputs: ["changeSwitchValue", "changeCheckboxValue", "clickedLink"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i1.InputNumberComponent, selector: "mrx-input-number", inputs: ["fields", "placeholder", "innerClass", "customClasses", "required", "allowNegative", "size", "separator", "decimalSeparator", "decimals", "isNullableValue", "isAutoCorrectingValue", "invalid", "checkInvalid", "numberType", "invalidMessage", "disabled", "readonly", "minValue", "maxValue"], outputs: ["modelChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
26
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: InputNumberComponent, selector: "app-input-number", usesInheritance: true, ngImport: i0, template: "@if (settings) {\r\n <div class=\"input-number-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 [customClasses]=\"'mt-2'\"\r\n >\r\n {{ settings.options.label }}\r\n </mrx-label>\r\n }\r\n\r\n <mrx-input-number\r\n [(ngModel)]=\"model.value\"\r\n [fields]=\"autosaveFields\"\r\n [readonly]=\"isReadonly\"\r\n [placeholder]=\"settings.options.placeholder || ''\"\r\n [invalid]=\"getInvalid\"\r\n [invalidMessage]=\"getInvalidMessage\"\r\n (modelChange)=\"dispatchModify($event)\"\r\n (change)=\"onChangeInput()\"\r\n ></mrx-input-number>\r\n\r\n @if (settings.options.minValue) {\r\n <mrx-hint-error-message\r\n message=\"\u041C\u0438\u043D\u0438\u043C\u0430\u043B\u044C\u043D\u043E\u0435 \u0437\u043D\u0430\u0447\u0435\u043D\u0438\u0435 \u2014 {{ settings.options.minValue }}\"\r\n [value]=\"validateValue\"\r\n [minValue]=\"settings.options.minValue\"\r\n ></mrx-hint-error-message>\r\n }\r\n @if (settings.options.maxValue) {\r\n <mrx-hint-error-message\r\n message=\"\u041C\u0430\u043A\u0441\u0438\u043C\u0430\u043B\u044C\u043D\u043E\u0435 \u0437\u043D\u0430\u0447\u0435\u043D\u0438\u0435 \u2014 {{ settings.options.maxValue }}\"\r\n [value]=\"validateValue\"\r\n [maxValue]=\"settings.options.maxValue\"\r\n ></mrx-hint-error-message>\r\n }\r\n </div>\r\n}\r\n", styles: [""], dependencies: [{ kind: "component", type: i1.LabelComponent, selector: "mrx-label", inputs: ["requiredHidden", "required", "boldLabel", "disabled", "placeholder", "label", "customClasses", "triggerTextPosition", "isPublicInfo", "publicInfoTooltip", "isSwitch", "switchLabel", "switchValue", "isCheckbox", "checkboxLabel", "checkboxValue", "counter", "linkText", "linkPrevent", "linkType", "linkMonochrome", "href", "triggerType", "tooltip", "tooltipInitialVisible", "isSaveToStorage"], outputs: ["changeSwitchValue", "changeCheckboxValue", "clickedLink"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i1.InputNumberComponent, selector: "mrx-input-number", inputs: ["fields", "placeholder", "innerClass", "customClasses", "required", "allowNegative", "size", "separator", "decimalSeparator", "decimals", "isNullableValue", "isAutoCorrectingValue", "invalid", "checkInvalid", "numberType", "invalidMessage", "disabled", "readonly", "minValue", "maxValue"], outputs: ["modelChange"] }, { kind: "component", type: i1.HintErrorMessageComponent, selector: "mrx-hint-error-message", inputs: ["message", "value", "maxValue", "minValue", "minLength", "maxLength", "checkInvalid"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
17
27
  }
18
28
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputNumberComponent, decorators: [{
19
29
  type: Component,
20
- args: [{ selector: 'app-input-number', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (settings) {\r\n <div class=\"input-number-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 [customClasses]=\"'mt-2'\"\r\n >\r\n {{ settings.options.label }}\r\n </mrx-label>\r\n }\r\n\r\n <mrx-input-number\r\n [(ngModel)]=\"model.value\"\r\n [fields]=\"autosaveFields\"\r\n [readonly]=\"isReadonly\"\r\n [placeholder]=\"settings.options.placeholder || ''\"\r\n [minValue]=\"settings.options.minValue || 0\"\r\n [maxValue]=\"settings.options.maxValue || 0\"\r\n [invalid]=\"getInvalid\"\r\n [invalidMessage]=\"getInvalidMessage\"\r\n (modelChange)=\"dispatchModify($event)\"\r\n ></mrx-input-number>\r\n </div>\r\n}\r\n" }]
30
+ args: [{ selector: 'app-input-number', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (settings) {\r\n <div class=\"input-number-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 [customClasses]=\"'mt-2'\"\r\n >\r\n {{ settings.options.label }}\r\n </mrx-label>\r\n }\r\n\r\n <mrx-input-number\r\n [(ngModel)]=\"model.value\"\r\n [fields]=\"autosaveFields\"\r\n [readonly]=\"isReadonly\"\r\n [placeholder]=\"settings.options.placeholder || ''\"\r\n [invalid]=\"getInvalid\"\r\n [invalidMessage]=\"getInvalidMessage\"\r\n (modelChange)=\"dispatchModify($event)\"\r\n (change)=\"onChangeInput()\"\r\n ></mrx-input-number>\r\n\r\n @if (settings.options.minValue) {\r\n <mrx-hint-error-message\r\n message=\"\u041C\u0438\u043D\u0438\u043C\u0430\u043B\u044C\u043D\u043E\u0435 \u0437\u043D\u0430\u0447\u0435\u043D\u0438\u0435 \u2014 {{ settings.options.minValue }}\"\r\n [value]=\"validateValue\"\r\n [minValue]=\"settings.options.minValue\"\r\n ></mrx-hint-error-message>\r\n }\r\n @if (settings.options.maxValue) {\r\n <mrx-hint-error-message\r\n message=\"\u041C\u0430\u043A\u0441\u0438\u043C\u0430\u043B\u044C\u043D\u043E\u0435 \u0437\u043D\u0430\u0447\u0435\u043D\u0438\u0435 \u2014 {{ settings.options.maxValue }}\"\r\n [value]=\"validateValue\"\r\n [maxValue]=\"settings.options.maxValue\"\r\n ></mrx-hint-error-message>\r\n }\r\n </div>\r\n}\r\n" }]
21
31
  }] });
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtbnVtYmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRleC1mb3JtL3NyYy9saWIvbW9kdWxlcy9vYmplY3QtZm9ybS9jb21wb25lbnRzL2VsZW1lbnRzL2lucHV0L251bWJlci9pbnB1dC1udW1iZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGV4LWZvcm0vc3JjL2xpYi9tb2R1bGVzL29iamVjdC1mb3JtL2NvbXBvbmVudHMvZWxlbWVudHMvaW5wdXQvbnVtYmVyL2lucHV0LW51bWJlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQzNFLE9BQU8sRUFBRSxhQUFhLEVBQUUsVUFBVSxFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sWUFBWSxDQUFDOzs7O0FBVWhELE1BQU0sT0FBTyxvQkFBcUIsU0FBUSxrQkFBNEQ7SUFOdEc7O1FBT0UsU0FBSSxHQUFHLGFBQWEsQ0FBQyxXQUFXLENBQUM7S0FLbEM7SUFIQyxJQUFXLFVBQVU7UUFDbkIsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxVQUFVLEtBQUssVUFBVSxDQUFDLE9BQU8sQ0FBQztJQUNqRSxDQUFDOytHQUxVLG9CQUFvQjttR0FBcEIsb0JBQW9CLCtFQ1pqQyxxMEJBeUJBOzs0RkRiYSxvQkFBb0I7a0JBTmhDLFNBQVM7K0JBQ0Usa0JBQWtCLG1CQUdYLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tcG9uZW50VHlwZSwgSW5wdXRTdGF0ZSB9IGZyb20gJy4uLy4uLy4uLy4uLy4uL3NoYXJlZC1mb3JtL2VudW1zJztcclxuaW1wb3J0IHsgQmFzZUZpZWxkQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYmFzZSc7XHJcbmltcG9ydCB7IElucHV0TnVtYmVyTW9kZWwgfSBmcm9tICcuLi8uLi8uLi8uLi9tb2RlbHMvZWxlbWV0cy9pbnB1dHMnO1xyXG5pbXBvcnQgeyBJbnB1dE51bWJlclZhbHVlV2l0aElkIH0gZnJvbSAnQG15cnRleC1vcmcvdWknO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtaW5wdXQtbnVtYmVyJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vaW5wdXQtbnVtYmVyLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9pbnB1dC1udW1iZXIuY29tcG9uZW50Lmxlc3MnXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgSW5wdXROdW1iZXJDb21wb25lbnQgZXh0ZW5kcyBCYXNlRmllbGRDb21wb25lbnQ8SW5wdXROdW1iZXJNb2RlbCwgSW5wdXROdW1iZXJWYWx1ZVdpdGhJZD4gaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIHR5cGUgPSBDb21wb25lbnRUeXBlLklucHV0TnVtYmVyO1xyXG5cclxuICBwdWJsaWMgZ2V0IGlzUmVhZG9ubHkoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5zZXR0aW5ncy5vcHRpb25zLmlucHV0U3RhdGUgPT09IElucHV0U3RhdGUuRm9ybXVsYTtcclxuICB9XHJcbn1cclxuIiwiQGlmIChzZXR0aW5ncykge1xyXG4gIDxkaXYgY2xhc3M9XCJpbnB1dC1udW1iZXItY29udGVudFwiPlxyXG4gICAgQGlmIChzZXR0aW5ncy5vcHRpb25zLmxhYmVsKSB7XHJcbiAgICAgIDxtcngtbGFiZWxcclxuICAgICAgICBbcmVxdWlyZWRdPVwic2V0dGluZ3Mub3B0aW9ucy5yZXF1aXJlZFwiXHJcbiAgICAgICAgW3Rvb2x0aXBdPVwic2V0dGluZ3Mub3B0aW9ucy50b29sdGlwIHx8ICcnXCJcclxuICAgICAgICBbY3VzdG9tQ2xhc3Nlc109XCInbXQtMidcIlxyXG4gICAgICA+XHJcbiAgICAgICAge3sgc2V0dGluZ3Mub3B0aW9ucy5sYWJlbCB9fVxyXG4gICAgICA8L21yeC1sYWJlbD5cclxuICAgIH1cclxuXHJcbiAgICA8bXJ4LWlucHV0LW51bWJlclxyXG4gICAgICBbKG5nTW9kZWwpXT1cIm1vZGVsLnZhbHVlXCJcclxuICAgICAgW2ZpZWxkc109XCJhdXRvc2F2ZUZpZWxkc1wiXHJcbiAgICAgIFtyZWFkb25seV09XCJpc1JlYWRvbmx5XCJcclxuICAgICAgW3BsYWNlaG9sZGVyXT1cInNldHRpbmdzLm9wdGlvbnMucGxhY2Vob2xkZXIgfHwgJydcIlxyXG4gICAgICBbbWluVmFsdWVdPVwic2V0dGluZ3Mub3B0aW9ucy5taW5WYWx1ZSB8fCAwXCJcclxuICAgICAgW21heFZhbHVlXT1cInNldHRpbmdzLm9wdGlvbnMubWF4VmFsdWUgfHwgMFwiXHJcbiAgICAgIFtpbnZhbGlkXT1cImdldEludmFsaWRcIlxyXG4gICAgICBbaW52YWxpZE1lc3NhZ2VdPVwiZ2V0SW52YWxpZE1lc3NhZ2VcIlxyXG4gICAgICAobW9kZWxDaGFuZ2UpPVwiZGlzcGF0Y2hNb2RpZnkoJGV2ZW50KVwiXHJcbiAgICA+PC9tcngtaW5wdXQtbnVtYmVyPlxyXG4gIDwvZGl2PlxyXG59XHJcbiJdfQ==
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtbnVtYmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRleC1mb3JtL3NyYy9saWIvbW9kdWxlcy9vYmplY3QtZm9ybS9jb21wb25lbnRzL2VsZW1lbnRzL2lucHV0L251bWJlci9pbnB1dC1udW1iZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGV4LWZvcm0vc3JjL2xpYi9tb2R1bGVzL29iamVjdC1mb3JtL2NvbXBvbmVudHMvZWxlbWVudHMvaW5wdXQvbnVtYmVyL2lucHV0LW51bWJlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQzNFLE9BQU8sRUFBRSxhQUFhLEVBQUUsVUFBVSxFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sWUFBWSxDQUFDOzs7O0FBV2hELE1BQU0sT0FBTyxvQkFBcUIsU0FBUSxrQkFBNEQ7SUFOdEc7O1FBT0UsU0FBSSxHQUFHLGFBQWEsQ0FBQyxXQUFXLENBQUM7UUFFMUIsa0JBQWEsR0FBRyxDQUFDLENBQUE7S0FvQnpCO0lBbEJDLElBQVcsVUFBVTtRQUNuQixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLFVBQVUsS0FBSyxVQUFVLENBQUMsT0FBTyxDQUFDO0lBQ2pFLENBQUM7SUFFTSxhQUFhO1FBQ2xCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUE7SUFDdkMsQ0FBQztJQUVRLGVBQWUsQ0FBQyxLQUEwQjtRQUNqRCxJQUFJLENBQUMsYUFBYSxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUE7UUFFaEMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLEVBQUUsQ0FBQTtRQUU3QixPQUFPLENBQUMsQ0FDTixJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxRQUFRLElBQUksS0FBSyxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDLEtBQUs7WUFDN0YsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsUUFBUSxJQUFJLEtBQUssQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQzlGLENBQUM7SUFDSixDQUFDOytHQXRCVSxvQkFBb0I7bUdBQXBCLG9CQUFvQiwrRUNiakMsMmdEQXVDQTs7NEZEMUJhLG9CQUFvQjtrQkFOaEMsU0FBUzsrQkFDRSxrQkFBa0IsbUJBR1gsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21wb25lbnRUeXBlLCBJbnB1dFN0YXRlIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vc2hhcmVkLWZvcm0vZW51bXMnO1xyXG5pbXBvcnQgeyBCYXNlRmllbGRDb21wb25lbnQgfSBmcm9tICcuLi8uLi9iYXNlJztcclxuaW1wb3J0IHsgSW5wdXROdW1iZXJNb2RlbCB9IGZyb20gJy4uLy4uLy4uLy4uL21vZGVscy9lbGVtZXRzL2lucHV0cyc7XHJcbmltcG9ydCB7IElucHV0TnVtYmVyVmFsdWVXaXRoSWQgfSBmcm9tICdAbXlydGV4LW9yZy91aSc7XHJcbmltcG9ydCB7IENvbXBvbmVudFZhbHVlTW9kZWwgfSBmcm9tICcuLi8uLi8uLi8uLi9tb2RlbHMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtaW5wdXQtbnVtYmVyJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vaW5wdXQtbnVtYmVyLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9pbnB1dC1udW1iZXIuY29tcG9uZW50Lmxlc3MnXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgSW5wdXROdW1iZXJDb21wb25lbnQgZXh0ZW5kcyBCYXNlRmllbGRDb21wb25lbnQ8SW5wdXROdW1iZXJNb2RlbCwgSW5wdXROdW1iZXJWYWx1ZVdpdGhJZD4gaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIHR5cGUgPSBDb21wb25lbnRUeXBlLklucHV0TnVtYmVyO1xyXG5cclxuICBwdWJsaWMgdmFsaWRhdGVWYWx1ZSA9IDBcclxuXHJcbiAgcHVibGljIGdldCBpc1JlYWRvbmx5KCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRoaXMuc2V0dGluZ3Mub3B0aW9ucy5pbnB1dFN0YXRlID09PSBJbnB1dFN0YXRlLkZvcm11bGE7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25DaGFuZ2VJbnB1dCgpIHtcclxuICAgIHRoaXMudmFsaWRhdGVWYWx1ZSA9IHRoaXMubW9kZWwudmFsdWVcclxuICB9XHJcblxyXG4gIG92ZXJyaWRlIF9jdXN0b21WYWxpZGF0ZShtb2RlbDogQ29tcG9uZW50VmFsdWVNb2RlbCkge1xyXG4gICAgdGhpcy52YWxpZGF0ZVZhbHVlID0gbW9kZWwudmFsdWVcclxuXHJcbiAgICB0aGlzLl9kZXRlY3Rvci5tYXJrRm9yQ2hlY2soKVxyXG5cclxuICAgIHJldHVybiAhKFxyXG4gICAgICB0aGlzLnNldHRpbmdzLm9wdGlvbnMubWluVmFsdWUgJiYgbW9kZWwudmFsdWUgJiYgdGhpcy5zZXR0aW5ncy5vcHRpb25zLm1pblZhbHVlID4gbW9kZWwudmFsdWUgfHxcclxuICAgICAgdGhpcy5zZXR0aW5ncy5vcHRpb25zLm1heFZhbHVlICYmIG1vZGVsLnZhbHVlICYmIHRoaXMuc2V0dGluZ3Mub3B0aW9ucy5tYXhWYWx1ZSA8IG1vZGVsLnZhbHVlXHJcbiAgICApO1xyXG4gIH1cclxufVxyXG4iLCJAaWYgKHNldHRpbmdzKSB7XHJcbiAgPGRpdiBjbGFzcz1cImlucHV0LW51bWJlci1jb250ZW50XCI+XHJcbiAgICBAaWYgKHNldHRpbmdzLm9wdGlvbnMubGFiZWwpIHtcclxuICAgICAgPG1yeC1sYWJlbFxyXG4gICAgICAgIFtyZXF1aXJlZF09XCJzZXR0aW5ncy5vcHRpb25zLnJlcXVpcmVkXCJcclxuICAgICAgICBbdG9vbHRpcF09XCJzZXR0aW5ncy5vcHRpb25zLnRvb2x0aXAgfHwgJydcIlxyXG4gICAgICAgIFtjdXN0b21DbGFzc2VzXT1cIidtdC0yJ1wiXHJcbiAgICAgID5cclxuICAgICAgICB7eyBzZXR0aW5ncy5vcHRpb25zLmxhYmVsIH19XHJcbiAgICAgIDwvbXJ4LWxhYmVsPlxyXG4gICAgfVxyXG5cclxuICAgIDxtcngtaW5wdXQtbnVtYmVyXHJcbiAgICAgIFsobmdNb2RlbCldPVwibW9kZWwudmFsdWVcIlxyXG4gICAgICBbZmllbGRzXT1cImF1dG9zYXZlRmllbGRzXCJcclxuICAgICAgW3JlYWRvbmx5XT1cImlzUmVhZG9ubHlcIlxyXG4gICAgICBbcGxhY2Vob2xkZXJdPVwic2V0dGluZ3Mub3B0aW9ucy5wbGFjZWhvbGRlciB8fCAnJ1wiXHJcbiAgICAgIFtpbnZhbGlkXT1cImdldEludmFsaWRcIlxyXG4gICAgICBbaW52YWxpZE1lc3NhZ2VdPVwiZ2V0SW52YWxpZE1lc3NhZ2VcIlxyXG4gICAgICAobW9kZWxDaGFuZ2UpPVwiZGlzcGF0Y2hNb2RpZnkoJGV2ZW50KVwiXHJcbiAgICAgIChjaGFuZ2UpPVwib25DaGFuZ2VJbnB1dCgpXCJcclxuICAgID48L21yeC1pbnB1dC1udW1iZXI+XHJcblxyXG4gICAgQGlmIChzZXR0aW5ncy5vcHRpb25zLm1pblZhbHVlKSB7XHJcbiAgICAgIDxtcngtaGludC1lcnJvci1tZXNzYWdlXHJcbiAgICAgICAgbWVzc2FnZT1cItCc0LjQvdC40LzQsNC70YzQvdC+0LUg0LfQvdCw0YfQtdC90LjQtSDigJQge3sgc2V0dGluZ3Mub3B0aW9ucy5taW5WYWx1ZSB9fVwiXHJcbiAgICAgICAgW3ZhbHVlXT1cInZhbGlkYXRlVmFsdWVcIlxyXG4gICAgICAgIFttaW5WYWx1ZV09XCJzZXR0aW5ncy5vcHRpb25zLm1pblZhbHVlXCJcclxuICAgICAgPjwvbXJ4LWhpbnQtZXJyb3ItbWVzc2FnZT5cclxuICAgIH1cclxuICAgIEBpZiAoc2V0dGluZ3Mub3B0aW9ucy5tYXhWYWx1ZSkge1xyXG4gICAgICA8bXJ4LWhpbnQtZXJyb3ItbWVzc2FnZVxyXG4gICAgICAgIG1lc3NhZ2U9XCLQnNCw0LrRgdC40LzQsNC70YzQvdC+0LUg0LfQvdCw0YfQtdC90LjQtSDigJQge3sgc2V0dGluZ3Mub3B0aW9ucy5tYXhWYWx1ZSB9fVwiXHJcbiAgICAgICAgW3ZhbHVlXT1cInZhbGlkYXRlVmFsdWVcIlxyXG4gICAgICAgIFttYXhWYWx1ZV09XCJzZXR0aW5ncy5vcHRpb25zLm1heFZhbHVlXCJcclxuICAgICAgPjwvbXJ4LWhpbnQtZXJyb3ItbWVzc2FnZT5cclxuICAgIH1cclxuICA8L2Rpdj5cclxufVxyXG4iXX0=
@@ -1,5 +1,5 @@
1
1
  import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, inject, Input, Output, ViewChild } from '@angular/core';
2
- import { ComponentType } from '../../../../../shared-form/enums';
2
+ import { ComponentType, DateTypeEnum } from '../../../../../shared-form/enums';
3
3
  import { Store } from '@ngrx/store';
4
4
  import { debounceTime } from 'rxjs/operators';
5
5
  import { Subject } from 'rxjs';
@@ -22,8 +22,25 @@ export class InputTableComponent {
22
22
  this._changeSubject$ = new Subject();
23
23
  this._subscriptions$ = [];
24
24
  this._isCheckRequired = false;
25
- this.dataSource = [];
26
- this.columns = [];
25
+ this.dataSource = [
26
+ // { text1: "Строка 1", text2: "Строка A", date: "2023-10-01", textArea: "Область 1", text3: "Текст 1", numberField: 100, isHidden: false },
27
+ // { text1: "Строка 2", text2: "Строка B", date: "2023-10-01", textArea: "Область 2", text3: "Текст 2", numberField: 200, isHidden: false },
28
+ // { text1: "Строка 3", text2: "Строка C", date: "2023-10-02", textArea: "Область 3", text3: "Текст 3", numberField: 300, isHidden: false },
29
+ // { text1: "Скрытая строка", text2: "Строка D", date: "2023-10-03", textArea: "Область 4", text3: "Текст 4", numberField: 400, isHidden: true } // Новая строка
30
+ ];
31
+ this.columns = [
32
+ // { caption: "Текстовая строка", dataField: "text1" },
33
+ // { caption: "Текстовая строка", dataField: "text2" },
34
+ // { caption: "Дата", dataField: "date", dataType: "date", format: "dd.MM.yyyy", groupIndex: 0 },
35
+ // {
36
+ // caption: "Группа полей",
37
+ // columns: [
38
+ // { caption: "Текстовая область", dataField: "textArea" },
39
+ // { caption: "Текстовая строка", dataField: "text3" },
40
+ // { caption: "Числовое поле", dataField: "numberField", dataType: "number" }
41
+ // ]
42
+ // }
43
+ ];
27
44
  this.values = [];
28
45
  this.changed = new EventEmitter();
29
46
  }
@@ -100,7 +117,12 @@ export class InputTableComponent {
100
117
  getFormat(component) {
101
118
  switch (component.type) {
102
119
  case ComponentType.InputDate:
103
- return 'dd.MM.yyyy';
120
+ switch (component.options.viewType) {
121
+ case DateTypeEnum.DateTime:
122
+ return 'dd.MM.yyyy hh:mm';
123
+ default:
124
+ return 'dd.MM.yyyy';
125
+ }
104
126
  default:
105
127
  return '';
106
128
  }
@@ -165,19 +187,27 @@ export class InputTableComponent {
165
187
  this._detector.detectChanges();
166
188
  }
167
189
  _transformColumn(component) {
168
- return {
190
+ const column = {
169
191
  caption: component.options.label || '',
170
192
  columns: component.components.map(c => this._transformColumn(structuredClone(c))),
171
193
  dataField: component.sysName,
194
+ dataType: this.getDataType(component),
172
195
  format: this.getFormat(component),
173
196
  };
197
+ if (this.settings.options.groups.length) {
198
+ const findIdx = this.settings.options.groups.findIndex(x => x === component.sysName);
199
+ if (findIdx !== -1) {
200
+ column.groupIndex = findIdx;
201
+ }
202
+ }
203
+ return column;
174
204
  }
175
205
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
176
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: InputTableComponent, selector: "app-input-table", inputs: { values: "values", data: "data" }, outputs: { changed: "changed" }, viewQueries: [{ propertyName: "dataGrid", first: true, predicate: ["dataGrid"], descendants: true }, { propertyName: "editTemplate", first: true, predicate: ["editTemplate"], descendants: true }], ngImport: i0, template: "@if (settings) {\r\n <div class=\"input-table-content w-100\">\r\n @if (settings.options.label) {\r\n <mrx-label\r\n [required]=\"settings.options.required\"\r\n [tooltip]=\"settings.options.tooltip || ''\"\r\n [customClasses]=\"'mt-2'\"\r\n >\r\n {{ settings.options.label }}\r\n </mrx-label>\r\n }\r\n\r\n <dx-data-grid\r\n #dataGrid\r\n [dataSource]=\"dataSource\"\r\n [columns]=\"columns\"\r\n noDataText=\"\u041D\u0435\u0442 \u0434\u0430\u043D\u043D\u044B\u0445\"\r\n style=\"width: 100%\"\r\n >\r\n <dxo-toolbar>\r\n <dxi-item location=\"after\">\r\n <div *dxTemplate class=\"add-row\">\r\n <mrx-button\r\n [size]=\"'medium'\"\r\n [type]=\"'tertiary'\"\r\n [customClasses]=\"'px-3'\"\r\n (mrxClick)=\"createRow()\"\r\n >\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C\r\n </mrx-button>\r\n </div>\r\n </dxi-item>\r\n </dxo-toolbar>\r\n\r\n <div *dxTemplate=\"let buttonData of 'editButtonTemplate'\">\r\n <span class=\"mrx-icon icon-edit icon-font-16 cursor-pointer\" (click)=\"editRow(buttonData)\"></span>\r\n </div>\r\n\r\n <div *dxTemplate=\"let buttonData of 'deleteButtonTemplate'\">\r\n <span class=\"mrx-icon icon-delete icon-font-16 cursor-pointer\" (click)=\"deleteRow(buttonData)\"></span>\r\n </div>\r\n\r\n @if (dataSource.length) {\r\n <dxo-summary>\r\n @for (component of settings.components; track component.id; let first = $first) {\r\n @if (!first) {\r\n @if (showTotal(component)) {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [summaryType]=\"'sum'\"\r\n [displayFormat]=\"'{0}'\"\r\n ></dxi-total-item>\r\n }\r\n\r\n @for (component of component.components; track component.id) {\r\n @if (showTotal(component)) {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [summaryType]=\"'sum'\"\r\n [displayFormat]=\"'{0}'\"\r\n ></dxi-total-item>\r\n }\r\n\r\n @for (component of component.components; track component.id) {\r\n @if (showTotal(component)) {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [summaryType]=\"'sum'\"\r\n [displayFormat]=\"'{0}'\"\r\n ></dxi-total-item>\r\n }\r\n }\r\n }\r\n } @else {\r\n @if (isTotalColumn(component)) {\r\n <dxi-total-item [column]=\"component.sysName\" [displayFormat]=\"'{0}'\"></dxi-total-item>\r\n } @else {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [cssClass]=\"'text-bold'\"\r\n [displayFormat]=\"'\u0418\u0422\u041E\u0413\u041E'\"\r\n ></dxi-total-item>\r\n }\r\n }\r\n }\r\n </dxo-summary>\r\n }\r\n </dx-data-grid>\r\n\r\n <ng-template #editTemplate let-cellInfo=\"cellInfo\">\r\n <div class=\"d-flex align-items-center justify-content-center\" style=\"gap: 4px\">\r\n <span class=\"mrx-icon icon-edit icon-font-16 cursor-pointer\" (click)=\"editRow(cellInfo)\"></span>\r\n <span class=\"mrx-icon icon-delete icon-font-16 cursor-pointer\" (click)=\"deleteRow(cellInfo)\"></span>\r\n </div>\r\n </ng-template>\r\n </div>\r\n}\r\n\r\n\r\n", styles: [":host::ng-deep .input-table-content .dx-datagrid{padding:0}:host::ng-deep .input-table-content .dx-datagrid-header-panel{display:flex;align-items:center;min-height:40px;padding:0}:host::ng-deep .input-table-content .dx-datagrid-rowsview{border-bottom:none}:host::ng-deep .input-table-content .dx-datagrid-rowsview.dx-empty{border-bottom:1px solid #ddd;height:48px}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer{border-top:none;border-left:none;border-right:none}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content{padding:0}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content table,:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content th,:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content td{border:1px solid #ddd;border-top:none;border-collapse:collapse}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content table{border-top:none}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content .dx-datagrid-summary-item{font-weight:400}:host::ng-deep .custom-cell-controls .dx-template-wrapper{display:inline-flex}\n"], dependencies: [{ kind: "component", type: i1.LabelComponent, selector: "mrx-label", inputs: ["requiredHidden", "required", "boldLabel", "disabled", "placeholder", "label", "customClasses", "triggerTextPosition", "isPublicInfo", "publicInfoTooltip", "isSwitch", "switchLabel", "switchValue", "isCheckbox", "checkboxLabel", "checkboxValue", "counter", "linkText", "linkPrevent", "linkType", "linkMonochrome", "href", "triggerType", "tooltip", "tooltipInitialVisible", "isSaveToStorage"], outputs: ["changeSwitchValue", "changeCheckboxValue", "clickedLink"] }, { kind: "component", type: i1.ButtonComponent, selector: "mrx-button", inputs: ["size", "type", "color", "iconPosition", "active", "disabled", "isLoading", "iconOnly", "customClasses", "label", "icon", "iconClass", "buttonType", "href", "target", "routerLink", "queryParams"], outputs: ["mrxClick"] }, { kind: "component", type: i2.DxDataGridComponent, selector: "dx-data-grid", inputs: ["accessKey", "activeStateEnabled", "allowColumnReordering", "allowColumnResizing", "autoNavigateToFocusedRow", "cacheEnabled", "cellHintEnabled", "columnAutoWidth", "columnChooser", "columnFixing", "columnHidingEnabled", "columnMinWidth", "columnResizingMode", "columns", "columnWidth", "customizeColumns", "dataRowTemplate", "dataSource", "dateSerializationFormat", "disabled", "editing", "elementAttr", "errorRowEnabled", "export", "filterBuilder", "filterBuilderPopup", "filterPanel", "filterRow", "filterSyncEnabled", "filterValue", "focusedColumnIndex", "focusedRowEnabled", "focusedRowIndex", "focusedRowKey", "grouping", "groupPanel", "headerFilter", "height", "highlightChanges", "hint", "hoverStateEnabled", "keyboardNavigation", "keyExpr", "loadPanel", "masterDetail", "noDataText", "pager", "paging", "remoteOperations", "renderAsync", "repaintChangesOnly", "rowAlternationEnabled", "rowDragging", "rowTemplate", "rtlEnabled", "scrolling", "searchPanel", "selectedRowKeys", "selection", "selectionFilter", "showBorders", "showColumnHeaders", "showColumnLines", "showRowLines", "sortByGroupSummaryInfo", "sorting", "stateStoring", "summary", "syncLookupFilterValues", "tabIndex", "toolbar", "twoWayBindingEnabled", "visible", "width", "wordWrapEnabled"], outputs: ["onAdaptiveDetailRowPreparing", "onCellClick", "onCellDblClick", "onCellHoverChanged", "onCellPrepared", "onContentReady", "onContextMenuPreparing", "onDataErrorOccurred", "onDisposing", "onEditCanceled", "onEditCanceling", "onEditingStart", "onEditorPrepared", "onEditorPreparing", "onExporting", "onFocusedCellChanged", "onFocusedCellChanging", "onFocusedRowChanged", "onFocusedRowChanging", "onInitialized", "onInitNewRow", "onKeyDown", "onOptionChanged", "onRowClick", "onRowCollapsed", "onRowCollapsing", "onRowDblClick", "onRowExpanded", "onRowExpanding", "onRowInserted", "onRowInserting", "onRowPrepared", "onRowRemoved", "onRowRemoving", "onRowUpdated", "onRowUpdating", "onRowValidating", "onSaved", "onSaving", "onSelectionChanged", "onToolbarPreparing", "accessKeyChange", "activeStateEnabledChange", "allowColumnReorderingChange", "allowColumnResizingChange", "autoNavigateToFocusedRowChange", "cacheEnabledChange", "cellHintEnabledChange", "columnAutoWidthChange", "columnChooserChange", "columnFixingChange", "columnHidingEnabledChange", "columnMinWidthChange", "columnResizingModeChange", "columnsChange", "columnWidthChange", "customizeColumnsChange", "dataRowTemplateChange", "dataSourceChange", "dateSerializationFormatChange", "disabledChange", "editingChange", "elementAttrChange", "errorRowEnabledChange", "exportChange", "filterBuilderChange", "filterBuilderPopupChange", "filterPanelChange", "filterRowChange", "filterSyncEnabledChange", "filterValueChange", "focusedColumnIndexChange", "focusedRowEnabledChange", "focusedRowIndexChange", "focusedRowKeyChange", "groupingChange", "groupPanelChange", "headerFilterChange", "heightChange", "highlightChangesChange", "hintChange", "hoverStateEnabledChange", "keyboardNavigationChange", "keyExprChange", "loadPanelChange", "masterDetailChange", "noDataTextChange", "pagerChange", "pagingChange", "remoteOperationsChange", "renderAsyncChange", "repaintChangesOnlyChange", "rowAlternationEnabledChange", "rowDraggingChange", "rowTemplateChange", "rtlEnabledChange", "scrollingChange", "searchPanelChange", "selectedRowKeysChange", "selectionChange", "selectionFilterChange", "showBordersChange", "showColumnHeadersChange", "showColumnLinesChange", "showRowLinesChange", "sortByGroupSummaryInfoChange", "sortingChange", "stateStoringChange", "summaryChange", "syncLookupFilterValuesChange", "tabIndexChange", "toolbarChange", "twoWayBindingEnabledChange", "visibleChange", "widthChange", "wordWrapEnabledChange"] }, { kind: "component", type: i3.DxiItemComponent, selector: "dxi-item", inputs: ["disabled", "html", "icon", "template", "text", "title", "titleTemplate", "visible", "onClick", "stylingMode", "type", "baseSize", "box", "ratio", "shrink", "elementAttr", "hint", "beginGroup", "closeMenuOnClick", "items", "selectable", "selected", "colSpan", "cssClass", "dataField", "editorOptions", "editorType", "helpText", "isRequired", "itemType", "label", "name", "validationRules", "visibleIndex", "alignItemLabels", "caption", "colCount", "colCountByScreen", "tabPanelOptions", "tabs", "badge", "tabTemplate", "buttonOptions", "horizontalAlignment", "verticalAlignment", "locateInMenu", "location", "menuItemTemplate", "options", "showText", "widget", "height", "width", "imageAlt", "imageSrc", "acceptedValues", "formatName", "formatValues", "key", "showChevron", "linkAttr", "url", "heightRatio", "widthRatio", "expanded", "hasItems", "id", "parentId"] }, { kind: "component", type: i3.DxoSummaryComponent, selector: "dxo-summary", inputs: ["calculateCustomSummary", "groupItems", "recalculateWhileEditing", "skipEmptyValues", "texts", "totalItems"] }, { kind: "component", type: i3.DxiTotalItemComponent, selector: "dxi-total-item", inputs: ["alignment", "column", "cssClass", "customizeText", "displayFormat", "name", "showInColumn", "skipEmptyValues", "summaryType", "valueFormat"] }, { kind: "component", type: i3.DxoToolbarComponent, selector: "dxo-toolbar", inputs: ["disabled", "items", "visible", "fileSelectionItems", "container", "multiline"] }, { kind: "directive", type: i4.DxTemplateDirective, selector: "[dxTemplate]", inputs: ["dxTemplateOf"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
206
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: InputTableComponent, selector: "app-input-table", inputs: { values: "values", data: "data" }, outputs: { changed: "changed" }, viewQueries: [{ propertyName: "dataGrid", first: true, predicate: ["dataGrid"], descendants: true }, { propertyName: "editTemplate", first: true, predicate: ["editTemplate"], descendants: true }], ngImport: i0, template: "@if (settings) {\r\n <div class=\"input-table-content w-100\">\r\n @if (settings.options.label) {\r\n <mrx-label\r\n [required]=\"settings.options.required\"\r\n [tooltip]=\"settings.options.tooltip || ''\"\r\n [customClasses]=\"'mt-2'\"\r\n >\r\n {{ settings.options.label }}\r\n </mrx-label>\r\n }\r\n\r\n <dx-data-grid\r\n #dataGrid\r\n [dataSource]=\"dataSource\"\r\n [columns]=\"columns\"\r\n noDataText=\"\u041D\u0435\u0442 \u0434\u0430\u043D\u043D\u044B\u0445\"\r\n style=\"width: 100%\"\r\n >\r\n <dxo-toolbar>\r\n <dxi-item location=\"after\">\r\n <div *dxTemplate class=\"add-row\">\r\n <mrx-button\r\n [size]=\"'medium'\"\r\n [type]=\"'tertiary'\"\r\n [customClasses]=\"'px-3'\"\r\n (mrxClick)=\"createRow()\"\r\n >\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C\r\n </mrx-button>\r\n </div>\r\n </dxi-item>\r\n </dxo-toolbar>\r\n\r\n <div *dxTemplate=\"let buttonData of 'editButtonTemplate'\">\r\n <span class=\"mrx-icon icon-edit icon-font-16 cursor-pointer\" (click)=\"editRow(buttonData)\"></span>\r\n </div>\r\n\r\n <div *dxTemplate=\"let buttonData of 'deleteButtonTemplate'\">\r\n <span class=\"mrx-icon icon-delete icon-font-16 cursor-pointer\" (click)=\"deleteRow(buttonData)\"></span>\r\n </div>\r\n\r\n @if (dataSource.length) {\r\n <dxo-summary>\r\n @for (component of settings.components; track component.id; let first = $first) {\r\n @if (!first) {\r\n @if (showTotal(component)) {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [summaryType]=\"'sum'\"\r\n [displayFormat]=\"'{0}'\"\r\n ></dxi-total-item>\r\n }\r\n\r\n @for (component of component.components; track component.id) {\r\n @if (showTotal(component)) {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [summaryType]=\"'sum'\"\r\n [displayFormat]=\"'{0}'\"\r\n ></dxi-total-item>\r\n }\r\n\r\n @for (component of component.components; track component.id) {\r\n @if (showTotal(component)) {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [summaryType]=\"'sum'\"\r\n [displayFormat]=\"'{0}'\"\r\n ></dxi-total-item>\r\n }\r\n }\r\n }\r\n } @else {\r\n @if (isTotalColumn(component)) {\r\n <dxi-total-item [column]=\"component.sysName\" [displayFormat]=\"'{0}'\"></dxi-total-item>\r\n } @else {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [cssClass]=\"'text-bold'\"\r\n [displayFormat]=\"'\u0418\u0422\u041E\u0413\u041E'\"\r\n ></dxi-total-item>\r\n }\r\n }\r\n }\r\n </dxo-summary>\r\n }\r\n </dx-data-grid>\r\n\r\n <ng-template #editTemplate let-cellInfo=\"cellInfo\">\r\n <div class=\"d-flex align-items-center justify-content-center\" style=\"gap: 4px\">\r\n <span class=\"mrx-icon icon-edit icon-font-16 cursor-pointer\" (click)=\"editRow(cellInfo)\"></span>\r\n <span class=\"mrx-icon icon-delete icon-font-16 cursor-pointer\" (click)=\"deleteRow(cellInfo)\"></span>\r\n </div>\r\n </ng-template>\r\n </div>\r\n}\r\n\r\n\r\n", styles: [":host::ng-deep .input-table-content .dx-datagrid{padding:0}:host::ng-deep .input-table-content .dx-datagrid-header-panel{display:flex;align-items:center;min-height:40px;padding:0}:host::ng-deep .input-table-content .dx-datagrid-rowsview{border-bottom:none}:host::ng-deep .input-table-content .dx-datagrid-rowsview.dx-empty{border-bottom:1px solid #ddd;height:48px}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer{border-top:none;border-left:none;border-right:none}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content{padding:0}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content table,:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content th,:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content td{border:1px solid #ddd;border-top:none;border-collapse:collapse}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content table{border-top:none}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content .dx-datagrid-summary-item{font-weight:400}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-headers{top:-24px}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-headers td.dx-command-expand.dx-datagrid-group-space{border-right:none!important;border-right-color:transparent}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer td.dx-command-expand.dx-datagrid-group-space{border-right-color:transparent}:host::ng-deep .input-table-content .dx-datagrid .dx-row>td,:host::ng-deep .input-table-content .dx-datagrid .page-wrapper .dx-treelist-container .dx-row>td{color:var(--neutral-text-secondary, #4D5157);font-family:var(--body-md-bold-font-family, \"PT Sans\");font-size:var(--body-md-bold-font-size, 14px);font-weight:var(--body-md-bold-font-weight, 700);line-height:var(--body-md-bold-line-height, 16px)}:host::ng-deep .input-table-content .dx-datagrid .dx-row.dx-data-row.dx-column-lines>td{color:var(--neutral-text-tertiary, #71767E);font-family:var(--body-md-font-family, \"PT Sans\");font-size:var(--body-md-font-size, 14px);font-weight:var(--body-md-font-weight, 400);line-height:var(--body-md-line-height, 20px)}:host::ng-deep .custom-cell-controls .dx-template-wrapper{display:inline-flex}\n"], dependencies: [{ kind: "component", type: i1.LabelComponent, selector: "mrx-label", inputs: ["requiredHidden", "required", "boldLabel", "disabled", "placeholder", "label", "customClasses", "triggerTextPosition", "isPublicInfo", "publicInfoTooltip", "isSwitch", "switchLabel", "switchValue", "isCheckbox", "checkboxLabel", "checkboxValue", "counter", "linkText", "linkPrevent", "linkType", "linkMonochrome", "href", "triggerType", "tooltip", "tooltipInitialVisible", "isSaveToStorage"], outputs: ["changeSwitchValue", "changeCheckboxValue", "clickedLink"] }, { kind: "component", type: i1.ButtonComponent, selector: "mrx-button", inputs: ["size", "type", "color", "iconPosition", "active", "disabled", "isLoading", "iconOnly", "customClasses", "label", "icon", "iconClass", "buttonType", "href", "target", "routerLink", "queryParams"], outputs: ["mrxClick"] }, { kind: "component", type: i2.DxDataGridComponent, selector: "dx-data-grid", inputs: ["accessKey", "activeStateEnabled", "allowColumnReordering", "allowColumnResizing", "autoNavigateToFocusedRow", "cacheEnabled", "cellHintEnabled", "columnAutoWidth", "columnChooser", "columnFixing", "columnHidingEnabled", "columnMinWidth", "columnResizingMode", "columns", "columnWidth", "customizeColumns", "dataRowTemplate", "dataSource", "dateSerializationFormat", "disabled", "editing", "elementAttr", "errorRowEnabled", "export", "filterBuilder", "filterBuilderPopup", "filterPanel", "filterRow", "filterSyncEnabled", "filterValue", "focusedColumnIndex", "focusedRowEnabled", "focusedRowIndex", "focusedRowKey", "grouping", "groupPanel", "headerFilter", "height", "highlightChanges", "hint", "hoverStateEnabled", "keyboardNavigation", "keyExpr", "loadPanel", "masterDetail", "noDataText", "pager", "paging", "remoteOperations", "renderAsync", "repaintChangesOnly", "rowAlternationEnabled", "rowDragging", "rowTemplate", "rtlEnabled", "scrolling", "searchPanel", "selectedRowKeys", "selection", "selectionFilter", "showBorders", "showColumnHeaders", "showColumnLines", "showRowLines", "sortByGroupSummaryInfo", "sorting", "stateStoring", "summary", "syncLookupFilterValues", "tabIndex", "toolbar", "twoWayBindingEnabled", "visible", "width", "wordWrapEnabled"], outputs: ["onAdaptiveDetailRowPreparing", "onCellClick", "onCellDblClick", "onCellHoverChanged", "onCellPrepared", "onContentReady", "onContextMenuPreparing", "onDataErrorOccurred", "onDisposing", "onEditCanceled", "onEditCanceling", "onEditingStart", "onEditorPrepared", "onEditorPreparing", "onExporting", "onFocusedCellChanged", "onFocusedCellChanging", "onFocusedRowChanged", "onFocusedRowChanging", "onInitialized", "onInitNewRow", "onKeyDown", "onOptionChanged", "onRowClick", "onRowCollapsed", "onRowCollapsing", "onRowDblClick", "onRowExpanded", "onRowExpanding", "onRowInserted", "onRowInserting", "onRowPrepared", "onRowRemoved", "onRowRemoving", "onRowUpdated", "onRowUpdating", "onRowValidating", "onSaved", "onSaving", "onSelectionChanged", "onToolbarPreparing", "accessKeyChange", "activeStateEnabledChange", "allowColumnReorderingChange", "allowColumnResizingChange", "autoNavigateToFocusedRowChange", "cacheEnabledChange", "cellHintEnabledChange", "columnAutoWidthChange", "columnChooserChange", "columnFixingChange", "columnHidingEnabledChange", "columnMinWidthChange", "columnResizingModeChange", "columnsChange", "columnWidthChange", "customizeColumnsChange", "dataRowTemplateChange", "dataSourceChange", "dateSerializationFormatChange", "disabledChange", "editingChange", "elementAttrChange", "errorRowEnabledChange", "exportChange", "filterBuilderChange", "filterBuilderPopupChange", "filterPanelChange", "filterRowChange", "filterSyncEnabledChange", "filterValueChange", "focusedColumnIndexChange", "focusedRowEnabledChange", "focusedRowIndexChange", "focusedRowKeyChange", "groupingChange", "groupPanelChange", "headerFilterChange", "heightChange", "highlightChangesChange", "hintChange", "hoverStateEnabledChange", "keyboardNavigationChange", "keyExprChange", "loadPanelChange", "masterDetailChange", "noDataTextChange", "pagerChange", "pagingChange", "remoteOperationsChange", "renderAsyncChange", "repaintChangesOnlyChange", "rowAlternationEnabledChange", "rowDraggingChange", "rowTemplateChange", "rtlEnabledChange", "scrollingChange", "searchPanelChange", "selectedRowKeysChange", "selectionChange", "selectionFilterChange", "showBordersChange", "showColumnHeadersChange", "showColumnLinesChange", "showRowLinesChange", "sortByGroupSummaryInfoChange", "sortingChange", "stateStoringChange", "summaryChange", "syncLookupFilterValuesChange", "tabIndexChange", "toolbarChange", "twoWayBindingEnabledChange", "visibleChange", "widthChange", "wordWrapEnabledChange"] }, { kind: "component", type: i3.DxiItemComponent, selector: "dxi-item", inputs: ["disabled", "html", "icon", "template", "text", "title", "titleTemplate", "visible", "onClick", "stylingMode", "type", "baseSize", "box", "ratio", "shrink", "elementAttr", "hint", "beginGroup", "closeMenuOnClick", "items", "selectable", "selected", "colSpan", "cssClass", "dataField", "editorOptions", "editorType", "helpText", "isRequired", "itemType", "label", "name", "validationRules", "visibleIndex", "alignItemLabels", "caption", "colCount", "colCountByScreen", "tabPanelOptions", "tabs", "badge", "tabTemplate", "buttonOptions", "horizontalAlignment", "verticalAlignment", "locateInMenu", "location", "menuItemTemplate", "options", "showText", "widget", "height", "width", "imageAlt", "imageSrc", "acceptedValues", "formatName", "formatValues", "key", "showChevron", "linkAttr", "url", "heightRatio", "widthRatio", "expanded", "hasItems", "id", "parentId"] }, { kind: "component", type: i3.DxoSummaryComponent, selector: "dxo-summary", inputs: ["calculateCustomSummary", "groupItems", "recalculateWhileEditing", "skipEmptyValues", "texts", "totalItems"] }, { kind: "component", type: i3.DxiTotalItemComponent, selector: "dxi-total-item", inputs: ["alignment", "column", "cssClass", "customizeText", "displayFormat", "name", "showInColumn", "skipEmptyValues", "summaryType", "valueFormat"] }, { kind: "component", type: i3.DxoToolbarComponent, selector: "dxo-toolbar", inputs: ["disabled", "items", "visible", "fileSelectionItems", "container", "multiline"] }, { kind: "directive", type: i4.DxTemplateDirective, selector: "[dxTemplate]", inputs: ["dxTemplateOf"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
177
207
  }
178
208
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputTableComponent, decorators: [{
179
209
  type: Component,
180
- args: [{ selector: 'app-input-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (settings) {\r\n <div class=\"input-table-content w-100\">\r\n @if (settings.options.label) {\r\n <mrx-label\r\n [required]=\"settings.options.required\"\r\n [tooltip]=\"settings.options.tooltip || ''\"\r\n [customClasses]=\"'mt-2'\"\r\n >\r\n {{ settings.options.label }}\r\n </mrx-label>\r\n }\r\n\r\n <dx-data-grid\r\n #dataGrid\r\n [dataSource]=\"dataSource\"\r\n [columns]=\"columns\"\r\n noDataText=\"\u041D\u0435\u0442 \u0434\u0430\u043D\u043D\u044B\u0445\"\r\n style=\"width: 100%\"\r\n >\r\n <dxo-toolbar>\r\n <dxi-item location=\"after\">\r\n <div *dxTemplate class=\"add-row\">\r\n <mrx-button\r\n [size]=\"'medium'\"\r\n [type]=\"'tertiary'\"\r\n [customClasses]=\"'px-3'\"\r\n (mrxClick)=\"createRow()\"\r\n >\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C\r\n </mrx-button>\r\n </div>\r\n </dxi-item>\r\n </dxo-toolbar>\r\n\r\n <div *dxTemplate=\"let buttonData of 'editButtonTemplate'\">\r\n <span class=\"mrx-icon icon-edit icon-font-16 cursor-pointer\" (click)=\"editRow(buttonData)\"></span>\r\n </div>\r\n\r\n <div *dxTemplate=\"let buttonData of 'deleteButtonTemplate'\">\r\n <span class=\"mrx-icon icon-delete icon-font-16 cursor-pointer\" (click)=\"deleteRow(buttonData)\"></span>\r\n </div>\r\n\r\n @if (dataSource.length) {\r\n <dxo-summary>\r\n @for (component of settings.components; track component.id; let first = $first) {\r\n @if (!first) {\r\n @if (showTotal(component)) {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [summaryType]=\"'sum'\"\r\n [displayFormat]=\"'{0}'\"\r\n ></dxi-total-item>\r\n }\r\n\r\n @for (component of component.components; track component.id) {\r\n @if (showTotal(component)) {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [summaryType]=\"'sum'\"\r\n [displayFormat]=\"'{0}'\"\r\n ></dxi-total-item>\r\n }\r\n\r\n @for (component of component.components; track component.id) {\r\n @if (showTotal(component)) {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [summaryType]=\"'sum'\"\r\n [displayFormat]=\"'{0}'\"\r\n ></dxi-total-item>\r\n }\r\n }\r\n }\r\n } @else {\r\n @if (isTotalColumn(component)) {\r\n <dxi-total-item [column]=\"component.sysName\" [displayFormat]=\"'{0}'\"></dxi-total-item>\r\n } @else {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [cssClass]=\"'text-bold'\"\r\n [displayFormat]=\"'\u0418\u0422\u041E\u0413\u041E'\"\r\n ></dxi-total-item>\r\n }\r\n }\r\n }\r\n </dxo-summary>\r\n }\r\n </dx-data-grid>\r\n\r\n <ng-template #editTemplate let-cellInfo=\"cellInfo\">\r\n <div class=\"d-flex align-items-center justify-content-center\" style=\"gap: 4px\">\r\n <span class=\"mrx-icon icon-edit icon-font-16 cursor-pointer\" (click)=\"editRow(cellInfo)\"></span>\r\n <span class=\"mrx-icon icon-delete icon-font-16 cursor-pointer\" (click)=\"deleteRow(cellInfo)\"></span>\r\n </div>\r\n </ng-template>\r\n </div>\r\n}\r\n\r\n\r\n", styles: [":host::ng-deep .input-table-content .dx-datagrid{padding:0}:host::ng-deep .input-table-content .dx-datagrid-header-panel{display:flex;align-items:center;min-height:40px;padding:0}:host::ng-deep .input-table-content .dx-datagrid-rowsview{border-bottom:none}:host::ng-deep .input-table-content .dx-datagrid-rowsview.dx-empty{border-bottom:1px solid #ddd;height:48px}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer{border-top:none;border-left:none;border-right:none}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content{padding:0}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content table,:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content th,:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content td{border:1px solid #ddd;border-top:none;border-collapse:collapse}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content table{border-top:none}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content .dx-datagrid-summary-item{font-weight:400}:host::ng-deep .custom-cell-controls .dx-template-wrapper{display:inline-flex}\n"] }]
210
+ args: [{ selector: 'app-input-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (settings) {\r\n <div class=\"input-table-content w-100\">\r\n @if (settings.options.label) {\r\n <mrx-label\r\n [required]=\"settings.options.required\"\r\n [tooltip]=\"settings.options.tooltip || ''\"\r\n [customClasses]=\"'mt-2'\"\r\n >\r\n {{ settings.options.label }}\r\n </mrx-label>\r\n }\r\n\r\n <dx-data-grid\r\n #dataGrid\r\n [dataSource]=\"dataSource\"\r\n [columns]=\"columns\"\r\n noDataText=\"\u041D\u0435\u0442 \u0434\u0430\u043D\u043D\u044B\u0445\"\r\n style=\"width: 100%\"\r\n >\r\n <dxo-toolbar>\r\n <dxi-item location=\"after\">\r\n <div *dxTemplate class=\"add-row\">\r\n <mrx-button\r\n [size]=\"'medium'\"\r\n [type]=\"'tertiary'\"\r\n [customClasses]=\"'px-3'\"\r\n (mrxClick)=\"createRow()\"\r\n >\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C\r\n </mrx-button>\r\n </div>\r\n </dxi-item>\r\n </dxo-toolbar>\r\n\r\n <div *dxTemplate=\"let buttonData of 'editButtonTemplate'\">\r\n <span class=\"mrx-icon icon-edit icon-font-16 cursor-pointer\" (click)=\"editRow(buttonData)\"></span>\r\n </div>\r\n\r\n <div *dxTemplate=\"let buttonData of 'deleteButtonTemplate'\">\r\n <span class=\"mrx-icon icon-delete icon-font-16 cursor-pointer\" (click)=\"deleteRow(buttonData)\"></span>\r\n </div>\r\n\r\n @if (dataSource.length) {\r\n <dxo-summary>\r\n @for (component of settings.components; track component.id; let first = $first) {\r\n @if (!first) {\r\n @if (showTotal(component)) {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [summaryType]=\"'sum'\"\r\n [displayFormat]=\"'{0}'\"\r\n ></dxi-total-item>\r\n }\r\n\r\n @for (component of component.components; track component.id) {\r\n @if (showTotal(component)) {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [summaryType]=\"'sum'\"\r\n [displayFormat]=\"'{0}'\"\r\n ></dxi-total-item>\r\n }\r\n\r\n @for (component of component.components; track component.id) {\r\n @if (showTotal(component)) {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [summaryType]=\"'sum'\"\r\n [displayFormat]=\"'{0}'\"\r\n ></dxi-total-item>\r\n }\r\n }\r\n }\r\n } @else {\r\n @if (isTotalColumn(component)) {\r\n <dxi-total-item [column]=\"component.sysName\" [displayFormat]=\"'{0}'\"></dxi-total-item>\r\n } @else {\r\n <dxi-total-item\r\n [column]=\"component.sysName\"\r\n [cssClass]=\"'text-bold'\"\r\n [displayFormat]=\"'\u0418\u0422\u041E\u0413\u041E'\"\r\n ></dxi-total-item>\r\n }\r\n }\r\n }\r\n </dxo-summary>\r\n }\r\n </dx-data-grid>\r\n\r\n <ng-template #editTemplate let-cellInfo=\"cellInfo\">\r\n <div class=\"d-flex align-items-center justify-content-center\" style=\"gap: 4px\">\r\n <span class=\"mrx-icon icon-edit icon-font-16 cursor-pointer\" (click)=\"editRow(cellInfo)\"></span>\r\n <span class=\"mrx-icon icon-delete icon-font-16 cursor-pointer\" (click)=\"deleteRow(cellInfo)\"></span>\r\n </div>\r\n </ng-template>\r\n </div>\r\n}\r\n\r\n\r\n", styles: [":host::ng-deep .input-table-content .dx-datagrid{padding:0}:host::ng-deep .input-table-content .dx-datagrid-header-panel{display:flex;align-items:center;min-height:40px;padding:0}:host::ng-deep .input-table-content .dx-datagrid-rowsview{border-bottom:none}:host::ng-deep .input-table-content .dx-datagrid-rowsview.dx-empty{border-bottom:1px solid #ddd;height:48px}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer{border-top:none;border-left:none;border-right:none}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content{padding:0}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content table,:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content th,:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content td{border:1px solid #ddd;border-top:none;border-collapse:collapse}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content table{border-top:none}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer .dx-datagrid-content .dx-datagrid-summary-item{font-weight:400}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-headers{top:-24px}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-headers td.dx-command-expand.dx-datagrid-group-space{border-right:none!important;border-right-color:transparent}:host::ng-deep .input-table-content .dx-datagrid .dx-datagrid-total-footer td.dx-command-expand.dx-datagrid-group-space{border-right-color:transparent}:host::ng-deep .input-table-content .dx-datagrid .dx-row>td,:host::ng-deep .input-table-content .dx-datagrid .page-wrapper .dx-treelist-container .dx-row>td{color:var(--neutral-text-secondary, #4D5157);font-family:var(--body-md-bold-font-family, \"PT Sans\");font-size:var(--body-md-bold-font-size, 14px);font-weight:var(--body-md-bold-font-weight, 700);line-height:var(--body-md-bold-line-height, 16px)}:host::ng-deep .input-table-content .dx-datagrid .dx-row.dx-data-row.dx-column-lines>td{color:var(--neutral-text-tertiary, #71767E);font-family:var(--body-md-font-family, \"PT Sans\");font-size:var(--body-md-font-size, 14px);font-weight:var(--body-md-font-weight, 400);line-height:var(--body-md-line-height, 20px)}:host::ng-deep .custom-cell-controls .dx-template-wrapper{display:inline-flex}\n"] }]
181
211
  }], propDecorators: { values: [{
182
212
  type: Input
183
213
  }], data: [{
@@ -191,4 +221,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
191
221
  }], changed: [{
192
222
  type: Output
193
223
  }] } });
194
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-table.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/table/input-table.component.ts","../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/table/input-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter, inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ComponentType } from '../../../../../shared-form/enums';\r\nimport { Store } from '@ngrx/store';\r\nimport { ComponentModelBase } from '../../../../../shared-form/models';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { DxDataGridComponent } from 'devextreme-angular';\r\nimport { cloneDeep } from 'lodash-es';\r\nimport { ComponentValueModel, SectionValueModel, TableRowModel, TableValueModel } from '../../../../models';\r\nimport { InputNumberModel, InputTableModel } from '../../../../models/elemets/inputs';\r\nimport { objectFormActions, objectFormSelectors } from '../../../../store';\r\nimport { ModalService } from '@myrtex-org/ui';\r\nimport { InputTableModalComponent } from './components';\r\nimport { getRowModel } from './helpers/get-row-model.helper';\r\nimport { ColumnModel } from './models/column.model';\r\n\r\n@Component({\r\n  selector: 'app-input-table',\r\n  templateUrl: './input-table.component.html',\r\n  styleUrls: ['./input-table.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class InputTableComponent implements OnInit, OnDestroy {\r\n  type = ComponentType.InputTable;\r\n\r\n  private _store: Store = inject(Store);\r\n  private _detector: ChangeDetectorRef = inject(ChangeDetectorRef);\r\n  private _modalService: ModalService = inject(ModalService);\r\n\r\n  private _changeSubject$: Subject<TableValueModel> = new Subject<TableValueModel>();\r\n  private _subscriptions$: Subscription[] = [];\r\n\r\n  private _isCheckRequired: boolean = false;\r\n\r\n  public model!: TableValueModel;\r\n  public settings!: InputTableModel;\r\n  public dataSource: { [key: string]: any }[] = [];\r\n  public columns: ColumnModel[] = [];\r\n\r\n  @Input() values: SectionValueModel[] = [];\r\n\r\n  @Input() set data(settings: ComponentModelBase) {\r\n    this.settings = settings as InputTableModel;\r\n\r\n    this.model = {sysName: settings.sysName, type: settings.type, data: [], totals: []};\r\n\r\n    this._detector.detectChanges();\r\n\r\n    this._initColumns(this.settings.components);\r\n  }\r\n\r\n  @ViewChild('dataGrid', {static: false}) dataGrid!: DxDataGridComponent;\r\n  @ViewChild('editTemplate', {static: false}) editTemplate!: any;\r\n\r\n  @Output() public changed: EventEmitter<ComponentValueModel | ComponentValueModel[]> = new EventEmitter<ComponentValueModel | ComponentValueModel[]>();\r\n\r\n  ngOnInit(): void {\r\n    this._initModel();\r\n\r\n    this._changeSubject$.pipe(\r\n      debounceTime(700),\r\n    ).subscribe(model => {\r\n      this._store.dispatch(objectFormActions.updateValues({value: model}));\r\n    });\r\n\r\n    this._subscriptions$.push(this._store.select(objectFormSelectors.selectIsCheckRequired).subscribe(result => {\r\n      this._isCheckRequired = result;\r\n      this._detector.detectChanges();\r\n    }));\r\n\r\n    this._subscriptions$.push(this._store.select(objectFormSelectors.selectValueModel(this.settings))\r\n      .subscribe((result: ComponentValueModel | null | (ComponentValueModel | null)[]) => {\r\n        const cloneResult = cloneDeep(result as TableValueModel | null);\r\n\r\n        if (cloneResult && !Array.isArray(cloneResult) && this.model.data !== cloneResult.data) {\r\n          this.model = cloneResult;\r\n          this._initDataSource(this.model.data);\r\n        }\r\n      }));\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._changeSubject$.unsubscribe();\r\n    this._subscriptions$.forEach((subscription) => subscription.unsubscribe());\r\n  }\r\n\r\n  public createRow() {\r\n    this._modalService.open(InputTableModalComponent, {\r\n      title: 'Создание строки',\r\n      okText: 'Создать',\r\n      settings: this.settings,\r\n      rowModel: getRowModel(this.settings)\r\n    }).afterClosed().subscribe(resolve => {\r\n      if (resolve.result) {\r\n        this.model.data = [...this.model.data, resolve.rowModel];\r\n\r\n        this._initDataSource(this.model.data);\r\n\r\n        this._changeSubject$.next(this.model);\r\n      }\r\n    });\r\n  }\r\n\r\n  public deleteRow(event: any) {\r\n    const findRow = this.model.data.find(item => item.id === event.row.data.id);\r\n\r\n    if (findRow) {\r\n      this.model.data = this.model.data.filter(item => item.id !== event.row.data.id);\r\n\r\n      this._initDataSource(this.model.data);\r\n\r\n      this._changeSubject$.next(this.model);\r\n    }\r\n  }\r\n\r\n  public editRow(event: any) {\r\n    const findRow: TableRowModel | undefined = this.model.data.find(item => item.id === event.row.data.id);\r\n\r\n    if (findRow) {\r\n      this._modalService.open(InputTableModalComponent, {\r\n        title: 'Редактирование строки',\r\n        okText: 'Сохранить',\r\n        settings: this.settings,\r\n        rowModel: findRow\r\n      }).afterClosed().subscribe(resolve => {\r\n        if (resolve.result) {\r\n          const cloneModel = cloneDeep(this.model);\r\n          const findRow = cloneModel.data.find(row => row.id === resolve.rowModel.id);\r\n\r\n          if (findRow) {\r\n            findRow.data = resolve.rowModel.data;\r\n\r\n            this._changeSubject$.next(cloneModel);\r\n          }\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public getFormat(component: ComponentModelBase) {\r\n    switch (component.type) {\r\n      case ComponentType.InputDate:\r\n        return 'dd.MM.yyyy';\r\n      default:\r\n        return '';\r\n    }\r\n  }\r\n\r\n  public getDataType(component: ComponentModelBase) {\r\n    switch (component.type) {\r\n      case ComponentType.InputDate:\r\n        return 'date';\r\n      default:\r\n        return undefined;\r\n    }\r\n  }\r\n\r\n  public showTotal(component: ComponentModelBase): boolean {\r\n    if (component.type === ComponentType.InputNumber) {\r\n      const element: InputNumberModel = component as InputNumberModel;\r\n\r\n      return element.options.inTotals;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  public isTotalColumn(component: ComponentModelBase): boolean {\r\n    return (component as InputNumberModel).options['inTotals'];\r\n  }\r\n\r\n  private _initModel() {\r\n    this.model = {\r\n      sysName: this.settings.sysName,\r\n      type: this.settings.type,\r\n      data: [],\r\n      totals: []\r\n    };\r\n  }\r\n\r\n  private _initDataSource(data: TableRowModel[]) {\r\n    this.dataSource = data.map((item: TableRowModel) => {\r\n      const newDataItem: any = {};\r\n\r\n      for (let i in item.data) {\r\n        newDataItem[item.data[i].sysName] = item.data[i].value;\r\n      }\r\n\r\n      newDataItem.id = item.id;\r\n\r\n      return newDataItem;\r\n    });\r\n\r\n    this._detector.detectChanges();\r\n\r\n    this.dataGrid.instance.refresh();\r\n  }\r\n\r\n  private _initColumns(components: ComponentModelBase[]) {\r\n    this.columns = components.map(c => this._transformColumn(structuredClone(c)));\r\n\r\n    this.columns.push({\r\n      caption: '',\r\n      type: 'buttons',\r\n      width: 80,\r\n      cssClass: 'custom-cell-controls',\r\n      buttons: [\r\n        {\r\n          template: 'editButtonTemplate',\r\n          hint: 'Редактировать',\r\n        },\r\n        {\r\n          template: 'deleteButtonTemplate',\r\n          hint: 'Удалить',\r\n        },\r\n      ],\r\n    });\r\n\r\n    this.dataGrid.instance.repaint();\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  private _transformColumn(component: ComponentModelBase): ColumnModel {\r\n    return {\r\n      caption: component.options.label || '',\r\n      columns: component.components.map(c => this._transformColumn(structuredClone(c))),\r\n      dataField: component.sysName,\r\n      format: this.getFormat(component),\r\n    };\r\n  }\r\n}\r\n","@if (settings) {\r\n  <div class=\"input-table-content w-100\">\r\n    @if (settings.options.label) {\r\n      <mrx-label\r\n        [required]=\"settings.options.required\"\r\n        [tooltip]=\"settings.options.tooltip || ''\"\r\n        [customClasses]=\"'mt-2'\"\r\n      >\r\n        {{ settings.options.label }}\r\n      </mrx-label>\r\n    }\r\n\r\n    <dx-data-grid\r\n      #dataGrid\r\n      [dataSource]=\"dataSource\"\r\n      [columns]=\"columns\"\r\n      noDataText=\"Нет данных\"\r\n      style=\"width: 100%\"\r\n    >\r\n      <dxo-toolbar>\r\n        <dxi-item location=\"after\">\r\n          <div *dxTemplate class=\"add-row\">\r\n            <mrx-button\r\n              [size]=\"'medium'\"\r\n              [type]=\"'tertiary'\"\r\n              [customClasses]=\"'px-3'\"\r\n              (mrxClick)=\"createRow()\"\r\n            >Добавить\r\n            </mrx-button>\r\n          </div>\r\n        </dxi-item>\r\n      </dxo-toolbar>\r\n\r\n      <div *dxTemplate=\"let buttonData of 'editButtonTemplate'\">\r\n        <span class=\"mrx-icon icon-edit icon-font-16 cursor-pointer\" (click)=\"editRow(buttonData)\"></span>\r\n      </div>\r\n\r\n      <div *dxTemplate=\"let buttonData of 'deleteButtonTemplate'\">\r\n        <span class=\"mrx-icon icon-delete icon-font-16 cursor-pointer\" (click)=\"deleteRow(buttonData)\"></span>\r\n      </div>\r\n\r\n      @if (dataSource.length) {\r\n        <dxo-summary>\r\n          @for (component of settings.components; track component.id; let first = $first) {\r\n            @if (!first) {\r\n              @if (showTotal(component)) {\r\n                <dxi-total-item\r\n                  [column]=\"component.sysName\"\r\n                  [summaryType]=\"'sum'\"\r\n                  [displayFormat]=\"'{0}'\"\r\n                ></dxi-total-item>\r\n              }\r\n\r\n              @for (component of component.components; track component.id) {\r\n                @if (showTotal(component)) {\r\n                  <dxi-total-item\r\n                    [column]=\"component.sysName\"\r\n                    [summaryType]=\"'sum'\"\r\n                    [displayFormat]=\"'{0}'\"\r\n                  ></dxi-total-item>\r\n                }\r\n\r\n                @for (component of component.components; track component.id) {\r\n                  @if (showTotal(component)) {\r\n                    <dxi-total-item\r\n                      [column]=\"component.sysName\"\r\n                      [summaryType]=\"'sum'\"\r\n                      [displayFormat]=\"'{0}'\"\r\n                    ></dxi-total-item>\r\n                  }\r\n                }\r\n              }\r\n            } @else {\r\n              @if (isTotalColumn(component)) {\r\n                <dxi-total-item [column]=\"component.sysName\" [displayFormat]=\"'{0}'\"></dxi-total-item>\r\n              } @else {\r\n                <dxi-total-item\r\n                  [column]=\"component.sysName\"\r\n                  [cssClass]=\"'text-bold'\"\r\n                  [displayFormat]=\"'ИТОГО'\"\r\n                ></dxi-total-item>\r\n              }\r\n            }\r\n          }\r\n        </dxo-summary>\r\n      }\r\n    </dx-data-grid>\r\n\r\n    <ng-template #editTemplate let-cellInfo=\"cellInfo\">\r\n      <div class=\"d-flex align-items-center justify-content-center\" style=\"gap: 4px\">\r\n        <span class=\"mrx-icon icon-edit icon-font-16 cursor-pointer\" (click)=\"editRow(cellInfo)\"></span>\r\n        <span class=\"mrx-icon icon-delete icon-font-16 cursor-pointer\" (click)=\"deleteRow(cellInfo)\"></span>\r\n      </div>\r\n    </ng-template>\r\n  </div>\r\n}\r\n\r\n\r\n"]}
224
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-table.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/table/input-table.component.ts","../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/table/input-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter, inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ComponentType, DateTypeEnum } from '../../../../../shared-form/enums';\r\nimport { Store } from '@ngrx/store';\r\nimport { ComponentModelBase } from '../../../../../shared-form/models';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { DxDataGridComponent } from 'devextreme-angular';\r\nimport { cloneDeep } from 'lodash-es';\r\nimport { ComponentValueModel, SectionValueModel, TableRowModel, TableValueModel } from '../../../../models';\r\nimport { InputDateModel, InputNumberModel, InputTableModel } from '../../../../models/elemets/inputs';\r\nimport { objectFormActions, objectFormSelectors } from '../../../../store';\r\nimport { ModalService } from '@myrtex-org/ui';\r\nimport { InputTableModalComponent } from './components';\r\nimport { getRowModel } from './helpers/get-row-model.helper';\r\nimport { ColumnModel } from './models/column.model';\r\n\r\n@Component({\r\n  selector: 'app-input-table',\r\n  templateUrl: './input-table.component.html',\r\n  styleUrls: ['./input-table.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class InputTableComponent implements OnInit, OnDestroy {\r\n  type = ComponentType.InputTable;\r\n\r\n  private _store: Store = inject(Store);\r\n  private _detector: ChangeDetectorRef = inject(ChangeDetectorRef);\r\n  private _modalService: ModalService = inject(ModalService);\r\n\r\n  private _changeSubject$: Subject<TableValueModel> = new Subject<TableValueModel>();\r\n  private _subscriptions$: Subscription[] = [];\r\n\r\n  private _isCheckRequired: boolean = false;\r\n\r\n  public model!: TableValueModel;\r\n  public settings!: InputTableModel;\r\n  public dataSource: { [key: string]: any }[] = [\r\n    // { text1: \"Строка 1\", text2: \"Строка A\", date: \"2023-10-01\", textArea: \"Область 1\", text3: \"Текст 1\", numberField: 100, isHidden: false },\r\n    // { text1: \"Строка 2\", text2: \"Строка B\", date: \"2023-10-01\", textArea: \"Область 2\", text3: \"Текст 2\", numberField: 200, isHidden: false },\r\n    // { text1: \"Строка 3\", text2: \"Строка C\", date: \"2023-10-02\", textArea: \"Область 3\", text3: \"Текст 3\", numberField: 300, isHidden: false },\r\n    // { text1: \"Скрытая строка\", text2: \"Строка D\", date: \"2023-10-03\", textArea: \"Область 4\", text3: \"Текст 4\", numberField: 400, isHidden: true } // Новая строка\r\n  ];\r\n  public columns: ColumnModel[] = [\r\n    // { caption: \"Текстовая строка\", dataField: \"text1\" },\r\n    // { caption: \"Текстовая строка\", dataField: \"text2\" },\r\n    // { caption: \"Дата\", dataField: \"date\", dataType: \"date\", format: \"dd.MM.yyyy\", groupIndex: 0 },\r\n    // {\r\n    //   caption: \"Группа полей\",\r\n    //   columns: [\r\n    //     { caption: \"Текстовая область\", dataField: \"textArea\" },\r\n    //     { caption: \"Текстовая строка\", dataField: \"text3\" },\r\n    //     { caption: \"Числовое поле\", dataField: \"numberField\", dataType: \"number\" }\r\n    //   ]\r\n    // }\r\n  ];\r\n\r\n  @Input() values: SectionValueModel[] = [];\r\n\r\n  @Input() set data(settings: ComponentModelBase) {\r\n    this.settings = settings as InputTableModel;\r\n\r\n    this.model = {sysName: settings.sysName, type: settings.type, data: [], totals: []};\r\n\r\n    this._detector.detectChanges();\r\n\r\n    this._initColumns(this.settings.components);\r\n  }\r\n\r\n  @ViewChild('dataGrid', {static: false}) dataGrid!: DxDataGridComponent;\r\n  @ViewChild('editTemplate', {static: false}) editTemplate!: any;\r\n\r\n  @Output() public changed: EventEmitter<ComponentValueModel | ComponentValueModel[]> = new EventEmitter<ComponentValueModel | ComponentValueModel[]>();\r\n\r\n  ngOnInit(): void {\r\n    this._initModel();\r\n\r\n    this._changeSubject$.pipe(\r\n      debounceTime(700),\r\n    ).subscribe(model => {\r\n      this._store.dispatch(objectFormActions.updateValues({value: model}));\r\n    });\r\n\r\n    this._subscriptions$.push(this._store.select(objectFormSelectors.selectIsCheckRequired).subscribe(result => {\r\n      this._isCheckRequired = result;\r\n      this._detector.detectChanges();\r\n    }));\r\n\r\n    this._subscriptions$.push(this._store.select(objectFormSelectors.selectValueModel(this.settings))\r\n      .subscribe((result: ComponentValueModel | null | (ComponentValueModel | null)[]) => {\r\n        const cloneResult = cloneDeep(result as TableValueModel | null);\r\n\r\n        if (cloneResult && !Array.isArray(cloneResult) && this.model.data !== cloneResult.data) {\r\n          this.model = cloneResult;\r\n          this._initDataSource(this.model.data);\r\n        }\r\n      }));\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._changeSubject$.unsubscribe();\r\n    this._subscriptions$.forEach((subscription) => subscription.unsubscribe());\r\n  }\r\n\r\n  public createRow() {\r\n    this._modalService.open(InputTableModalComponent, {\r\n      title: 'Создание строки',\r\n      okText: 'Создать',\r\n      settings: this.settings,\r\n      rowModel: getRowModel(this.settings)\r\n    }).afterClosed().subscribe(resolve => {\r\n      if (resolve.result) {\r\n        this.model.data = [...this.model.data, resolve.rowModel];\r\n\r\n        this._initDataSource(this.model.data);\r\n\r\n        this._changeSubject$.next(this.model);\r\n      }\r\n    });\r\n  }\r\n\r\n  public deleteRow(event: any) {\r\n    const findRow = this.model.data.find(item => item.id === event.row.data.id);\r\n\r\n    if (findRow) {\r\n      this.model.data = this.model.data.filter(item => item.id !== event.row.data.id);\r\n\r\n      this._initDataSource(this.model.data);\r\n\r\n      this._changeSubject$.next(this.model);\r\n    }\r\n  }\r\n\r\n  public editRow(event: any) {\r\n    const findRow: TableRowModel | undefined = this.model.data.find(item => item.id === event.row.data.id);\r\n\r\n    if (findRow) {\r\n      this._modalService.open(InputTableModalComponent, {\r\n        title: 'Редактирование строки',\r\n        okText: 'Сохранить',\r\n        settings: this.settings,\r\n        rowModel: findRow\r\n      }).afterClosed().subscribe(resolve => {\r\n        if (resolve.result) {\r\n          const cloneModel = cloneDeep(this.model);\r\n          const findRow = cloneModel.data.find(row => row.id === resolve.rowModel.id);\r\n\r\n          if (findRow) {\r\n            findRow.data = resolve.rowModel.data;\r\n\r\n            this._changeSubject$.next(cloneModel);\r\n          }\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public getFormat(component: ComponentModelBase) {\r\n    switch (component.type) {\r\n      case ComponentType.InputDate:\r\n        switch ((component as InputDateModel).options.viewType) {\r\n          case DateTypeEnum.DateTime:\r\n            return 'dd.MM.yyyy hh:mm';\r\n          default:\r\n            return 'dd.MM.yyyy';\r\n        }\r\n      default:\r\n        return '';\r\n    }\r\n  }\r\n\r\n  public getDataType(component: ComponentModelBase) {\r\n    switch (component.type) {\r\n      case ComponentType.InputDate:\r\n        return 'date';\r\n      default:\r\n        return undefined;\r\n    }\r\n  }\r\n\r\n  public showTotal(component: ComponentModelBase): boolean {\r\n    if (component.type === ComponentType.InputNumber) {\r\n      const element: InputNumberModel = component as InputNumberModel;\r\n\r\n      return element.options.inTotals;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  public isTotalColumn(component: ComponentModelBase): boolean {\r\n    return (component as InputNumberModel).options['inTotals'];\r\n  }\r\n\r\n  private _initModel() {\r\n    this.model = {\r\n      sysName: this.settings.sysName,\r\n      type: this.settings.type,\r\n      data: [],\r\n      totals: []\r\n    };\r\n  }\r\n\r\n  private _initDataSource(data: TableRowModel[]) {\r\n    this.dataSource = data.map((item: TableRowModel) => {\r\n      const newDataItem: any = {};\r\n\r\n      for (let i in item.data) {\r\n        newDataItem[item.data[i].sysName] = item.data[i].value;\r\n      }\r\n\r\n      newDataItem.id = item.id;\r\n\r\n      return newDataItem;\r\n    });\r\n\r\n    this._detector.detectChanges();\r\n\r\n    this.dataGrid.instance.refresh();\r\n  }\r\n\r\n  private _initColumns(components: ComponentModelBase[]) {\r\n    this.columns = components.map(c => this._transformColumn(structuredClone(c)));\r\n\r\n    this.columns.push({\r\n      caption: '',\r\n      type: 'buttons',\r\n      width: 80,\r\n      cssClass: 'custom-cell-controls',\r\n      buttons: [\r\n        {\r\n          template: 'editButtonTemplate',\r\n          hint: 'Редактировать',\r\n        },\r\n        {\r\n          template: 'deleteButtonTemplate',\r\n          hint: 'Удалить',\r\n        },\r\n      ],\r\n    });\r\n\r\n    this.dataGrid.instance.repaint();\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  private _transformColumn(component: ComponentModelBase): ColumnModel {\r\n    const column: ColumnModel = {\r\n      caption: component.options.label || '',\r\n      columns: component.components.map(c => this._transformColumn(structuredClone(c))),\r\n      dataField: component.sysName,\r\n      dataType: this.getDataType(component),\r\n      format: this.getFormat(component),\r\n    }\r\n\r\n    if (this.settings.options.groups.length) {\r\n      const findIdx = this.settings.options.groups.findIndex(x => x === component.sysName);\r\n\r\n      if (findIdx !== -1) {\r\n        column.groupIndex = findIdx\r\n      }\r\n    }\r\n\r\n    return column\r\n  }\r\n}\r\n","@if (settings) {\r\n  <div class=\"input-table-content w-100\">\r\n    @if (settings.options.label) {\r\n      <mrx-label\r\n        [required]=\"settings.options.required\"\r\n        [tooltip]=\"settings.options.tooltip || ''\"\r\n        [customClasses]=\"'mt-2'\"\r\n      >\r\n        {{ settings.options.label }}\r\n      </mrx-label>\r\n    }\r\n\r\n    <dx-data-grid\r\n      #dataGrid\r\n      [dataSource]=\"dataSource\"\r\n      [columns]=\"columns\"\r\n      noDataText=\"Нет данных\"\r\n      style=\"width: 100%\"\r\n    >\r\n      <dxo-toolbar>\r\n        <dxi-item location=\"after\">\r\n          <div *dxTemplate class=\"add-row\">\r\n            <mrx-button\r\n              [size]=\"'medium'\"\r\n              [type]=\"'tertiary'\"\r\n              [customClasses]=\"'px-3'\"\r\n              (mrxClick)=\"createRow()\"\r\n            >Добавить\r\n            </mrx-button>\r\n          </div>\r\n        </dxi-item>\r\n      </dxo-toolbar>\r\n\r\n      <div *dxTemplate=\"let buttonData of 'editButtonTemplate'\">\r\n        <span class=\"mrx-icon icon-edit icon-font-16 cursor-pointer\" (click)=\"editRow(buttonData)\"></span>\r\n      </div>\r\n\r\n      <div *dxTemplate=\"let buttonData of 'deleteButtonTemplate'\">\r\n        <span class=\"mrx-icon icon-delete icon-font-16 cursor-pointer\" (click)=\"deleteRow(buttonData)\"></span>\r\n      </div>\r\n\r\n      @if (dataSource.length) {\r\n        <dxo-summary>\r\n          @for (component of settings.components; track component.id; let first = $first) {\r\n            @if (!first) {\r\n              @if (showTotal(component)) {\r\n                <dxi-total-item\r\n                  [column]=\"component.sysName\"\r\n                  [summaryType]=\"'sum'\"\r\n                  [displayFormat]=\"'{0}'\"\r\n                ></dxi-total-item>\r\n              }\r\n\r\n              @for (component of component.components; track component.id) {\r\n                @if (showTotal(component)) {\r\n                  <dxi-total-item\r\n                    [column]=\"component.sysName\"\r\n                    [summaryType]=\"'sum'\"\r\n                    [displayFormat]=\"'{0}'\"\r\n                  ></dxi-total-item>\r\n                }\r\n\r\n                @for (component of component.components; track component.id) {\r\n                  @if (showTotal(component)) {\r\n                    <dxi-total-item\r\n                      [column]=\"component.sysName\"\r\n                      [summaryType]=\"'sum'\"\r\n                      [displayFormat]=\"'{0}'\"\r\n                    ></dxi-total-item>\r\n                  }\r\n                }\r\n              }\r\n            } @else {\r\n              @if (isTotalColumn(component)) {\r\n                <dxi-total-item [column]=\"component.sysName\" [displayFormat]=\"'{0}'\"></dxi-total-item>\r\n              } @else {\r\n                <dxi-total-item\r\n                  [column]=\"component.sysName\"\r\n                  [cssClass]=\"'text-bold'\"\r\n                  [displayFormat]=\"'ИТОГО'\"\r\n                ></dxi-total-item>\r\n              }\r\n            }\r\n          }\r\n        </dxo-summary>\r\n      }\r\n    </dx-data-grid>\r\n\r\n    <ng-template #editTemplate let-cellInfo=\"cellInfo\">\r\n      <div class=\"d-flex align-items-center justify-content-center\" style=\"gap: 4px\">\r\n        <span class=\"mrx-icon icon-edit icon-font-16 cursor-pointer\" (click)=\"editRow(cellInfo)\"></span>\r\n        <span class=\"mrx-icon icon-delete icon-font-16 cursor-pointer\" (click)=\"deleteRow(cellInfo)\"></span>\r\n      </div>\r\n    </ng-template>\r\n  </div>\r\n}\r\n\r\n\r\n"]}
@@ -8,12 +8,21 @@ export class InputTextComponent extends BaseFieldComponent {
8
8
  constructor() {
9
9
  super(...arguments);
10
10
  this.type = ComponentType.InputText;
11
+ this.validateValue = '';
12
+ }
13
+ onChangeInput() {
14
+ this.validateValue = this.model.value;
15
+ }
16
+ _customValidate(model) {
17
+ this.validateValue = model.value;
18
+ this._detector.markForCheck();
19
+ return !(this.settings.options.minLength && model.value && this.settings.options.minLength > model.value.length);
11
20
  }
12
21
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputTextComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
13
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: InputTextComponent, selector: "app-input-text", usesInheritance: true, ngImport: i0, template: "@if (settings) {\r\n <div class=\"input-text-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 [customClasses]=\"'mt-2'\"\r\n >\r\n {{ settings.options.label }}\r\n </mrx-label>\r\n }\r\n\r\n <mrx-input-text\r\n [(ngModel)]=\"model.value\"\r\n [fields]=\"autosaveFields\"\r\n [readonly]=\"false\"\r\n [placeholder]=\"settings.options.placeholder || ''\"\r\n [mask]=\"settings.options.mask || ''\"\r\n [showMaskTyped]=\"true\"\r\n [minlength]=\"settings.options.minLength || 0\"\r\n [maxlength]=\"settings.options.maxLength || 0\"\r\n [invalid]=\"getInvalid\"\r\n [invalidMessage]=\"getInvalidMessage\"\r\n (modelChange)=\"dispatchModify($event)\"\r\n ></mrx-input-text>\r\n </div>\r\n}\r\n", styles: [""], dependencies: [{ kind: "component", type: i1.InputTextComponent, selector: "mrx-input-text", inputs: ["fields", "disabled", "required", "readonly", "maxlength", "minlength", "placeholder", "invalid", "invalidMessage", "checkInvalid", "customClasses", "size", "isTooltipValue", "icon", "iconColor", "mask", "maskPrefix", "showMaskTyped", "maskDropSpecialCharacters"], outputs: ["changed", "modelChange"] }, { kind: "component", type: i1.LabelComponent, selector: "mrx-label", inputs: ["requiredHidden", "required", "boldLabel", "disabled", "placeholder", "label", "customClasses", "triggerTextPosition", "isPublicInfo", "publicInfoTooltip", "isSwitch", "switchLabel", "switchValue", "isCheckbox", "checkboxLabel", "checkboxValue", "counter", "linkText", "linkPrevent", "linkType", "linkMonochrome", "href", "triggerType", "tooltip", "tooltipInitialVisible", "isSaveToStorage"], outputs: ["changeSwitchValue", "changeCheckboxValue", "clickedLink"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: ["minlength"] }, { kind: "directive", type: i2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
22
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: InputTextComponent, selector: "app-input-text", usesInheritance: true, ngImport: i0, template: "@if (settings) {\r\n <div class=\"input-text-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 [customClasses]=\"'mt-2'\"\r\n >\r\n {{ settings.options.label }}\r\n </mrx-label>\r\n }\r\n\r\n <mrx-input-text\r\n [(ngModel)]=\"model.value\"\r\n [fields]=\"autosaveFields\"\r\n [readonly]=\"false\"\r\n [placeholder]=\"settings.options.placeholder || ''\"\r\n [mask]=\"settings.options.mask || ''\"\r\n [showMaskTyped]=\"true\"\r\n [minlength]=\"settings.options.minLength || 0\"\r\n [maxlength]=\"settings.options.maxLength || 0\"\r\n [invalid]=\"getInvalid\"\r\n [invalidMessage]=\"getInvalidMessage\"\r\n (modelChange)=\"dispatchModify($event)\"\r\n (change)=\"onChangeInput()\"\r\n ></mrx-input-text>\r\n\r\n @if (settings.options.minLength) {\r\n <mrx-hint-error-message\r\n message=\"\u041C\u0438\u043D\u0438\u043C\u0430\u043B\u044C\u043D\u043E\u0435 \u043A\u043E\u043B\u0438\u0447\u0435\u0442\u0441\u0432\u043E \u0441\u0438\u043C\u0432\u043E\u043B\u043E\u0432 \u2014 {{ settings.options.minLength }}\"\r\n [value]=\"validateValue\"\r\n [minLength]=\"settings.options.minLength\"\r\n ></mrx-hint-error-message>\r\n }\r\n </div>\r\n}\r\n", styles: [""], dependencies: [{ kind: "component", type: i1.InputTextComponent, selector: "mrx-input-text", inputs: ["fields", "disabled", "required", "readonly", "maxlength", "minlength", "placeholder", "invalid", "invalidMessage", "checkInvalid", "customClasses", "size", "isTooltipValue", "icon", "iconColor", "mask", "maskPrefix", "showMaskTyped", "maskDropSpecialCharacters"], outputs: ["changed", "modelChange"] }, { kind: "component", type: i1.LabelComponent, selector: "mrx-label", inputs: ["requiredHidden", "required", "boldLabel", "disabled", "placeholder", "label", "customClasses", "triggerTextPosition", "isPublicInfo", "publicInfoTooltip", "isSwitch", "switchLabel", "switchValue", "isCheckbox", "checkboxLabel", "checkboxValue", "counter", "linkText", "linkPrevent", "linkType", "linkMonochrome", "href", "triggerType", "tooltip", "tooltipInitialVisible", "isSaveToStorage"], outputs: ["changeSwitchValue", "changeCheckboxValue", "clickedLink"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: ["minlength"] }, { kind: "directive", type: i2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i1.HintErrorMessageComponent, selector: "mrx-hint-error-message", inputs: ["message", "value", "maxValue", "minValue", "minLength", "maxLength", "checkInvalid"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
14
23
  }
15
24
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputTextComponent, decorators: [{
16
25
  type: Component,
17
- args: [{ selector: 'app-input-text', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (settings) {\r\n <div class=\"input-text-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 [customClasses]=\"'mt-2'\"\r\n >\r\n {{ settings.options.label }}\r\n </mrx-label>\r\n }\r\n\r\n <mrx-input-text\r\n [(ngModel)]=\"model.value\"\r\n [fields]=\"autosaveFields\"\r\n [readonly]=\"false\"\r\n [placeholder]=\"settings.options.placeholder || ''\"\r\n [mask]=\"settings.options.mask || ''\"\r\n [showMaskTyped]=\"true\"\r\n [minlength]=\"settings.options.minLength || 0\"\r\n [maxlength]=\"settings.options.maxLength || 0\"\r\n [invalid]=\"getInvalid\"\r\n [invalidMessage]=\"getInvalidMessage\"\r\n (modelChange)=\"dispatchModify($event)\"\r\n ></mrx-input-text>\r\n </div>\r\n}\r\n" }]
26
+ args: [{ selector: 'app-input-text', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (settings) {\r\n <div class=\"input-text-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 [customClasses]=\"'mt-2'\"\r\n >\r\n {{ settings.options.label }}\r\n </mrx-label>\r\n }\r\n\r\n <mrx-input-text\r\n [(ngModel)]=\"model.value\"\r\n [fields]=\"autosaveFields\"\r\n [readonly]=\"false\"\r\n [placeholder]=\"settings.options.placeholder || ''\"\r\n [mask]=\"settings.options.mask || ''\"\r\n [showMaskTyped]=\"true\"\r\n [minlength]=\"settings.options.minLength || 0\"\r\n [maxlength]=\"settings.options.maxLength || 0\"\r\n [invalid]=\"getInvalid\"\r\n [invalidMessage]=\"getInvalidMessage\"\r\n (modelChange)=\"dispatchModify($event)\"\r\n (change)=\"onChangeInput()\"\r\n ></mrx-input-text>\r\n\r\n @if (settings.options.minLength) {\r\n <mrx-hint-error-message\r\n message=\"\u041C\u0438\u043D\u0438\u043C\u0430\u043B\u044C\u043D\u043E\u0435 \u043A\u043E\u043B\u0438\u0447\u0435\u0442\u0441\u0432\u043E \u0441\u0438\u043C\u0432\u043E\u043B\u043E\u0432 \u2014 {{ settings.options.minLength }}\"\r\n [value]=\"validateValue\"\r\n [minLength]=\"settings.options.minLength\"\r\n ></mrx-hint-error-message>\r\n }\r\n </div>\r\n}\r\n" }]
18
27
  }] });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtdGV4dC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0ZXgtZm9ybS9zcmMvbGliL21vZHVsZXMvb2JqZWN0LWZvcm0vY29tcG9uZW50cy9lbGVtZW50cy9pbnB1dC90ZXh0L2lucHV0LXRleHQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGV4LWZvcm0vc3JjL2xpYi9tb2R1bGVzL29iamVjdC1mb3JtL2NvbXBvbmVudHMvZWxlbWVudHMvaW5wdXQvdGV4dC9pbnB1dC10ZXh0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQXFCLE1BQU0sZUFBZSxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxZQUFZLENBQUM7Ozs7QUFVaEQsTUFBTSxPQUFPLGtCQUFtQixTQUFRLGtCQUF3RDtJQU5oRzs7UUFPRSxTQUFJLEdBQUcsYUFBYSxDQUFDLFNBQVMsQ0FBQztLQUNoQzsrR0FGWSxrQkFBa0I7bUdBQWxCLGtCQUFrQiw2RUNaL0IsZzVCQTJCQTs7NEZEZmEsa0JBQWtCO2tCQU45QixTQUFTOytCQUNFLGdCQUFnQixtQkFHVCx1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25EZXN0cm95LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tcG9uZW50VHlwZSB9IGZyb20gJy4uLy4uLy4uLy4uLy4uL3NoYXJlZC1mb3JtL2VudW1zJztcclxuaW1wb3J0IHsgQmFzZUZpZWxkQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYmFzZSc7XHJcbmltcG9ydCB7IElucHV0VGV4dE1vZGVsIH0gZnJvbSAnLi4vLi4vLi4vLi4vbW9kZWxzL2VsZW1ldHMvaW5wdXRzJztcclxuaW1wb3J0IHsgSW5wdXRUZXh0VmFsdWVXaXRoSWQgfSBmcm9tICdAbXlydGV4LW9yZy91aSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC1pbnB1dC10ZXh0JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vaW5wdXQtdGV4dC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vaW5wdXQtdGV4dC5jb21wb25lbnQubGVzcyddLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBJbnB1dFRleHRDb21wb25lbnQgZXh0ZW5kcyBCYXNlRmllbGRDb21wb25lbnQ8SW5wdXRUZXh0TW9kZWwsIElucHV0VGV4dFZhbHVlV2l0aElkPiBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcclxuICB0eXBlID0gQ29tcG9uZW50VHlwZS5JbnB1dFRleHQ7XHJcbn1cclxuIiwiQGlmIChzZXR0aW5ncykge1xyXG4gIDxkaXYgY2xhc3M9XCJpbnB1dC10ZXh0LWNvbnRlbnRcIj5cclxuICAgIEBpZiAoc2V0dGluZ3Mub3B0aW9ucy5sYWJlbCkge1xyXG4gICAgICA8bXJ4LWxhYmVsXHJcbiAgICAgICAgW3JlcXVpcmVkXT1cInNldHRpbmdzLm9wdGlvbnMucmVxdWlyZWRcIlxyXG4gICAgICAgIFt0b29sdGlwXT1cInNldHRpbmdzLm9wdGlvbnMudG9vbHRpcCB8fCAnJ1wiXHJcbiAgICAgICAgW2N1c3RvbUNsYXNzZXNdPVwiJ210LTInXCJcclxuICAgICAgPlxyXG4gICAgICAgIHt7IHNldHRpbmdzLm9wdGlvbnMubGFiZWwgfX1cclxuICAgICAgPC9tcngtbGFiZWw+XHJcbiAgICB9XHJcblxyXG4gICAgPG1yeC1pbnB1dC10ZXh0XHJcbiAgICAgIFsobmdNb2RlbCldPVwibW9kZWwudmFsdWVcIlxyXG4gICAgICBbZmllbGRzXT1cImF1dG9zYXZlRmllbGRzXCJcclxuICAgICAgW3JlYWRvbmx5XT1cImZhbHNlXCJcclxuICAgICAgW3BsYWNlaG9sZGVyXT1cInNldHRpbmdzLm9wdGlvbnMucGxhY2Vob2xkZXIgfHwgJydcIlxyXG4gICAgICBbbWFza109XCJzZXR0aW5ncy5vcHRpb25zLm1hc2sgfHwgJydcIlxyXG4gICAgICBbc2hvd01hc2tUeXBlZF09XCJ0cnVlXCJcclxuICAgICAgW21pbmxlbmd0aF09XCJzZXR0aW5ncy5vcHRpb25zLm1pbkxlbmd0aCB8fCAwXCJcclxuICAgICAgW21heGxlbmd0aF09XCJzZXR0aW5ncy5vcHRpb25zLm1heExlbmd0aCB8fCAwXCJcclxuICAgICAgW2ludmFsaWRdPVwiZ2V0SW52YWxpZFwiXHJcbiAgICAgIFtpbnZhbGlkTWVzc2FnZV09XCJnZXRJbnZhbGlkTWVzc2FnZVwiXHJcbiAgICAgIChtb2RlbENoYW5nZSk9XCJkaXNwYXRjaE1vZGlmeSgkZXZlbnQpXCJcclxuICAgID48L21yeC1pbnB1dC10ZXh0PlxyXG4gIDwvZGl2PlxyXG59XHJcbiJdfQ==
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtdGV4dC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0ZXgtZm9ybS9zcmMvbGliL21vZHVsZXMvb2JqZWN0LWZvcm0vY29tcG9uZW50cy9lbGVtZW50cy9pbnB1dC90ZXh0L2lucHV0LXRleHQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGV4LWZvcm0vc3JjL2xpYi9tb2R1bGVzL29iamVjdC1mb3JtL2NvbXBvbmVudHMvZWxlbWVudHMvaW5wdXQvdGV4dC9pbnB1dC10ZXh0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQXFCLE1BQU0sZUFBZSxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxZQUFZLENBQUM7Ozs7QUFXaEQsTUFBTSxPQUFPLGtCQUFtQixTQUFRLGtCQUF3RDtJQU5oRzs7UUFPRSxTQUFJLEdBQUcsYUFBYSxDQUFDLFNBQVMsQ0FBQztRQUV4QixrQkFBYSxHQUFHLEVBQUUsQ0FBQTtLQWExQjtJQVhRLGFBQWE7UUFDbEIsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQTtJQUN2QyxDQUFDO0lBRVEsZUFBZSxDQUFDLEtBQTBCO1FBQ2pELElBQUksQ0FBQyxhQUFhLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQTtRQUVoQyxJQUFJLENBQUMsU0FBUyxDQUFDLFlBQVksRUFBRSxDQUFBO1FBRTdCLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLFNBQVMsSUFBSSxLQUFLLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ25ILENBQUM7K0dBZlUsa0JBQWtCO21HQUFsQixrQkFBa0IsNkVDYi9CLDYzQ0FvQ0E7OzRGRHZCYSxrQkFBa0I7a0JBTjlCLFNBQVM7K0JBQ0UsZ0JBQWdCLG1CQUdULHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkRlc3Ryb3ksIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21wb25lbnRUeXBlIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vc2hhcmVkLWZvcm0vZW51bXMnO1xyXG5pbXBvcnQgeyBCYXNlRmllbGRDb21wb25lbnQgfSBmcm9tICcuLi8uLi9iYXNlJztcclxuaW1wb3J0IHsgSW5wdXRUZXh0TW9kZWwgfSBmcm9tICcuLi8uLi8uLi8uLi9tb2RlbHMvZWxlbWV0cy9pbnB1dHMnO1xyXG5pbXBvcnQgeyBJbnB1dFRleHRWYWx1ZVdpdGhJZCB9IGZyb20gJ0BteXJ0ZXgtb3JnL3VpJztcclxuaW1wb3J0IHsgQ29tcG9uZW50VmFsdWVNb2RlbCB9IGZyb20gJy4uLy4uLy4uLy4uL21vZGVscyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC1pbnB1dC10ZXh0JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vaW5wdXQtdGV4dC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vaW5wdXQtdGV4dC5jb21wb25lbnQubGVzcyddLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBJbnB1dFRleHRDb21wb25lbnQgZXh0ZW5kcyBCYXNlRmllbGRDb21wb25lbnQ8SW5wdXRUZXh0TW9kZWwsIElucHV0VGV4dFZhbHVlV2l0aElkPiBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcclxuICB0eXBlID0gQ29tcG9uZW50VHlwZS5JbnB1dFRleHQ7XHJcblxyXG4gIHB1YmxpYyB2YWxpZGF0ZVZhbHVlID0gJydcclxuXHJcbiAgcHVibGljIG9uQ2hhbmdlSW5wdXQoKSB7XHJcbiAgICB0aGlzLnZhbGlkYXRlVmFsdWUgPSB0aGlzLm1vZGVsLnZhbHVlXHJcbiAgfVxyXG5cclxuICBvdmVycmlkZSBfY3VzdG9tVmFsaWRhdGUobW9kZWw6IENvbXBvbmVudFZhbHVlTW9kZWwpIHtcclxuICAgIHRoaXMudmFsaWRhdGVWYWx1ZSA9IG1vZGVsLnZhbHVlXHJcblxyXG4gICAgdGhpcy5fZGV0ZWN0b3IubWFya0ZvckNoZWNrKClcclxuXHJcbiAgICByZXR1cm4gISh0aGlzLnNldHRpbmdzLm9wdGlvbnMubWluTGVuZ3RoICYmIG1vZGVsLnZhbHVlICYmIHRoaXMuc2V0dGluZ3Mub3B0aW9ucy5taW5MZW5ndGggPiBtb2RlbC52YWx1ZS5sZW5ndGgpO1xyXG4gIH1cclxufVxyXG4iLCJAaWYgKHNldHRpbmdzKSB7XHJcbiAgPGRpdiBjbGFzcz1cImlucHV0LXRleHQtY29udGVudFwiPlxyXG4gICAgQGlmIChzZXR0aW5ncy5vcHRpb25zLmxhYmVsKSB7XHJcbiAgICAgIDxtcngtbGFiZWxcclxuICAgICAgICBbcmVxdWlyZWRdPVwic2V0dGluZ3Mub3B0aW9ucy5yZXF1aXJlZFwiXHJcbiAgICAgICAgW3Rvb2x0aXBdPVwic2V0dGluZ3Mub3B0aW9ucy50b29sdGlwIHx8ICcnXCJcclxuICAgICAgICBbY3VzdG9tQ2xhc3Nlc109XCInbXQtMidcIlxyXG4gICAgICA+XHJcbiAgICAgICAge3sgc2V0dGluZ3Mub3B0aW9ucy5sYWJlbCB9fVxyXG4gICAgICA8L21yeC1sYWJlbD5cclxuICAgIH1cclxuXHJcbiAgICA8bXJ4LWlucHV0LXRleHRcclxuICAgICAgWyhuZ01vZGVsKV09XCJtb2RlbC52YWx1ZVwiXHJcbiAgICAgIFtmaWVsZHNdPVwiYXV0b3NhdmVGaWVsZHNcIlxyXG4gICAgICBbcmVhZG9ubHldPVwiZmFsc2VcIlxyXG4gICAgICBbcGxhY2Vob2xkZXJdPVwic2V0dGluZ3Mub3B0aW9ucy5wbGFjZWhvbGRlciB8fCAnJ1wiXHJcbiAgICAgIFttYXNrXT1cInNldHRpbmdzLm9wdGlvbnMubWFzayB8fCAnJ1wiXHJcbiAgICAgIFtzaG93TWFza1R5cGVkXT1cInRydWVcIlxyXG4gICAgICBbbWlubGVuZ3RoXT1cInNldHRpbmdzLm9wdGlvbnMubWluTGVuZ3RoIHx8IDBcIlxyXG4gICAgICBbbWF4bGVuZ3RoXT1cInNldHRpbmdzLm9wdGlvbnMubWF4TGVuZ3RoIHx8IDBcIlxyXG4gICAgICBbaW52YWxpZF09XCJnZXRJbnZhbGlkXCJcclxuICAgICAgW2ludmFsaWRNZXNzYWdlXT1cImdldEludmFsaWRNZXNzYWdlXCJcclxuICAgICAgKG1vZGVsQ2hhbmdlKT1cImRpc3BhdGNoTW9kaWZ5KCRldmVudClcIlxyXG4gICAgICAoY2hhbmdlKT1cIm9uQ2hhbmdlSW5wdXQoKVwiXHJcbiAgICA+PC9tcngtaW5wdXQtdGV4dD5cclxuXHJcbiAgICBAaWYgKHNldHRpbmdzLm9wdGlvbnMubWluTGVuZ3RoKSB7XHJcbiAgICAgIDxtcngtaGludC1lcnJvci1tZXNzYWdlXHJcbiAgICAgICAgbWVzc2FnZT1cItCc0LjQvdC40LzQsNC70YzQvdC+0LUg0LrQvtC70LjRh9C10YLRgdCy0L4g0YHQuNC80LLQvtC70L7QsiDigJQge3sgc2V0dGluZ3Mub3B0aW9ucy5taW5MZW5ndGggfX1cIlxyXG4gICAgICAgIFt2YWx1ZV09XCJ2YWxpZGF0ZVZhbHVlXCJcclxuICAgICAgICBbbWluTGVuZ3RoXT1cInNldHRpbmdzLm9wdGlvbnMubWluTGVuZ3RoXCJcclxuICAgICAgPjwvbXJ4LWhpbnQtZXJyb3ItbWVzc2FnZT5cclxuICAgIH1cclxuICA8L2Rpdj5cclxufVxyXG4iXX0=