@myrtex-org/form 1.1.15 → 1.1.17
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/esm2022/lib/modules/object-form/components/elements/input/table/components/input-table-modal/input-table-modal.component.mjs +17 -4
- package/fesm2022/myrtex-org-form.mjs +40 -27
- 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/lib/modules/object-form/components/elements/input/table/components/input-table-modal/input-table-modal.component.d.ts +2 -0
- package/lib/modules/object-form/components/elements/input/table/input-table.component.d.ts +1 -1
- 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":"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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"]}
|
|
@@ -5,7 +5,7 @@ import { FormDispenserModal } from './form-dispenser-modal/form-dispenser-modal.
|
|
|
5
5
|
import { provideNgxMask } from 'ngx-mask';
|
|
6
6
|
import { ReferenceService } from '../../../../../../services';
|
|
7
7
|
import { objectFormActions } from '../../../../../../store';
|
|
8
|
-
import { ComponentType } from '../../../../../../../shared-form/enums';
|
|
8
|
+
import { ComponentType, ValueType } from '../../../../../../../shared-form/enums';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
import * as i1 from "@myrtex-org/ui";
|
|
11
11
|
import * as i2 from "@ngrx/store";
|
|
@@ -14,6 +14,7 @@ export class InputTableModalComponent extends ModalServiceComponent {
|
|
|
14
14
|
super();
|
|
15
15
|
this.dialogRef = dialogRef;
|
|
16
16
|
this.store = store;
|
|
17
|
+
this.emptyRow = true;
|
|
17
18
|
this.title = data.title;
|
|
18
19
|
this.okText = data.okText;
|
|
19
20
|
this.settings = data.settings;
|
|
@@ -30,6 +31,7 @@ export class InputTableModalComponent extends ModalServiceComponent {
|
|
|
30
31
|
else {
|
|
31
32
|
this._transformValues(valueModel);
|
|
32
33
|
}
|
|
34
|
+
this.emptyRow = this.rowModel.data.every(x => this.isEmpty(x.value, x.valueType));
|
|
33
35
|
}
|
|
34
36
|
ok() {
|
|
35
37
|
if (!this._isValid()) {
|
|
@@ -78,11 +80,22 @@ export class InputTableModalComponent extends ModalServiceComponent {
|
|
|
78
80
|
}
|
|
79
81
|
return components;
|
|
80
82
|
}
|
|
83
|
+
isEmpty(value, type) {
|
|
84
|
+
if (type === ValueType.Undefined)
|
|
85
|
+
return true;
|
|
86
|
+
if (value === null || value === undefined)
|
|
87
|
+
return true;
|
|
88
|
+
if (type === "string" || type === "guid")
|
|
89
|
+
return value === "";
|
|
90
|
+
if (Array.isArray(value))
|
|
91
|
+
return value.length === 0;
|
|
92
|
+
return false;
|
|
93
|
+
}
|
|
81
94
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputTableModalComponent, deps: [{ token: i1.ModalRef }, { token: i2.Store }, { token: MODAL_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
82
95
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: InputTableModalComponent, isStandalone: true, selector: "app-input-table-modal", providers: [
|
|
83
96
|
provideNgxMask(),
|
|
84
97
|
ReferenceService // для компонента список
|
|
85
|
-
], usesInheritance: true, ngImport: i0, template: "<mrx-modal\r\n [title]=\"title\"\r\n size=\"large\"\r\n (close)=\"close()\"\r\n (ok)=\"ok()\"\r\n>\r\n <app-form-dispenser-modal\r\n [sectionSettings]=\"settings\"\r\n [values]=\"rowModel.data\"\r\n [valueMode]=\"'manual'\"\r\n (changed)=\"componentValueChanged($event)\"\r\n ></app-form-dispenser-modal>\r\n\r\n <ng-template #footerContent>\r\n <mrx-button\r\n [customClasses]=\"'mr-3'\"\r\n [type]=\"'secondary'\"\r\n [size]=\"'medium'\"\r\n (click)=\"close()\"\r\n >\u041E\u0442\u043C\u0435\u043D\u0430\r\n </mrx-button>\r\n <mrx-button\r\n [type]=\"'primary'\"\r\n [size]=\"'medium'\"\r\n (click)=\"ok()\"\r\n >{{ okText }}\r\n </mrx-button>\r\n </ng-template>\r\n</mrx-modal>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: ModalModule }, { kind: "component", type: i1.ModalComponent, selector: "mrx-modal", inputs: ["title", "message", "alert", "okText", "closeText", "size", "color", "customClasses", "expandable", "isEmbed", "isClose", "isBack", "backText", "enableFooter", "alignButtons", "isLoading", "iconPosition"], outputs: ["ok", "close", "back", "expand"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "component", type: i1.ButtonComponent, selector: "mrx-button", inputs: ["size", "type", "color", "iconPosition", "active", "disabled", "isLoading", "iconOnly", "customClasses", "label", "icon", "iconClass", "buttonType", "href", "target", "routerLink", "queryParams"], outputs: ["mrxClick"] }, { kind: "component", type: FormDispenserModal, selector: "app-form-dispenser-modal", inputs: ["sectionSettings", "values", "valueMode"], outputs: ["changed"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
98
|
+
], usesInheritance: true, ngImport: i0, template: "<mrx-modal\r\n [title]=\"title\"\r\n size=\"large\"\r\n (close)=\"close()\"\r\n (ok)=\"ok()\"\r\n>\r\n <app-form-dispenser-modal\r\n [sectionSettings]=\"settings\"\r\n [values]=\"rowModel.data\"\r\n [valueMode]=\"'manual'\"\r\n (changed)=\"componentValueChanged($event)\"\r\n ></app-form-dispenser-modal>\r\n\r\n <ng-template #footerContent>\r\n <mrx-button\r\n [customClasses]=\"'mr-3'\"\r\n [type]=\"'secondary'\"\r\n [size]=\"'medium'\"\r\n (click)=\"close()\"\r\n >\u041E\u0442\u043C\u0435\u043D\u0430\r\n </mrx-button>\r\n <mrx-button\r\n [type]=\"'primary'\"\r\n [size]=\"'medium'\"\r\n [disabled]=\"emptyRow\"\r\n (click)=\"ok()\"\r\n >{{ okText }}\r\n </mrx-button>\r\n </ng-template>\r\n</mrx-modal>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: ModalModule }, { kind: "component", type: i1.ModalComponent, selector: "mrx-modal", inputs: ["title", "message", "alert", "okText", "closeText", "size", "color", "customClasses", "expandable", "isEmbed", "isClose", "isBack", "backText", "enableFooter", "alignButtons", "isLoading", "iconPosition"], outputs: ["ok", "close", "back", "expand"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "component", type: i1.ButtonComponent, selector: "mrx-button", inputs: ["size", "type", "color", "iconPosition", "active", "disabled", "isLoading", "iconOnly", "customClasses", "label", "icon", "iconClass", "buttonType", "href", "target", "routerLink", "queryParams"], outputs: ["mrxClick"] }, { kind: "component", type: FormDispenserModal, selector: "app-form-dispenser-modal", inputs: ["sectionSettings", "values", "valueMode"], outputs: ["changed"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
86
99
|
}
|
|
87
100
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputTableModalComponent, decorators: [{
|
|
88
101
|
type: Component,
|
|
@@ -93,9 +106,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
93
106
|
], providers: [
|
|
94
107
|
provideNgxMask(),
|
|
95
108
|
ReferenceService // для компонента список
|
|
96
|
-
], template: "<mrx-modal\r\n [title]=\"title\"\r\n size=\"large\"\r\n (close)=\"close()\"\r\n (ok)=\"ok()\"\r\n>\r\n <app-form-dispenser-modal\r\n [sectionSettings]=\"settings\"\r\n [values]=\"rowModel.data\"\r\n [valueMode]=\"'manual'\"\r\n (changed)=\"componentValueChanged($event)\"\r\n ></app-form-dispenser-modal>\r\n\r\n <ng-template #footerContent>\r\n <mrx-button\r\n [customClasses]=\"'mr-3'\"\r\n [type]=\"'secondary'\"\r\n [size]=\"'medium'\"\r\n (click)=\"close()\"\r\n >\u041E\u0442\u043C\u0435\u043D\u0430\r\n </mrx-button>\r\n <mrx-button\r\n [type]=\"'primary'\"\r\n [size]=\"'medium'\"\r\n (click)=\"ok()\"\r\n >{{ okText }}\r\n </mrx-button>\r\n </ng-template>\r\n</mrx-modal>\r\n" }]
|
|
109
|
+
], template: "<mrx-modal\r\n [title]=\"title\"\r\n size=\"large\"\r\n (close)=\"close()\"\r\n (ok)=\"ok()\"\r\n>\r\n <app-form-dispenser-modal\r\n [sectionSettings]=\"settings\"\r\n [values]=\"rowModel.data\"\r\n [valueMode]=\"'manual'\"\r\n (changed)=\"componentValueChanged($event)\"\r\n ></app-form-dispenser-modal>\r\n\r\n <ng-template #footerContent>\r\n <mrx-button\r\n [customClasses]=\"'mr-3'\"\r\n [type]=\"'secondary'\"\r\n [size]=\"'medium'\"\r\n (click)=\"close()\"\r\n >\u041E\u0442\u043C\u0435\u043D\u0430\r\n </mrx-button>\r\n <mrx-button\r\n [type]=\"'primary'\"\r\n [size]=\"'medium'\"\r\n [disabled]=\"emptyRow\"\r\n (click)=\"ok()\"\r\n >{{ okText }}\r\n </mrx-button>\r\n </ng-template>\r\n</mrx-modal>\r\n" }]
|
|
97
110
|
}], ctorParameters: () => [{ type: i1.ModalRef }, { type: i2.Store }, { type: undefined, decorators: [{
|
|
98
111
|
type: Inject,
|
|
99
112
|
args: [MODAL_DATA]
|
|
100
113
|
}] }] });
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-table-modal.component.js","sourceRoot":"","sources":["../../../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/table/components/input-table-modal/input-table-modal.component.ts","../../../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/table/components/input-table-modal/input-table-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Inject } from '@angular/core';\r\nimport { isArray } from 'lodash-es';\r\nimport { ButtonModule, MODAL_DATA, ModalModule, ModalRef, ModalServiceComponent } from '@myrtex-org/ui';\r\nimport { InputTableModel } from '../../../../../../models/elemets/inputs';\r\nimport { ComponentValueModel, TableRowModel } from '../../../../../../models';\r\nimport { FormDispenserModal } from './form-dispenser-modal/form-dispenser-modal.component';\r\nimport { provideNgxMask } from 'ngx-mask';\r\nimport { ReferenceService } from '../../../../../../services';\r\nimport { Store } from '@ngrx/store';\r\nimport { objectFormActions } from '../../../../../../store';\r\nimport { ComponentModelBase } from '../../../../../../../shared-form/models';\r\nimport { ComponentType } from '../../../../../../../shared-form/enums';\r\n\r\nexport interface InputTableModalParams {\r\n  title: string;\r\n  okText: string;\r\n  settings: InputTableModel;\r\n  rowModel: TableRowModel;\r\n  isCheckRequired: boolean;\r\n}\r\n\r\nexport interface InputTableModalResult {\r\n  result: boolean;\r\n  rowModel: TableRowModel;\r\n}\r\n\r\n@Component({\r\n  selector: 'app-input-table-modal',\r\n  templateUrl: './input-table-modal.component.html',\r\n  styleUrls: ['./input-table-modal.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [\r\n    ModalModule,\r\n    ButtonModule,\r\n    FormDispenserModal,\r\n  ],\r\n  providers: [\r\n    provideNgxMask(),\r\n    ReferenceService // для компонента список\r\n  ]\r\n})\r\nexport class InputTableModalComponent extends ModalServiceComponent<InputTableModalParams, InputTableModalResult> {\r\n  public title!: string;\r\n  public okText!: string;\r\n  public settings!: InputTableModel;\r\n  public rowModel!: TableRowModel;\r\n  // Запоминаем статус проверки формы при открытии модалки\r\n  public isCheckRequired!: boolean;\r\n\r\n  constructor(\r\n    private dialogRef: ModalRef<InputTableModalResult>,\r\n    private store: Store,\r\n    @Inject(MODAL_DATA) data: InputTableModalParams,\r\n  ) {\r\n    super();\r\n\r\n    this.title = data.title;\r\n    this.okText = data.okText\r\n    this.settings = data.settings;\r\n    this.rowModel = data.rowModel;\r\n    this.isCheckRequired = data.isCheckRequired;\r\n\r\n    this.result = {result: false, rowModel: this.rowModel};\r\n  }\r\n\r\n  public componentValueChanged(valueModel: ComponentValueModel | ComponentValueModel[]) {\r\n    if (isArray(valueModel)) {\r\n      valueModel.forEach(model => {\r\n        this._transformValues(model);\r\n      });\r\n    } else {\r\n      this._transformValues(valueModel);\r\n    }\r\n  }\r\n\r\n  public ok() {\r\n    if (!this._isValid())\r\n    {\r\n      // включаем подсветку полей\r\n      this.store.dispatch(objectFormActions.updateCheckRequired({ isCheckRequired: true }));\r\n      return;\r\n    }\r\n\r\n    // возвращаем признак как был до открытия модалки\r\n    this.store.dispatch(objectFormActions.updateCheckRequired({ isCheckRequired: this.isCheckRequired }));\r\n\r\n    this.result = {result: true, rowModel: this.rowModel};\r\n    this.dialogRef.close(structuredClone(this.result));\r\n  }\r\n\r\n  public close() {\r\n    // возвращаем признак как был до открытия модалки\r\n    this.store.dispatch(objectFormActions.updateCheckRequired({ isCheckRequired: this.isCheckRequired }));\r\n\r\n    this.result = {result: false, rowModel: this.rowModel};\r\n    this.dialogRef.close(this.result);\r\n  }\r\n\r\n  private _transformValues(value: ComponentValueModel) {\r\n    const cloneRowModel = structuredClone(this.rowModel);\r\n    const findValue: ComponentValueModel | undefined = cloneRowModel.data.find((c: ComponentValueModel) => c.sysName === value.sysName);\r\n\r\n    if (findValue) {\r\n      findValue.value = value.value;\r\n    }\r\n\r\n    this.rowModel = cloneRowModel;\r\n  }\r\n\r\n  private _isValid(): boolean {\r\n    var hasError = false;\r\n    var requiredComponents = this._getRequiredComponents(this.settings.components);\r\n    for (const component of requiredComponents) {\r\n      const value = this.rowModel.data\r\n        .find(x => x.sysName == component.sysName\r\n              || x.sysName == `${component.sysName}_start`\r\n              || x.sysName == `${component.sysName}_end`);\r\n      if (!value?.value) {\r\n        hasError = true;\r\n        break;\r\n      }\r\n    }\r\n    return !hasError;\r\n  }\r\n\r\n  private _getRequiredComponents(components: ComponentModelBase[]): ComponentModelBase[]{\r\n    var components = components.filter(x => x.type != ComponentType.Group && !!x.options.required);\r\n    for (const component of components.filter(x => x.type == ComponentType.Group && x.components.length > 0)) {\r\n      this._getRequiredComponents(component.components);\r\n    }\r\n    return components;\r\n  }\r\n}\r\n","<mrx-modal\r\n  [title]=\"title\"\r\n  size=\"large\"\r\n  (close)=\"close()\"\r\n  (ok)=\"ok()\"\r\n>\r\n  <app-form-dispenser-modal\r\n    [sectionSettings]=\"settings\"\r\n    [values]=\"rowModel.data\"\r\n    [valueMode]=\"'manual'\"\r\n    (changed)=\"componentValueChanged($event)\"\r\n  ></app-form-dispenser-modal>\r\n\r\n  <ng-template #footerContent>\r\n    <mrx-button\r\n      [customClasses]=\"'mr-3'\"\r\n      [type]=\"'secondary'\"\r\n      [size]=\"'medium'\"\r\n      (click)=\"close()\"\r\n    >Отмена\r\n    </mrx-button>\r\n    <mrx-button\r\n      [type]=\"'primary'\"\r\n      [size]=\"'medium'\"\r\n      (click)=\"ok()\"\r\n    >{{ okText }}\r\n    </mrx-button>\r\n  </ng-template>\r\n</mrx-modal>\r\n"]}
|
|
114
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-table-modal.component.js","sourceRoot":"","sources":["../../../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/table/components/input-table-modal/input-table-modal.component.ts","../../../../../../../../../../../../projects/myrtex-form/src/lib/modules/object-form/components/elements/input/table/components/input-table-modal/input-table-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Inject } from '@angular/core';\r\nimport { isArray } from 'lodash-es';\r\nimport { ButtonModule, MODAL_DATA, ModalModule, ModalRef, ModalServiceComponent } from '@myrtex-org/ui';\r\nimport { InputTableModel } from '../../../../../../models/elemets/inputs';\r\nimport { ComponentValueModel, TableRowModel } from '../../../../../../models';\r\nimport { FormDispenserModal } from './form-dispenser-modal/form-dispenser-modal.component';\r\nimport { provideNgxMask } from 'ngx-mask';\r\nimport { ReferenceService } from '../../../../../../services';\r\nimport { Store } from '@ngrx/store';\r\nimport { objectFormActions } from '../../../../../../store';\r\nimport { ComponentModelBase } from '../../../../../../../shared-form/models';\r\nimport { ComponentType, ValueType } from '../../../../../../../shared-form/enums';\r\n\r\nexport interface InputTableModalParams {\r\n  title: string;\r\n  okText: string;\r\n  settings: InputTableModel;\r\n  rowModel: TableRowModel;\r\n  isCheckRequired: boolean;\r\n}\r\n\r\nexport interface InputTableModalResult {\r\n  result: boolean;\r\n  rowModel: TableRowModel;\r\n}\r\n\r\n@Component({\r\n  selector: 'app-input-table-modal',\r\n  templateUrl: './input-table-modal.component.html',\r\n  styleUrls: ['./input-table-modal.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [\r\n    ModalModule,\r\n    ButtonModule,\r\n    FormDispenserModal,\r\n  ],\r\n  providers: [\r\n    provideNgxMask(),\r\n    ReferenceService // для компонента список\r\n  ]\r\n})\r\nexport class InputTableModalComponent extends ModalServiceComponent<InputTableModalParams, InputTableModalResult> {\r\n  public title!: string;\r\n  public okText!: string;\r\n  public settings!: InputTableModel;\r\n  public rowModel!: TableRowModel;\r\n  // Запоминаем статус проверки формы при открытии модалки\r\n  public isCheckRequired!: boolean;\r\n  public emptyRow: boolean = true;\r\n\r\n  constructor(\r\n    private dialogRef: ModalRef<InputTableModalResult>,\r\n    private store: Store,\r\n    @Inject(MODAL_DATA) data: InputTableModalParams,\r\n  ) {\r\n    super();\r\n\r\n    this.title = data.title;\r\n    this.okText = data.okText\r\n    this.settings = data.settings;\r\n    this.rowModel = data.rowModel;\r\n    this.isCheckRequired = data.isCheckRequired;\r\n\r\n    this.result = {result: false, rowModel: this.rowModel};\r\n  }\r\n\r\n  public componentValueChanged(valueModel: ComponentValueModel | ComponentValueModel[]) {\r\n    if (isArray(valueModel)) {\r\n      valueModel.forEach(model => {\r\n        this._transformValues(model);\r\n      });\r\n    } else {\r\n      this._transformValues(valueModel);\r\n    }\r\n    this.emptyRow = this.rowModel.data.every(x => this.isEmpty(x.value, x.valueType));\r\n  }\r\n\r\n  public ok() {\r\n    if (!this._isValid())\r\n    {\r\n      // включаем подсветку полей\r\n      this.store.dispatch(objectFormActions.updateCheckRequired({ isCheckRequired: true }));\r\n      return;\r\n    }\r\n\r\n    // возвращаем признак как был до открытия модалки\r\n    this.store.dispatch(objectFormActions.updateCheckRequired({ isCheckRequired: this.isCheckRequired }));\r\n\r\n    this.result = {result: true, rowModel: this.rowModel};\r\n    this.dialogRef.close(structuredClone(this.result));\r\n  }\r\n\r\n  public close() {\r\n    // возвращаем признак как был до открытия модалки\r\n    this.store.dispatch(objectFormActions.updateCheckRequired({ isCheckRequired: this.isCheckRequired }));\r\n\r\n    this.result = {result: false, rowModel: this.rowModel};\r\n    this.dialogRef.close(this.result);\r\n  }\r\n\r\n  private _transformValues(value: ComponentValueModel) {\r\n    const cloneRowModel = structuredClone(this.rowModel);\r\n    const findValue: ComponentValueModel | undefined = cloneRowModel.data.find((c: ComponentValueModel) => c.sysName === value.sysName);\r\n\r\n    if (findValue) {\r\n      findValue.value = value.value;\r\n    }\r\n\r\n    this.rowModel = cloneRowModel;\r\n  }\r\n\r\n  private _isValid(): boolean {\r\n    var hasError = false;\r\n    var requiredComponents = this._getRequiredComponents(this.settings.components);\r\n    for (const component of requiredComponents) {\r\n      const value = this.rowModel.data\r\n        .find(x => x.sysName == component.sysName\r\n              || x.sysName == `${component.sysName}_start`\r\n              || x.sysName == `${component.sysName}_end`);\r\n      if (!value?.value) {\r\n        hasError = true;\r\n        break;\r\n      }\r\n    }\r\n    return !hasError;\r\n  }\r\n\r\n  private _getRequiredComponents(components: ComponentModelBase[]): ComponentModelBase[]{\r\n    var components = components.filter(x => x.type != ComponentType.Group && !!x.options.required);\r\n    for (const component of components.filter(x => x.type == ComponentType.Group && x.components.length > 0)) {\r\n      this._getRequiredComponents(component.components);\r\n    }\r\n    return components;\r\n  }\r\n\r\n  private isEmpty(value: any, type: ValueType): boolean {\r\n    if (type === ValueType.Undefined) return true;\r\n    if (value === null || value === undefined) return true;\r\n    if (type === \"string\" || type === \"guid\") return value === \"\";\r\n    if (Array.isArray(value)) return value.length === 0;\r\n    return false;\r\n  }\r\n}\r\n","<mrx-modal\r\n  [title]=\"title\"\r\n  size=\"large\"\r\n  (close)=\"close()\"\r\n  (ok)=\"ok()\"\r\n>\r\n  <app-form-dispenser-modal\r\n    [sectionSettings]=\"settings\"\r\n    [values]=\"rowModel.data\"\r\n    [valueMode]=\"'manual'\"\r\n    (changed)=\"componentValueChanged($event)\"\r\n  ></app-form-dispenser-modal>\r\n\r\n  <ng-template #footerContent>\r\n    <mrx-button\r\n      [customClasses]=\"'mr-3'\"\r\n      [type]=\"'secondary'\"\r\n      [size]=\"'medium'\"\r\n      (click)=\"close()\"\r\n    >Отмена\r\n    </mrx-button>\r\n    <mrx-button\r\n      [type]=\"'primary'\"\r\n      [size]=\"'medium'\"\r\n      [disabled]=\"emptyRow\"\r\n      (click)=\"ok()\"\r\n    >{{ okText }}\r\n    </mrx-button>\r\n  </ng-template>\r\n</mrx-modal>\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);
|
|
@@ -1961,6 +1961,7 @@ class InputTableModalComponent extends ModalServiceComponent {
|
|
|
1961
1961
|
super();
|
|
1962
1962
|
this.dialogRef = dialogRef;
|
|
1963
1963
|
this.store = store;
|
|
1964
|
+
this.emptyRow = true;
|
|
1964
1965
|
this.title = data.title;
|
|
1965
1966
|
this.okText = data.okText;
|
|
1966
1967
|
this.settings = data.settings;
|
|
@@ -1977,6 +1978,7 @@ class InputTableModalComponent extends ModalServiceComponent {
|
|
|
1977
1978
|
else {
|
|
1978
1979
|
this._transformValues(valueModel);
|
|
1979
1980
|
}
|
|
1981
|
+
this.emptyRow = this.rowModel.data.every(x => this.isEmpty(x.value, x.valueType));
|
|
1980
1982
|
}
|
|
1981
1983
|
ok() {
|
|
1982
1984
|
if (!this._isValid()) {
|
|
@@ -2025,11 +2027,22 @@ class InputTableModalComponent extends ModalServiceComponent {
|
|
|
2025
2027
|
}
|
|
2026
2028
|
return components;
|
|
2027
2029
|
}
|
|
2030
|
+
isEmpty(value, type) {
|
|
2031
|
+
if (type === ValueType.Undefined)
|
|
2032
|
+
return true;
|
|
2033
|
+
if (value === null || value === undefined)
|
|
2034
|
+
return true;
|
|
2035
|
+
if (type === "string" || type === "guid")
|
|
2036
|
+
return value === "";
|
|
2037
|
+
if (Array.isArray(value))
|
|
2038
|
+
return value.length === 0;
|
|
2039
|
+
return false;
|
|
2040
|
+
}
|
|
2028
2041
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputTableModalComponent, deps: [{ token: i1$2.ModalRef }, { token: i2.Store }, { token: MODAL_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2029
2042
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: InputTableModalComponent, isStandalone: true, selector: "app-input-table-modal", providers: [
|
|
2030
2043
|
provideNgxMask(),
|
|
2031
2044
|
ReferenceService // для компонента список
|
|
2032
|
-
], usesInheritance: true, ngImport: i0, template: "<mrx-modal\r\n [title]=\"title\"\r\n size=\"large\"\r\n (close)=\"close()\"\r\n (ok)=\"ok()\"\r\n>\r\n <app-form-dispenser-modal\r\n [sectionSettings]=\"settings\"\r\n [values]=\"rowModel.data\"\r\n [valueMode]=\"'manual'\"\r\n (changed)=\"componentValueChanged($event)\"\r\n ></app-form-dispenser-modal>\r\n\r\n <ng-template #footerContent>\r\n <mrx-button\r\n [customClasses]=\"'mr-3'\"\r\n [type]=\"'secondary'\"\r\n [size]=\"'medium'\"\r\n (click)=\"close()\"\r\n >\u041E\u0442\u043C\u0435\u043D\u0430\r\n </mrx-button>\r\n <mrx-button\r\n [type]=\"'primary'\"\r\n [size]=\"'medium'\"\r\n (click)=\"ok()\"\r\n >{{ okText }}\r\n </mrx-button>\r\n </ng-template>\r\n</mrx-modal>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: ModalModule }, { kind: "component", type: i1$2.ModalComponent, selector: "mrx-modal", inputs: ["title", "message", "alert", "okText", "closeText", "size", "color", "customClasses", "expandable", "isEmbed", "isClose", "isBack", "backText", "enableFooter", "alignButtons", "isLoading", "iconPosition"], outputs: ["ok", "close", "back", "expand"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "component", type: i1$2.ButtonComponent, selector: "mrx-button", inputs: ["size", "type", "color", "iconPosition", "active", "disabled", "isLoading", "iconOnly", "customClasses", "label", "icon", "iconClass", "buttonType", "href", "target", "routerLink", "queryParams"], outputs: ["mrxClick"] }, { kind: "component", type: FormDispenserModal, selector: "app-form-dispenser-modal", inputs: ["sectionSettings", "values", "valueMode"], outputs: ["changed"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
2045
|
+
], usesInheritance: true, ngImport: i0, template: "<mrx-modal\r\n [title]=\"title\"\r\n size=\"large\"\r\n (close)=\"close()\"\r\n (ok)=\"ok()\"\r\n>\r\n <app-form-dispenser-modal\r\n [sectionSettings]=\"settings\"\r\n [values]=\"rowModel.data\"\r\n [valueMode]=\"'manual'\"\r\n (changed)=\"componentValueChanged($event)\"\r\n ></app-form-dispenser-modal>\r\n\r\n <ng-template #footerContent>\r\n <mrx-button\r\n [customClasses]=\"'mr-3'\"\r\n [type]=\"'secondary'\"\r\n [size]=\"'medium'\"\r\n (click)=\"close()\"\r\n >\u041E\u0442\u043C\u0435\u043D\u0430\r\n </mrx-button>\r\n <mrx-button\r\n [type]=\"'primary'\"\r\n [size]=\"'medium'\"\r\n [disabled]=\"emptyRow\"\r\n (click)=\"ok()\"\r\n >{{ okText }}\r\n </mrx-button>\r\n </ng-template>\r\n</mrx-modal>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: ModalModule }, { kind: "component", type: i1$2.ModalComponent, selector: "mrx-modal", inputs: ["title", "message", "alert", "okText", "closeText", "size", "color", "customClasses", "expandable", "isEmbed", "isClose", "isBack", "backText", "enableFooter", "alignButtons", "isLoading", "iconPosition"], outputs: ["ok", "close", "back", "expand"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "component", type: i1$2.ButtonComponent, selector: "mrx-button", inputs: ["size", "type", "color", "iconPosition", "active", "disabled", "isLoading", "iconOnly", "customClasses", "label", "icon", "iconClass", "buttonType", "href", "target", "routerLink", "queryParams"], outputs: ["mrxClick"] }, { kind: "component", type: FormDispenserModal, selector: "app-form-dispenser-modal", inputs: ["sectionSettings", "values", "valueMode"], outputs: ["changed"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
2033
2046
|
}
|
|
2034
2047
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputTableModalComponent, decorators: [{
|
|
2035
2048
|
type: Component,
|
|
@@ -2040,7 +2053,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
2040
2053
|
], providers: [
|
|
2041
2054
|
provideNgxMask(),
|
|
2042
2055
|
ReferenceService // для компонента список
|
|
2043
|
-
], template: "<mrx-modal\r\n [title]=\"title\"\r\n size=\"large\"\r\n (close)=\"close()\"\r\n (ok)=\"ok()\"\r\n>\r\n <app-form-dispenser-modal\r\n [sectionSettings]=\"settings\"\r\n [values]=\"rowModel.data\"\r\n [valueMode]=\"'manual'\"\r\n (changed)=\"componentValueChanged($event)\"\r\n ></app-form-dispenser-modal>\r\n\r\n <ng-template #footerContent>\r\n <mrx-button\r\n [customClasses]=\"'mr-3'\"\r\n [type]=\"'secondary'\"\r\n [size]=\"'medium'\"\r\n (click)=\"close()\"\r\n >\u041E\u0442\u043C\u0435\u043D\u0430\r\n </mrx-button>\r\n <mrx-button\r\n [type]=\"'primary'\"\r\n [size]=\"'medium'\"\r\n (click)=\"ok()\"\r\n >{{ okText }}\r\n </mrx-button>\r\n </ng-template>\r\n</mrx-modal>\r\n" }]
|
|
2056
|
+
], template: "<mrx-modal\r\n [title]=\"title\"\r\n size=\"large\"\r\n (close)=\"close()\"\r\n (ok)=\"ok()\"\r\n>\r\n <app-form-dispenser-modal\r\n [sectionSettings]=\"settings\"\r\n [values]=\"rowModel.data\"\r\n [valueMode]=\"'manual'\"\r\n (changed)=\"componentValueChanged($event)\"\r\n ></app-form-dispenser-modal>\r\n\r\n <ng-template #footerContent>\r\n <mrx-button\r\n [customClasses]=\"'mr-3'\"\r\n [type]=\"'secondary'\"\r\n [size]=\"'medium'\"\r\n (click)=\"close()\"\r\n >\u041E\u0442\u043C\u0435\u043D\u0430\r\n </mrx-button>\r\n <mrx-button\r\n [type]=\"'primary'\"\r\n [size]=\"'medium'\"\r\n [disabled]=\"emptyRow\"\r\n (click)=\"ok()\"\r\n >{{ okText }}\r\n </mrx-button>\r\n </ng-template>\r\n</mrx-modal>\r\n" }]
|
|
2044
2057
|
}], ctorParameters: () => [{ type: i1$2.ModalRef }, { type: i2.Store }, { type: undefined, decorators: [{
|
|
2045
2058
|
type: Inject,
|
|
2046
2059
|
args: [MODAL_DATA]
|