@myrtex-org/form 1.1.14 → 1.1.16

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.
@@ -12,6 +12,7 @@ export class InputDateComponent extends BaseFieldComponent {
12
12
  this.type = ComponentType.InputDate;
13
13
  this._millisecondsInDay = 1000 * 60 * 60 * 24;
14
14
  this._isInit = false;
15
+ this._isUpdatingInternal = false;
15
16
  this.dateModel = '';
16
17
  this.modelCounter = 0;
17
18
  }
@@ -37,27 +38,29 @@ export class InputDateComponent extends BaseFieldComponent {
37
38
  }
38
39
  updateValue(event) {
39
40
  if (this._isInit) {
41
+ this._isUpdatingInternal = true; // Блокируем внешние обновления на время ввода
40
42
  if (this.settings.options.range) {
41
43
  if (!event.value || event.value.length === 0) {
42
- this.dateModel = []; // Локальное обновление для UI
44
+ this.dateModel = [];
43
45
  this.modelStart.value = null;
44
46
  this.modelEnd.value = null;
45
- this.model.value = [null, null];
46
47
  this.modelCounter = 0;
47
48
  }
48
49
  else if (event.value.length === 2) {
49
- this.dateModel = [event.value[0], event.value[1]]; // Локальное обновление для UI
50
+ this.dateModel = [event.value[0], event.value[1]];
50
51
  this.modelStart.value = event.value[0];
51
52
  this.modelEnd.value = event.value[1];
52
- this.model.value = [this.modelStart.value, this.modelEnd.value];
53
53
  this.modelCounter = this._getDaysDifference(this.modelStart.value, this.modelEnd.value);
54
54
  }
55
+ this.model.value = this.dateModel;
55
56
  }
56
57
  else {
57
58
  this.dateModel = event.value;
58
59
  this.model.value = event.value;
59
60
  }
60
61
  this.dispatchModify(event);
62
+ // Снимаем блокировку чуть позже, когда Store переварит изменения
63
+ setTimeout(() => this._isUpdatingInternal = false, 600);
61
64
  }
62
65
  }
63
66
  updateCounter(value) {
@@ -92,42 +95,52 @@ export class InputDateComponent extends BaseFieldComponent {
92
95
  _initSubscriptionForValue() {
93
96
  this._subscriptions$.push(this._store.select(objectFormSelectors.selectValueModel(this.settings))
94
97
  .subscribe((result) => {
95
- if (result) {
96
- if (Array.isArray(result)) {
97
- this.modelStart = structuredClone(result[0]) || defaultValueModel(this.settings);
98
- this.modelEnd = structuredClone(result[1]) || defaultValueModel(this.settings);
99
- }
100
- else {
101
- this.model = structuredClone(result || defaultValueModel(this.settings));
98
+ if (!result || this._isUpdatingInternal)
99
+ return;
100
+ // Если компонент уже инициализирован, проверяем, нужно ли обновляться.
101
+ // Мы НЕ обновляемся, если данные в Store идентичны тем, что мы уже держим в памяти.
102
+ if (this._isInit) {
103
+ const newValue = Array.isArray(result)
104
+ ? JSON.stringify([result[0]?.value, result[1]?.value])
105
+ : JSON.stringify(result.value);
106
+ const currentValue = this.settings.options.range
107
+ ? JSON.stringify([this.modelStart?.value, this.modelEnd?.value])
108
+ : JSON.stringify(this.model?.value);
109
+ if (newValue === currentValue) {
110
+ return; // Данные те же самые, выходим, чтобы не запускать таймер заново
102
111
  }
103
- this._customInit();
104
112
  }
113
+ // Если данные реально новые (пришли извне), обновляем локальные модели
114
+ if (Array.isArray(result)) {
115
+ this.modelStart = structuredClone(result[0]) || defaultValueModel(this.settings);
116
+ this.modelEnd = structuredClone(result[1]) || defaultValueModel(this.settings);
117
+ }
118
+ else {
119
+ this.model = structuredClone(result || defaultValueModel(this.settings));
120
+ }
121
+ this._customInit();
105
122
  }));
106
123
  }
107
124
  _customInit() {
108
- // Уменьшаем задержку, чтобы инициализация была быстрее
109
- setTimeout(() => {
110
- if (!this.model) {
111
- this.model = defaultValueModel(this.settings);
112
- }
113
- if (this.settings.options.range) {
114
- // Синхронизируем UI с моделями из Store
115
- if (this.modelStart?.value && this.modelEnd?.value) {
116
- this.dateModel = [this.modelStart.value, this.modelEnd.value];
117
- this.modelCounter = this._getDaysDifference(this.modelStart.value, this.modelEnd.value);
118
- }
119
- else {
120
- // Если в Store реально пусто, только тогда чистим UI
121
- this.dateModel = [];
122
- this.modelCounter = 0;
123
- }
125
+ if (!this.model) {
126
+ this.model = defaultValueModel(this.settings);
127
+ }
128
+ if (this.settings.options.range) {
129
+ if (this.modelStart?.value && this.modelEnd?.value) {
130
+ this.dateModel = [this.modelStart.value, this.modelEnd.value];
131
+ this.modelCounter = this._getDaysDifference(this.modelStart.value, this.modelEnd.value);
124
132
  }
125
- else {
126
- this.dateModel = this.model.value;
133
+ else if (!this.modelStart?.value && !this.modelEnd?.value) {
134
+ // Очищаем только если в Store реально пусто
135
+ this.dateModel = [];
136
+ this.modelCounter = 0;
127
137
  }
128
- this._isInit = true;
129
- this._detector.detectChanges();
130
- }, 100); // 100мс достаточно
138
+ }
139
+ else {
140
+ this.dateModel = this.model.value;
141
+ }
142
+ this._isInit = true;
143
+ this._detector.markForCheck();
131
144
  }
132
145
  _getDaysDifference(startDate, endDate) {
133
146
  const start = new Date(startDate);
@@ -168,4 +181,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
168
181
  type: Component,
169
182
  args: [{ selector: 'app-input-date', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (settings) {\r\n <div class=\"input-date-content\">\r\n <div class=\"row\">\r\n <div class=\"col\" [class.col-8]=\"settings.options.counter\">\r\n @if (settings.options.label) {\r\n <mrx-label\r\n [required]=\"settings.options.required\"\r\n [tooltip]=\"settings.options.tooltip || ''\"\r\n >\r\n {{ settings.options.label }}\r\n </mrx-label>\r\n }\r\n\r\n <mrx-input-date-time\r\n [dateFormat]=\"settings.options.format\"\r\n [ngModel]=\"dateModel\"\r\n [fields]=\"autosaveFields\"\r\n [range]=\"settings.options.range\"\r\n [datePlaceholder]=\"(settings.options.range ? settings.options.placeholder + ' - ' + settings.options.placeholder : settings.options.placeholder) || ''\"\r\n [isManualInput]=\"!settings.options.range\"\r\n [timepicker]=\"getViewTypeTimepicker\"\r\n [invalid]=\"getInvalid\"\r\n [invalidMessage]=\"getInvalidMessage\"\r\n [minDate]=\"settings.options.minDate\"\r\n [maxDate]=\"settings.options.maxDate\"\r\n [disabled]=\"disabled\"\r\n (modelChange)=\"updateValue($event)\"\r\n ></mrx-input-date-time>\r\n\r\n @if(!!settings.options.minDate) {\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.minDate | dateTimeFormat: 'mos' : 'dd.MM.yyyy'}}\"\r\n ></mrx-hint-error-message>\r\n }\r\n\r\n @if(!!settings.options.maxDate) {\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.maxDate | dateTimeFormat: 'mos' : 'dd.MM.yyyy' }}\"\r\n ></mrx-hint-error-message>\r\n }\r\n </div>\r\n\r\n @if (settings.options.counter && settings.options.range) {\r\n <div class=\"col col-4\">\r\n <mrx-label>\r\n {{ settings.options.counterLabel }}\r\n </mrx-label>\r\n <mrx-input-number\r\n [ngModel]=\"modelCounter\"\r\n [placeholder]=\"'0'\"\r\n [disabled]=\"!settings.options.counterEditable\"\r\n (ngModelChange)=\"updateCounter($event)\"\r\n ></mrx-input-number>\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n}\r\n" }]
170
183
  }] });
171
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/date/input-date.component.ts","../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/date/input-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core';\r\nimport { ComponentType, DateTypeEnum } from '../../../../../shared-form/enums';\r\nimport { BaseFieldComponent } from '../../base';\r\nimport { InputDateModel } from '../../../../models/elemets/inputs';\r\nimport { ComponentValueModel } from '../../../../models';\r\nimport { objectFormSelectors } from '../../../../store';\r\nimport { defaultValueModel } from '../../../../helpers';\r\nimport { InputDateTimeValueWithId } from '@myrtex-org/ui';\r\n\r\n@Component({\r\n  selector: 'app-input-date',\r\n  templateUrl: './input-date.component.html',\r\n  styleUrls: ['./input-date.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class InputDateComponent extends BaseFieldComponent<InputDateModel, InputDateTimeValueWithId> implements OnInit {\r\n  type = ComponentType.InputDate;\r\n\r\n  private readonly _millisecondsInDay: number = 1000 * 60 * 60 * 24;\r\n\r\n  private _isInit = false;\r\n\r\n  public dateModel: string | string[] | null = '';\r\n\r\n  public modelStart!: ComponentValueModel;\r\n  public modelEnd!: ComponentValueModel;\r\n  public modelCounter: number = 0;\r\n\r\n  override get getInvalid(): boolean {\r\n    if (this.settings.options.range) {\r\n      if (this._isCheckRequired && this.settings.options.required) {\r\n        return !(!!this.modelStart?.value && !!this.modelEnd?.value);\r\n      }\r\n      return false;\r\n    }\r\n    return super.getInvalid;\r\n  }\r\n\r\n  public get value(): string | string[] {\r\n    if (this.settings.options.range) {\r\n      return [this.modelStart.value, this.modelEnd.value];\r\n    } else {\r\n      return this.model.value;\r\n    }\r\n  }\r\n\r\n  public get getViewTypeTimepicker(): boolean {\r\n    return this.settings.options.viewType === DateTypeEnum.DateTime;\r\n  }\r\n\r\n  public updateValue(event: InputDateTimeValueWithId) {\r\n    if (this._isInit) {\r\n      if (this.settings.options.range) {\r\n        if (!event.value || event.value.length === 0) {\r\n          this.dateModel = []; // Локальное обновление для UI\r\n          this.modelStart.value = null;\r\n          this.modelEnd.value = null;\r\n          this.model.value = [null, null];\r\n          this.modelCounter = 0;\r\n        } else if (event.value.length === 2) {\r\n          this.dateModel = [event.value[0], event.value[1]]; // Локальное обновление для UI\r\n          this.modelStart.value = event.value[0];\r\n          this.modelEnd.value = event.value[1];\r\n          this.model.value = [this.modelStart.value, this.modelEnd.value];\r\n          this.modelCounter = this._getDaysDifference(this.modelStart.value, this.modelEnd.value);\r\n        }\r\n      } else {\r\n        this.dateModel = event.value;\r\n        this.model.value = event.value;\r\n      }\r\n      this.dispatchModify(event);\r\n    }\r\n  }\r\n\r\n  public updateCounter(value: number | null): void {\r\n    if (value) {\r\n      this.modelCounter = value;\r\n    } else {\r\n      this.modelCounter = 0;\r\n    }\r\n\r\n    if (this.settings.options.range) {\r\n      if(this.model.value && this.model.value[0]) {\r\n        this.model.value = [this.model.value[0], new Date()]\r\n        this.model.value[1] = this._changeDays(this.model.value[0], this.modelCounter);\r\n\r\n        this.dateModel = this.model.value; \r\n      } else {\r\n        this.model.value = [new Date(), new Date()]\r\n\r\n        this.model.value[1] = this._changeDays(this.model.value[0], this.modelCounter);\r\n\r\n        this.dateModel = this.model.value;\r\n      }\r\n    }\r\n\r\n    this.dispatchModify(structuredClone(this.model.value));\r\n  }\r\n\r\n  override _transformOutputValue() {\r\n    if (this.settings.options.range) {\r\n      return [structuredClone(this.modelStart), structuredClone(this.modelEnd)];\r\n    } else {\r\n      return structuredClone(this.model);\r\n    }\r\n  }\r\n\r\n  override _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.modelStart = structuredClone(result[0]) || defaultValueModel(this.settings);\r\n            this.modelEnd = structuredClone(result[1]) || defaultValueModel(this.settings);\r\n          } else {\r\n            this.model = structuredClone(result || defaultValueModel(this.settings));\r\n          }\r\n\r\n          this._customInit();\r\n        }\r\n      }));\r\n  }\r\n\r\n  override _customInit() {\r\n    // Уменьшаем задержку, чтобы инициализация была быстрее\r\n    setTimeout(() => {\r\n      if (!this.model) {\r\n        this.model = defaultValueModel(this.settings);\r\n      }\r\n\r\n      if (this.settings.options.range) {\r\n        // Синхронизируем UI с моделями из Store\r\n        if (this.modelStart?.value && this.modelEnd?.value) {\r\n          this.dateModel = [this.modelStart.value, this.modelEnd.value];\r\n          this.modelCounter = this._getDaysDifference(this.modelStart.value, this.modelEnd.value);\r\n        } else {\r\n          // Если в Store реально пусто, только тогда чистим UI\r\n          this.dateModel = [];\r\n          this.modelCounter = 0;\r\n        }\r\n      } else {\r\n        this.dateModel = this.model.value;\r\n      }\r\n\r\n      this._isInit = true;\r\n      this._detector.detectChanges();\r\n    }, 100); // 100мс достаточно\r\n  }\r\n\r\n  private _getDaysDifference(startDate: string, endDate: string): number {\r\n    const start = new Date(startDate);\r\n    const end = new Date(endDate);\r\n\r\n    if (isNaN(start.getTime()) || isNaN(end.getTime())) {\r\n      console.error('Invalid date format');\r\n      return 0;\r\n    }\r\n\r\n    const differenceInMs = Math.abs(end.getTime() - start.getTime());\r\n    return Math.floor(differenceInMs / this._millisecondsInDay);\r\n  }\r\n\r\n  private _changeDays(startDate: string, days: number): string | null {\r\n    if (startDate) {\r\n      const start = new Date(startDate);\r\n\r\n      if (isNaN(start.getTime())) {\r\n        console.error('Invalid start date format');\r\n        return startDate;\r\n      }\r\n\r\n      if (!Number.isInteger(days) || days < 0) {\r\n        console.error('Days must be a non-negative integer');\r\n        return startDate;\r\n      }\r\n\r\n      let newDate = new Date(start.getTime() + days * this._millisecondsInDay);\r\n\r\n      if (!!this.settings.options.maxDate && newDate > new Date(this.settings.options.maxDate)) {\r\n        const maxDays = Math.floor((new Date(this.settings.options.maxDate).getTime() - start.getTime()) / this._millisecondsInDay);\r\n        newDate = new Date(start.getTime() + (maxDays + 1) * this._millisecondsInDay);\r\n      }\r\n\r\n      return newDate.toISOString();\r\n    } else {\r\n      return null;\r\n    }\r\n  }\r\n}\r\n","@if (settings) {\r\n  <div class=\"input-date-content\">\r\n    <div class=\"row\">\r\n      <div class=\"col\" [class.col-8]=\"settings.options.counter\">\r\n        @if (settings.options.label) {\r\n          <mrx-label\r\n            [required]=\"settings.options.required\"\r\n            [tooltip]=\"settings.options.tooltip || ''\"\r\n          >\r\n            {{ settings.options.label }}\r\n          </mrx-label>\r\n        }\r\n\r\n        <mrx-input-date-time\r\n          [dateFormat]=\"settings.options.format\"\r\n          [ngModel]=\"dateModel\"\r\n          [fields]=\"autosaveFields\"\r\n          [range]=\"settings.options.range\"\r\n          [datePlaceholder]=\"(settings.options.range ? settings.options.placeholder + ' - ' + settings.options.placeholder : settings.options.placeholder) || ''\"\r\n          [isManualInput]=\"!settings.options.range\"\r\n          [timepicker]=\"getViewTypeTimepicker\"\r\n          [invalid]=\"getInvalid\"\r\n          [invalidMessage]=\"getInvalidMessage\"\r\n          [minDate]=\"settings.options.minDate\"\r\n          [maxDate]=\"settings.options.maxDate\"\r\n          [disabled]=\"disabled\"\r\n          (modelChange)=\"updateValue($event)\"\r\n        ></mrx-input-date-time>\r\n\r\n        @if(!!settings.options.minDate) {\r\n          <mrx-hint-error-message  \r\n            message=\"Минимальное значение — {{ settings.options.minDate | dateTimeFormat: 'mos' : 'dd.MM.yyyy'}}\"\r\n          ></mrx-hint-error-message>\r\n        }\r\n\r\n        @if(!!settings.options.maxDate) {\r\n          <mrx-hint-error-message  \r\n            message=\"Максимальное значение — {{ settings.options.maxDate | dateTimeFormat: 'mos' : 'dd.MM.yyyy' }}\"\r\n          ></mrx-hint-error-message>\r\n        }\r\n      </div>\r\n\r\n      @if (settings.options.counter && settings.options.range) {\r\n        <div class=\"col col-4\">\r\n          <mrx-label>\r\n            {{ settings.options.counterLabel }}\r\n          </mrx-label>\r\n          <mrx-input-number\r\n            [ngModel]=\"modelCounter\"\r\n            [placeholder]=\"'0'\"\r\n            [disabled]=\"!settings.options.counterEditable\"\r\n            (ngModelChange)=\"updateCounter($event)\"\r\n          ></mrx-input-number>\r\n        </div>\r\n      }\r\n    </div>\r\n  </div>\r\n}\r\n"]}
184
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/date/input-date.component.ts","../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/date/input-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core';\r\nimport { ComponentType, DateTypeEnum } from '../../../../../shared-form/enums';\r\nimport { BaseFieldComponent } from '../../base';\r\nimport { InputDateModel } from '../../../../models/elemets/inputs';\r\nimport { ComponentValueModel } from '../../../../models';\r\nimport { objectFormSelectors } from '../../../../store';\r\nimport { defaultValueModel } from '../../../../helpers';\r\nimport { InputDateTimeValueWithId } from '@myrtex-org/ui';\r\n\r\n@Component({\r\n  selector: 'app-input-date',\r\n  templateUrl: './input-date.component.html',\r\n  styleUrls: ['./input-date.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class InputDateComponent extends BaseFieldComponent<InputDateModel, InputDateTimeValueWithId> implements OnInit {\r\n  type = ComponentType.InputDate;\r\n\r\n  private readonly _millisecondsInDay: number = 1000 * 60 * 60 * 24;\r\n\r\n  private _isInit = false;\r\n  private _isUpdatingInternal = false;\r\n\r\n  public dateModel: string | string[] | null = '';\r\n\r\n  public modelStart!: ComponentValueModel;\r\n  public modelEnd!: ComponentValueModel;\r\n  public modelCounter: number = 0;\r\n\r\n  override get getInvalid(): boolean {\r\n    if (this.settings.options.range) {\r\n      if (this._isCheckRequired && this.settings.options.required) {\r\n        return !(!!this.modelStart?.value && !!this.modelEnd?.value);\r\n      }\r\n      return false;\r\n    }\r\n    return super.getInvalid;\r\n  }\r\n\r\n  public get value(): string | string[] {\r\n    if (this.settings.options.range) {\r\n      return [this.modelStart.value, this.modelEnd.value];\r\n    } else {\r\n      return this.model.value;\r\n    }\r\n  }\r\n\r\n  public get getViewTypeTimepicker(): boolean {\r\n    return this.settings.options.viewType === DateTypeEnum.DateTime;\r\n  }\r\n\r\n  public updateValue(event: InputDateTimeValueWithId) {\r\n    if (this._isInit) {\r\n      this._isUpdatingInternal = true; // Блокируем внешние обновления на время ввода\r\n\r\n      if (this.settings.options.range) {\r\n        if (!event.value || event.value.length === 0) {\r\n          this.dateModel = [];\r\n          this.modelStart.value = null;\r\n          this.modelEnd.value = null;\r\n          this.modelCounter = 0;\r\n        } else if (event.value.length === 2) {\r\n          this.dateModel = [event.value[0], event.value[1]];\r\n          this.modelStart.value = event.value[0];\r\n          this.modelEnd.value = event.value[1];\r\n          this.modelCounter = this._getDaysDifference(this.modelStart.value, this.modelEnd.value);\r\n        }\r\n        this.model.value = this.dateModel;\r\n      } else {\r\n        this.dateModel = event.value;\r\n        this.model.value = event.value;\r\n      }\r\n\r\n      this.dispatchModify(event);\r\n      \r\n      // Снимаем блокировку чуть позже, когда Store переварит изменения\r\n      setTimeout(() => this._isUpdatingInternal = false, 600); \r\n    }\r\n  }\r\n\r\n  public updateCounter(value: number | null): void {\r\n    if (value) {\r\n      this.modelCounter = value;\r\n    } else {\r\n      this.modelCounter = 0;\r\n    }\r\n\r\n    if (this.settings.options.range) {\r\n      if(this.model.value && this.model.value[0]) {\r\n        this.model.value = [this.model.value[0], new Date()]\r\n        this.model.value[1] = this._changeDays(this.model.value[0], this.modelCounter);\r\n\r\n        this.dateModel = this.model.value; \r\n      } else {\r\n        this.model.value = [new Date(), new Date()]\r\n\r\n        this.model.value[1] = this._changeDays(this.model.value[0], this.modelCounter);\r\n\r\n        this.dateModel = this.model.value;\r\n      }\r\n    }\r\n\r\n    this.dispatchModify(structuredClone(this.model.value));\r\n  }\r\n\r\n  override _transformOutputValue() {\r\n    if (this.settings.options.range) {\r\n      return [structuredClone(this.modelStart), structuredClone(this.modelEnd)];\r\n    } else {\r\n      return structuredClone(this.model);\r\n    }\r\n  }\r\n\r\n  override _initSubscriptionForValue() {\r\n    this._subscriptions$.push(\r\n      this._store.select(objectFormSelectors.selectValueModel(this.settings))\r\n        .subscribe((result: ComponentValueModel | null | (ComponentValueModel | null)[]) => {\r\n          if (!result || this._isUpdatingInternal) return;\r\n\r\n          // Если компонент уже инициализирован, проверяем, нужно ли обновляться.\r\n          // Мы НЕ обновляемся, если данные в Store идентичны тем, что мы уже держим в памяти.\r\n          if (this._isInit) {\r\n            const newValue = Array.isArray(result) \r\n              ? JSON.stringify([result[0]?.value, result[1]?.value])\r\n              : JSON.stringify(result.value);\r\n\r\n            const currentValue = this.settings.options.range\r\n              ? JSON.stringify([this.modelStart?.value, this.modelEnd?.value])\r\n              : JSON.stringify(this.model?.value);\r\n\r\n            if (newValue === currentValue) {\r\n              return; // Данные те же самые, выходим, чтобы не запускать таймер заново\r\n            }\r\n          }\r\n\r\n          // Если данные реально новые (пришли извне), обновляем локальные модели\r\n          if (Array.isArray(result)) {\r\n            this.modelStart = structuredClone(result[0]) || defaultValueModel(this.settings);\r\n            this.modelEnd = structuredClone(result[1]) || defaultValueModel(this.settings);\r\n          } else {\r\n            this.model = structuredClone(result || defaultValueModel(this.settings));\r\n          }\r\n\r\n          this._customInit();\r\n        })\r\n    );\r\n  }\r\n\r\n  override _customInit() {\r\n    if (!this.model) {\r\n      this.model = defaultValueModel(this.settings);\r\n    }\r\n\r\n    if (this.settings.options.range) {\r\n      if (this.modelStart?.value && this.modelEnd?.value) {\r\n        this.dateModel = [this.modelStart.value, this.modelEnd.value];\r\n        this.modelCounter = this._getDaysDifference(this.modelStart.value, this.modelEnd.value);\r\n      } else if (!this.modelStart?.value && !this.modelEnd?.value) {\r\n        // Очищаем только если в Store реально пусто\r\n        this.dateModel = [];\r\n        this.modelCounter = 0;\r\n      }\r\n    } else {\r\n      this.dateModel = this.model.value;\r\n    }\r\n\r\n    this._isInit = true;\r\n    this._detector.markForCheck(); \r\n  }\r\n\r\n  private _getDaysDifference(startDate: string, endDate: string): number {\r\n    const start = new Date(startDate);\r\n    const end = new Date(endDate);\r\n\r\n    if (isNaN(start.getTime()) || isNaN(end.getTime())) {\r\n      console.error('Invalid date format');\r\n      return 0;\r\n    }\r\n\r\n    const differenceInMs = Math.abs(end.getTime() - start.getTime());\r\n    return Math.floor(differenceInMs / this._millisecondsInDay);\r\n  }\r\n\r\n  private _changeDays(startDate: string, days: number): string | null {\r\n    if (startDate) {\r\n      const start = new Date(startDate);\r\n\r\n      if (isNaN(start.getTime())) {\r\n        console.error('Invalid start date format');\r\n        return startDate;\r\n      }\r\n\r\n      if (!Number.isInteger(days) || days < 0) {\r\n        console.error('Days must be a non-negative integer');\r\n        return startDate;\r\n      }\r\n\r\n      let newDate = new Date(start.getTime() + days * this._millisecondsInDay);\r\n\r\n      if (!!this.settings.options.maxDate && newDate > new Date(this.settings.options.maxDate)) {\r\n        const maxDays = Math.floor((new Date(this.settings.options.maxDate).getTime() - start.getTime()) / this._millisecondsInDay);\r\n        newDate = new Date(start.getTime() + (maxDays + 1) * this._millisecondsInDay);\r\n      }\r\n\r\n      return newDate.toISOString();\r\n    } else {\r\n      return null;\r\n    }\r\n  }\r\n}\r\n","@if (settings) {\r\n  <div class=\"input-date-content\">\r\n    <div class=\"row\">\r\n      <div class=\"col\" [class.col-8]=\"settings.options.counter\">\r\n        @if (settings.options.label) {\r\n          <mrx-label\r\n            [required]=\"settings.options.required\"\r\n            [tooltip]=\"settings.options.tooltip || ''\"\r\n          >\r\n            {{ settings.options.label }}\r\n          </mrx-label>\r\n        }\r\n\r\n        <mrx-input-date-time\r\n          [dateFormat]=\"settings.options.format\"\r\n          [ngModel]=\"dateModel\"\r\n          [fields]=\"autosaveFields\"\r\n          [range]=\"settings.options.range\"\r\n          [datePlaceholder]=\"(settings.options.range ? settings.options.placeholder + ' - ' + settings.options.placeholder : settings.options.placeholder) || ''\"\r\n          [isManualInput]=\"!settings.options.range\"\r\n          [timepicker]=\"getViewTypeTimepicker\"\r\n          [invalid]=\"getInvalid\"\r\n          [invalidMessage]=\"getInvalidMessage\"\r\n          [minDate]=\"settings.options.minDate\"\r\n          [maxDate]=\"settings.options.maxDate\"\r\n          [disabled]=\"disabled\"\r\n          (modelChange)=\"updateValue($event)\"\r\n        ></mrx-input-date-time>\r\n\r\n        @if(!!settings.options.minDate) {\r\n          <mrx-hint-error-message  \r\n            message=\"Минимальное значение — {{ settings.options.minDate | dateTimeFormat: 'mos' : 'dd.MM.yyyy'}}\"\r\n          ></mrx-hint-error-message>\r\n        }\r\n\r\n        @if(!!settings.options.maxDate) {\r\n          <mrx-hint-error-message  \r\n            message=\"Максимальное значение — {{ settings.options.maxDate | dateTimeFormat: 'mos' : 'dd.MM.yyyy' }}\"\r\n          ></mrx-hint-error-message>\r\n        }\r\n      </div>\r\n\r\n      @if (settings.options.counter && settings.options.range) {\r\n        <div class=\"col col-4\">\r\n          <mrx-label>\r\n            {{ settings.options.counterLabel }}\r\n          </mrx-label>\r\n          <mrx-input-number\r\n            [ngModel]=\"modelCounter\"\r\n            [placeholder]=\"'0'\"\r\n            [disabled]=\"!settings.options.counterEditable\"\r\n            (ngModelChange)=\"updateCounter($event)\"\r\n          ></mrx-input-number>\r\n        </div>\r\n      }\r\n    </div>\r\n  </div>\r\n}\r\n"]}
@@ -1494,6 +1494,7 @@ class InputDateComponent extends BaseFieldComponent {
1494
1494
  this.type = ComponentType.InputDate;
1495
1495
  this._millisecondsInDay = 1000 * 60 * 60 * 24;
1496
1496
  this._isInit = false;
1497
+ this._isUpdatingInternal = false;
1497
1498
  this.dateModel = '';
1498
1499
  this.modelCounter = 0;
1499
1500
  }
@@ -1519,27 +1520,29 @@ class InputDateComponent extends BaseFieldComponent {
1519
1520
  }
1520
1521
  updateValue(event) {
1521
1522
  if (this._isInit) {
1523
+ this._isUpdatingInternal = true; // Блокируем внешние обновления на время ввода
1522
1524
  if (this.settings.options.range) {
1523
1525
  if (!event.value || event.value.length === 0) {
1524
- this.dateModel = []; // Локальное обновление для UI
1526
+ this.dateModel = [];
1525
1527
  this.modelStart.value = null;
1526
1528
  this.modelEnd.value = null;
1527
- this.model.value = [null, null];
1528
1529
  this.modelCounter = 0;
1529
1530
  }
1530
1531
  else if (event.value.length === 2) {
1531
- this.dateModel = [event.value[0], event.value[1]]; // Локальное обновление для UI
1532
+ this.dateModel = [event.value[0], event.value[1]];
1532
1533
  this.modelStart.value = event.value[0];
1533
1534
  this.modelEnd.value = event.value[1];
1534
- this.model.value = [this.modelStart.value, this.modelEnd.value];
1535
1535
  this.modelCounter = this._getDaysDifference(this.modelStart.value, this.modelEnd.value);
1536
1536
  }
1537
+ this.model.value = this.dateModel;
1537
1538
  }
1538
1539
  else {
1539
1540
  this.dateModel = event.value;
1540
1541
  this.model.value = event.value;
1541
1542
  }
1542
1543
  this.dispatchModify(event);
1544
+ // Снимаем блокировку чуть позже, когда Store переварит изменения
1545
+ setTimeout(() => this._isUpdatingInternal = false, 600);
1543
1546
  }
1544
1547
  }
1545
1548
  updateCounter(value) {
@@ -1574,42 +1577,52 @@ class InputDateComponent extends BaseFieldComponent {
1574
1577
  _initSubscriptionForValue() {
1575
1578
  this._subscriptions$.push(this._store.select(selectValueModel(this.settings))
1576
1579
  .subscribe((result) => {
1577
- if (result) {
1578
- if (Array.isArray(result)) {
1579
- this.modelStart = structuredClone(result[0]) || defaultValueModel(this.settings);
1580
- this.modelEnd = structuredClone(result[1]) || defaultValueModel(this.settings);
1581
- }
1582
- else {
1583
- this.model = structuredClone(result || defaultValueModel(this.settings));
1580
+ if (!result || this._isUpdatingInternal)
1581
+ return;
1582
+ // Если компонент уже инициализирован, проверяем, нужно ли обновляться.
1583
+ // Мы НЕ обновляемся, если данные в Store идентичны тем, что мы уже держим в памяти.
1584
+ if (this._isInit) {
1585
+ const newValue = Array.isArray(result)
1586
+ ? JSON.stringify([result[0]?.value, result[1]?.value])
1587
+ : JSON.stringify(result.value);
1588
+ const currentValue = this.settings.options.range
1589
+ ? JSON.stringify([this.modelStart?.value, this.modelEnd?.value])
1590
+ : JSON.stringify(this.model?.value);
1591
+ if (newValue === currentValue) {
1592
+ return; // Данные те же самые, выходим, чтобы не запускать таймер заново
1584
1593
  }
1585
- this._customInit();
1586
1594
  }
1595
+ // Если данные реально новые (пришли извне), обновляем локальные модели
1596
+ if (Array.isArray(result)) {
1597
+ this.modelStart = structuredClone(result[0]) || defaultValueModel(this.settings);
1598
+ this.modelEnd = structuredClone(result[1]) || defaultValueModel(this.settings);
1599
+ }
1600
+ else {
1601
+ this.model = structuredClone(result || defaultValueModel(this.settings));
1602
+ }
1603
+ this._customInit();
1587
1604
  }));
1588
1605
  }
1589
1606
  _customInit() {
1590
- // Уменьшаем задержку, чтобы инициализация была быстрее
1591
- setTimeout(() => {
1592
- if (!this.model) {
1593
- this.model = defaultValueModel(this.settings);
1594
- }
1595
- if (this.settings.options.range) {
1596
- // Синхронизируем UI с моделями из Store
1597
- if (this.modelStart?.value && this.modelEnd?.value) {
1598
- this.dateModel = [this.modelStart.value, this.modelEnd.value];
1599
- this.modelCounter = this._getDaysDifference(this.modelStart.value, this.modelEnd.value);
1600
- }
1601
- else {
1602
- // Если в Store реально пусто, только тогда чистим UI
1603
- this.dateModel = [];
1604
- this.modelCounter = 0;
1605
- }
1607
+ if (!this.model) {
1608
+ this.model = defaultValueModel(this.settings);
1609
+ }
1610
+ if (this.settings.options.range) {
1611
+ if (this.modelStart?.value && this.modelEnd?.value) {
1612
+ this.dateModel = [this.modelStart.value, this.modelEnd.value];
1613
+ this.modelCounter = this._getDaysDifference(this.modelStart.value, this.modelEnd.value);
1606
1614
  }
1607
- else {
1608
- this.dateModel = this.model.value;
1615
+ else if (!this.modelStart?.value && !this.modelEnd?.value) {
1616
+ // Очищаем только если в Store реально пусто
1617
+ this.dateModel = [];
1618
+ this.modelCounter = 0;
1609
1619
  }
1610
- this._isInit = true;
1611
- this._detector.detectChanges();
1612
- }, 100); // 100мс достаточно
1620
+ }
1621
+ else {
1622
+ this.dateModel = this.model.value;
1623
+ }
1624
+ this._isInit = true;
1625
+ this._detector.markForCheck();
1613
1626
  }
1614
1627
  _getDaysDifference(startDate, endDate) {
1615
1628
  const start = new Date(startDate);