@myrtex-org/form 1.1.14 → 1.1.15
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
CHANGED
|
@@ -92,32 +92,45 @@ export class InputDateComponent extends BaseFieldComponent {
|
|
|
92
92
|
_initSubscriptionForValue() {
|
|
93
93
|
this._subscriptions$.push(this._store.select(objectFormSelectors.selectValueModel(this.settings))
|
|
94
94
|
.subscribe((result) => {
|
|
95
|
-
if (result)
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
95
|
+
if (!result)
|
|
96
|
+
return;
|
|
97
|
+
// Если компонент уже инициализирован, проверяем, нужно ли обновляться.
|
|
98
|
+
// Мы НЕ обновляемся, если данные в Store идентичны тем, что мы уже держим в памяти.
|
|
99
|
+
if (this._isInit) {
|
|
100
|
+
const newValue = Array.isArray(result)
|
|
101
|
+
? JSON.stringify([result[0]?.value, result[1]?.value])
|
|
102
|
+
: JSON.stringify(result.value);
|
|
103
|
+
const currentValue = this.settings.options.range
|
|
104
|
+
? JSON.stringify([this.modelStart?.value, this.modelEnd?.value])
|
|
105
|
+
: JSON.stringify(this.model?.value);
|
|
106
|
+
if (newValue === currentValue) {
|
|
107
|
+
return; // Данные те же самые, выходим, чтобы не запускать таймер заново
|
|
99
108
|
}
|
|
100
|
-
else {
|
|
101
|
-
this.model = structuredClone(result || defaultValueModel(this.settings));
|
|
102
|
-
}
|
|
103
|
-
this._customInit();
|
|
104
109
|
}
|
|
110
|
+
// Если данные реально новые (пришли извне), обновляем локальные модели
|
|
111
|
+
if (Array.isArray(result)) {
|
|
112
|
+
this.modelStart = structuredClone(result[0]) || defaultValueModel(this.settings);
|
|
113
|
+
this.modelEnd = structuredClone(result[1]) || defaultValueModel(this.settings);
|
|
114
|
+
}
|
|
115
|
+
else {
|
|
116
|
+
this.model = structuredClone(result || defaultValueModel(this.settings));
|
|
117
|
+
}
|
|
118
|
+
this._customInit();
|
|
105
119
|
}));
|
|
106
120
|
}
|
|
107
121
|
_customInit() {
|
|
108
|
-
//
|
|
122
|
+
// 0 или 10мс — этого достаточно
|
|
109
123
|
setTimeout(() => {
|
|
110
124
|
if (!this.model) {
|
|
111
125
|
this.model = defaultValueModel(this.settings);
|
|
112
126
|
}
|
|
113
127
|
if (this.settings.options.range) {
|
|
114
|
-
// Синхронизируем UI с моделями из Store
|
|
115
128
|
if (this.modelStart?.value && this.modelEnd?.value) {
|
|
116
129
|
this.dateModel = [this.modelStart.value, this.modelEnd.value];
|
|
117
130
|
this.modelCounter = this._getDaysDifference(this.modelStart.value, this.modelEnd.value);
|
|
118
131
|
}
|
|
119
|
-
else {
|
|
120
|
-
//
|
|
132
|
+
else if (!this.modelStart?.value && !this.modelEnd?.value) {
|
|
133
|
+
// Очищаем только если в Store реально пусто
|
|
121
134
|
this.dateModel = [];
|
|
122
135
|
this.modelCounter = 0;
|
|
123
136
|
}
|
|
@@ -127,7 +140,7 @@ export class InputDateComponent extends BaseFieldComponent {
|
|
|
127
140
|
}
|
|
128
141
|
this._isInit = true;
|
|
129
142
|
this._detector.detectChanges();
|
|
130
|
-
},
|
|
143
|
+
}, 0);
|
|
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\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"]}
|
|
@@ -1574,32 +1574,45 @@ class InputDateComponent extends BaseFieldComponent {
|
|
|
1574
1574
|
_initSubscriptionForValue() {
|
|
1575
1575
|
this._subscriptions$.push(this._store.select(selectValueModel(this.settings))
|
|
1576
1576
|
.subscribe((result) => {
|
|
1577
|
-
if (result)
|
|
1578
|
-
|
|
1579
|
-
|
|
1580
|
-
|
|
1581
|
-
|
|
1582
|
-
|
|
1583
|
-
|
|
1577
|
+
if (!result)
|
|
1578
|
+
return;
|
|
1579
|
+
// Если компонент уже инициализирован, проверяем, нужно ли обновляться.
|
|
1580
|
+
// Мы НЕ обновляемся, если данные в Store идентичны тем, что мы уже держим в памяти.
|
|
1581
|
+
if (this._isInit) {
|
|
1582
|
+
const newValue = Array.isArray(result)
|
|
1583
|
+
? JSON.stringify([result[0]?.value, result[1]?.value])
|
|
1584
|
+
: JSON.stringify(result.value);
|
|
1585
|
+
const currentValue = this.settings.options.range
|
|
1586
|
+
? JSON.stringify([this.modelStart?.value, this.modelEnd?.value])
|
|
1587
|
+
: JSON.stringify(this.model?.value);
|
|
1588
|
+
if (newValue === currentValue) {
|
|
1589
|
+
return; // Данные те же самые, выходим, чтобы не запускать таймер заново
|
|
1584
1590
|
}
|
|
1585
|
-
this._customInit();
|
|
1586
1591
|
}
|
|
1592
|
+
// Если данные реально новые (пришли извне), обновляем локальные модели
|
|
1593
|
+
if (Array.isArray(result)) {
|
|
1594
|
+
this.modelStart = structuredClone(result[0]) || defaultValueModel(this.settings);
|
|
1595
|
+
this.modelEnd = structuredClone(result[1]) || defaultValueModel(this.settings);
|
|
1596
|
+
}
|
|
1597
|
+
else {
|
|
1598
|
+
this.model = structuredClone(result || defaultValueModel(this.settings));
|
|
1599
|
+
}
|
|
1600
|
+
this._customInit();
|
|
1587
1601
|
}));
|
|
1588
1602
|
}
|
|
1589
1603
|
_customInit() {
|
|
1590
|
-
//
|
|
1604
|
+
// 0 или 10мс — этого достаточно
|
|
1591
1605
|
setTimeout(() => {
|
|
1592
1606
|
if (!this.model) {
|
|
1593
1607
|
this.model = defaultValueModel(this.settings);
|
|
1594
1608
|
}
|
|
1595
1609
|
if (this.settings.options.range) {
|
|
1596
|
-
// Синхронизируем UI с моделями из Store
|
|
1597
1610
|
if (this.modelStart?.value && this.modelEnd?.value) {
|
|
1598
1611
|
this.dateModel = [this.modelStart.value, this.modelEnd.value];
|
|
1599
1612
|
this.modelCounter = this._getDaysDifference(this.modelStart.value, this.modelEnd.value);
|
|
1600
1613
|
}
|
|
1601
|
-
else {
|
|
1602
|
-
//
|
|
1614
|
+
else if (!this.modelStart?.value && !this.modelEnd?.value) {
|
|
1615
|
+
// Очищаем только если в Store реально пусто
|
|
1603
1616
|
this.dateModel = [];
|
|
1604
1617
|
this.modelCounter = 0;
|
|
1605
1618
|
}
|
|
@@ -1609,7 +1622,7 @@ class InputDateComponent extends BaseFieldComponent {
|
|
|
1609
1622
|
}
|
|
1610
1623
|
this._isInit = true;
|
|
1611
1624
|
this._detector.detectChanges();
|
|
1612
|
-
},
|
|
1625
|
+
}, 0);
|
|
1613
1626
|
}
|
|
1614
1627
|
_getDaysDifference(startDate, endDate) {
|
|
1615
1628
|
const start = new Date(startDate);
|