@myrtex-org/form 1.1.15 → 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.
- package/esm2022/lib/modules/object-form/components/elements/input/date/input-date.component.mjs +26 -26
- package/fesm2022/myrtex-org-form.mjs +25 -25
- package/fesm2022/myrtex-org-form.mjs.map +1 -1
- package/lib/modules/object-form/components/elements/input/date/input-date.component.d.ts +1 -0
- package/package.json +1 -1
package/esm2022/lib/modules/object-form/components/elements/input/date/input-date.component.mjs
CHANGED
|
@@ -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 = [];
|
|
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]];
|
|
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,7 +95,7 @@ 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)
|
|
98
|
+
if (!result || this._isUpdatingInternal)
|
|
96
99
|
return;
|
|
97
100
|
// Если компонент уже инициализирован, проверяем, нужно ли обновляться.
|
|
98
101
|
// Мы НЕ обновляемся, если данные в Store идентичны тем, что мы уже держим в памяти.
|
|
@@ -119,28 +122,25 @@ export class InputDateComponent extends BaseFieldComponent {
|
|
|
119
122
|
}));
|
|
120
123
|
}
|
|
121
124
|
_customInit() {
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
this.dateModel = [this.modelStart.value, this.modelEnd.value];
|
|
130
|
-
this.modelCounter = this._getDaysDifference(this.modelStart.value, this.modelEnd.value);
|
|
131
|
-
}
|
|
132
|
-
else if (!this.modelStart?.value && !this.modelEnd?.value) {
|
|
133
|
-
// Очищаем только если в Store реально пусто
|
|
134
|
-
this.dateModel = [];
|
|
135
|
-
this.modelCounter = 0;
|
|
136
|
-
}
|
|
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);
|
|
137
132
|
}
|
|
138
|
-
else {
|
|
139
|
-
|
|
133
|
+
else if (!this.modelStart?.value && !this.modelEnd?.value) {
|
|
134
|
+
// Очищаем только если в Store реально пусто
|
|
135
|
+
this.dateModel = [];
|
|
136
|
+
this.modelCounter = 0;
|
|
140
137
|
}
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
this.dateModel = this.model.value;
|
|
141
|
+
}
|
|
142
|
+
this._isInit = true;
|
|
143
|
+
this._detector.markForCheck();
|
|
144
144
|
}
|
|
145
145
|
_getDaysDifference(startDate, endDate) {
|
|
146
146
|
const start = new Date(startDate);
|
|
@@ -181,4 +181,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
181
181
|
type: Component,
|
|
182
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" }]
|
|
183
183
|
}] });
|
|
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\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(\r\n      this._store.select(objectFormSelectors.selectValueModel(this.settings))\r\n        .subscribe((result: ComponentValueModel | null | (ComponentValueModel | null)[]) => {\r\n          if (!result) 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    // 0 или 10мс — этого достаточно\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        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.detectChanges();\r\n    }, 0); \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":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAU,MAAM,eAAe,CAAC;AAC3E,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAC/E,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAGhD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;;;;AASxD,MAAM,OAAO,kBAAmB,SAAQ,kBAA4D;IANpG;;QAOE,SAAI,GAAG,aAAa,CAAC,SAAS,CAAC;QAEd,uBAAkB,GAAW,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;QAE1D,YAAO,GAAG,KAAK,CAAC;QAChB,wBAAmB,GAAG,KAAK,CAAC;QAE7B,cAAS,GAA6B,EAAE,CAAC;QAIzC,iBAAY,GAAW,CAAC,CAAC;KAsLjC;IApLC,IAAa,UAAU;QACrB,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YAChC,IAAI,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;gBAC5D,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,KAAK,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;YAC/D,CAAC;YACD,OAAO,KAAK,CAAC;QACf,CAAC;QACD,OAAO,KAAK,CAAC,UAAU,CAAC;IAC1B,CAAC;IAED,IAAW,KAAK;QACd,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YAChC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACtD,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;QAC1B,CAAC;IACH,CAAC;IAED,IAAW,qBAAqB;QAC9B,OAAO,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,KAAK,YAAY,CAAC,QAAQ,CAAC;IAClE,CAAC;IAEM,WAAW,CAAC,KAA+B;QAChD,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,CAAC,8CAA8C;YAE/E,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;gBAChC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;oBAC7C,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;oBACpB,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,IAAI,CAAC;oBAC7B,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC;oBAC3B,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;gBACxB,CAAC;qBAAM,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;oBACpC,IAAI,CAAC,SAAS,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;oBAClD,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;oBACvC,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;oBACrC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;gBAC1F,CAAC;gBACD,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC;YACpC,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,KAAK,CAAC;gBAC7B,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;YACjC,CAAC;YAED,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;YAE3B,iEAAiE;YACjE,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,mBAAmB,GAAG,KAAK,EAAE,GAAG,CAAC,CAAC;QAC1D,CAAC;IACH,CAAC;IAEM,aAAa,CAAC,KAAoB;QACvC,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC5B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;QACxB,CAAC;QAED,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YAChC,IAAG,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;gBAC3C,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,IAAI,EAAE,CAAC,CAAA;gBACpD,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;gBAE/E,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;YACpC,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,IAAI,IAAI,EAAE,EAAE,IAAI,IAAI,EAAE,CAAC,CAAA;gBAE3C,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;gBAE/E,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;YACpC,CAAC;QACH,CAAC;QAED,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;IACzD,CAAC;IAEQ,qBAAqB;QAC5B,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YAChC,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;QAC5E,CAAC;aAAM,CAAC;YACN,OAAO,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACrC,CAAC;IACH,CAAC;IAEQ,yBAAyB;QAChC,IAAI,CAAC,eAAe,CAAC,IAAI,CACvB,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,mBAAmB,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aACpE,SAAS,CAAC,CAAC,MAAmE,EAAE,EAAE;YACjF,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,mBAAmB;gBAAE,OAAO;YAEhD,uEAAuE;YACvE,oFAAoF;YACpF,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBACjB,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC;oBACpC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;oBACtD,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBAEjC,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK;oBAC9C,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;oBAChE,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;gBAEtC,IAAI,QAAQ,KAAK,YAAY,EAAE,CAAC;oBAC9B,OAAO,CAAC,gEAAgE;gBAC1E,CAAC;YACH,CAAC;YAED,uEAAuE;YACvE,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;gBAC1B,IAAI,CAAC,UAAU,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBACjF,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACjF,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,KAAK,GAAG,eAAe,CAAC,MAAM,IAAI,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;YAC3E,CAAC;YAED,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC,CAAC,CACL,CAAC;IACJ,CAAC;IAEQ,WAAW;QAClB,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,KAAK,GAAG,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAChD,CAAC;QAED,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YAChC,IAAI,IAAI,CAAC,UAAU,EAAE,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAE,CAAC;gBACnD,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;gBAC9D,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAC1F,CAAC;iBAAM,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,KAAK,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAE,CAAC;gBAC5D,4CAA4C;gBAC5C,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;gBACpB,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;YACxB,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;QACpC,CAAC;QAED,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC;IAChC,CAAC;IAEO,kBAAkB,CAAC,SAAiB,EAAE,OAAe;QAC3D,MAAM,KAAK,GAAG,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC;QAClC,MAAM,GAAG,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC;QAE9B,IAAI,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC;YACnD,OAAO,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC;YACrC,OAAO,CAAC,CAAC;QACX,CAAC;QAED,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;QACjE,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAC9D,CAAC;IAEO,WAAW,CAAC,SAAiB,EAAE,IAAY;QACjD,IAAI,SAAS,EAAE,CAAC;YACd,MAAM,KAAK,GAAG,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC;YAElC,IAAI,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC;gBAC3B,OAAO,CAAC,KAAK,CAAC,2BAA2B,CAAC,CAAC;gBAC3C,OAAO,SAAS,CAAC;YACnB,CAAC;YAED,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,IAAI,GAAG,CAAC,EAAE,CAAC;gBACxC,OAAO,CAAC,KAAK,CAAC,qCAAqC,CAAC,CAAC;gBACrD,OAAO,SAAS,CAAC;YACnB,CAAC;YAED,IAAI,OAAO,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,IAAI,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC;YAEzE,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,IAAI,OAAO,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;gBACzF,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,GAAG,KAAK,CAAC,OAAO,EAAE,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC;gBAC5H,OAAO,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,CAAC,OAAO,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC;YAChF,CAAC;YAED,OAAO,OAAO,CAAC,WAAW,EAAE,CAAC;QAC/B,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;+GAjMU,kBAAkB;mGAAlB,kBAAkB,6ECf/B,i+EA0DA;;4FD3Ca,kBAAkB;kBAN9B,SAAS;+BACE,gBAAgB,mBAGT,uBAAuB,CAAC,MAAM","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 = [];
|
|
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]];
|
|
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,7 +1577,7 @@ 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)
|
|
1580
|
+
if (!result || this._isUpdatingInternal)
|
|
1578
1581
|
return;
|
|
1579
1582
|
// Если компонент уже инициализирован, проверяем, нужно ли обновляться.
|
|
1580
1583
|
// Мы НЕ обновляемся, если данные в Store идентичны тем, что мы уже держим в памяти.
|
|
@@ -1601,28 +1604,25 @@ class InputDateComponent extends BaseFieldComponent {
|
|
|
1601
1604
|
}));
|
|
1602
1605
|
}
|
|
1603
1606
|
_customInit() {
|
|
1604
|
-
|
|
1605
|
-
|
|
1606
|
-
|
|
1607
|
-
|
|
1608
|
-
|
|
1609
|
-
|
|
1610
|
-
|
|
1611
|
-
this.dateModel = [this.modelStart.value, this.modelEnd.value];
|
|
1612
|
-
this.modelCounter = this._getDaysDifference(this.modelStart.value, this.modelEnd.value);
|
|
1613
|
-
}
|
|
1614
|
-
else if (!this.modelStart?.value && !this.modelEnd?.value) {
|
|
1615
|
-
// Очищаем только если в Store реально пусто
|
|
1616
|
-
this.dateModel = [];
|
|
1617
|
-
this.modelCounter = 0;
|
|
1618
|
-
}
|
|
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);
|
|
1619
1614
|
}
|
|
1620
|
-
else {
|
|
1621
|
-
|
|
1615
|
+
else if (!this.modelStart?.value && !this.modelEnd?.value) {
|
|
1616
|
+
// Очищаем только если в Store реально пусто
|
|
1617
|
+
this.dateModel = [];
|
|
1618
|
+
this.modelCounter = 0;
|
|
1622
1619
|
}
|
|
1623
|
-
|
|
1624
|
-
|
|
1625
|
-
|
|
1620
|
+
}
|
|
1621
|
+
else {
|
|
1622
|
+
this.dateModel = this.model.value;
|
|
1623
|
+
}
|
|
1624
|
+
this._isInit = true;
|
|
1625
|
+
this._detector.markForCheck();
|
|
1626
1626
|
}
|
|
1627
1627
|
_getDaysDifference(startDate, endDate) {
|
|
1628
1628
|
const start = new Date(startDate);
|