myrta-ui 1.1.27 → 1.1.28
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/esm2020/lib/components/form/formula-editor/formula-editor.component.mjs +28 -39
- package/esm2020/lib/services/mrx-form-validator/validations/callback.validation.mjs +2 -2
- package/esm2020/lib/services/mrx-form-validator/validations/email.validation.mjs +1 -1
- package/esm2020/lib/services/mrx-form-validator/validations/max-length.validation.mjs +1 -1
- package/esm2020/lib/services/mrx-form-validator/validations/min-length.validation.mjs +2 -2
- package/esm2020/lib/services/mrx-form-validator/validations/pattern.validation.mjs +1 -1
- package/esm2020/lib/services/mrx-form-validator/validations/required.validation.mjs +1 -4
- package/fesm2015/myrta-ui.mjs +27 -41
- package/fesm2015/myrta-ui.mjs.map +1 -1
- package/fesm2020/myrta-ui.mjs +27 -41
- package/fesm2020/myrta-ui.mjs.map +1 -1
- package/lib/components/form/formula-editor/formula-editor.component.d.ts +7 -6
- package/lib/services/mrx-form-validator/validations/callback.validation.d.ts +1 -2
- package/lib/services/mrx-form-validator/validations/email.validation.d.ts +1 -2
- package/lib/services/mrx-form-validator/validations/max-length.validation.d.ts +1 -2
- package/lib/services/mrx-form-validator/validations/min-length.validation.d.ts +1 -2
- package/lib/services/mrx-form-validator/validations/pattern.validation.d.ts +1 -2
- package/lib/services/mrx-form-validator/validations/required.validation.d.ts +1 -2
- package/package.json +1 -1
|
@@ -24,8 +24,13 @@ export class FormulaEditorComponent {
|
|
|
24
24
|
endOffset: 0
|
|
25
25
|
};
|
|
26
26
|
this.searchText = '';
|
|
27
|
-
this.
|
|
28
|
-
this.
|
|
27
|
+
this._operatorList = ['+', '-', '*', '/'];
|
|
28
|
+
this._bracketList = ['(', ')'];
|
|
29
|
+
this._itemList = [];
|
|
30
|
+
this._modifiedItemList = {
|
|
31
|
+
items: {},
|
|
32
|
+
regExp: new RegExp(''),
|
|
33
|
+
};
|
|
29
34
|
this.value = '';
|
|
30
35
|
this.visibleValue = '';
|
|
31
36
|
this.isFocused = false;
|
|
@@ -36,8 +41,6 @@ export class FormulaEditorComponent {
|
|
|
36
41
|
// SAVE STATE
|
|
37
42
|
this.uuid = uuidv4();
|
|
38
43
|
this.fields = [];
|
|
39
|
-
// TODO items
|
|
40
|
-
this.items = [];
|
|
41
44
|
this.disabled = false;
|
|
42
45
|
this.readonly = false;
|
|
43
46
|
this.placeholder = '';
|
|
@@ -54,11 +57,17 @@ export class FormulaEditorComponent {
|
|
|
54
57
|
this.onTouched = () => {
|
|
55
58
|
};
|
|
56
59
|
}
|
|
60
|
+
set items(items) {
|
|
61
|
+
const itemsMap = Object.fromEntries(items.map(obj => [obj.label, obj.sysName]));
|
|
62
|
+
this._itemList = items;
|
|
63
|
+
this._modifiedItemList.items = itemsMap;
|
|
64
|
+
this._modifiedItemList.regExp = new RegExp(items.map(s => s.label).join('|'), 'g');
|
|
65
|
+
}
|
|
57
66
|
get getErrorMessage() {
|
|
58
67
|
return this.invalidMessage || ErrorMessagesEnum[this.errorModel.errorType];
|
|
59
68
|
}
|
|
60
69
|
get filteredList() {
|
|
61
|
-
return this.
|
|
70
|
+
return this._itemList.filter(item => item.label.includes(this.searchText));
|
|
62
71
|
}
|
|
63
72
|
get getInvalid() {
|
|
64
73
|
return this.errorModel.isError || this.invalid;
|
|
@@ -77,15 +86,15 @@ export class FormulaEditorComponent {
|
|
|
77
86
|
}
|
|
78
87
|
writeValue(outsideValue) {
|
|
79
88
|
if (outsideValue !== null) {
|
|
80
|
-
const {
|
|
89
|
+
const { visibleValue } = this._transformValue(this._modifiedValue(outsideValue));
|
|
81
90
|
this.value = outsideValue;
|
|
82
91
|
this.visibleValue = visibleValue;
|
|
83
92
|
this._detector.detectChanges();
|
|
84
93
|
}
|
|
85
94
|
}
|
|
86
95
|
onInput(event) {
|
|
87
|
-
const {
|
|
88
|
-
this.updateValue(value);
|
|
96
|
+
const { searchText } = this._transformValue(this._modifiedValue(this._inputValue), false);
|
|
97
|
+
// this.updateValue(value);
|
|
89
98
|
this.searchText = searchText;
|
|
90
99
|
this._storeCursorPosition();
|
|
91
100
|
}
|
|
@@ -121,10 +130,7 @@ export class FormulaEditorComponent {
|
|
|
121
130
|
this.onTouched();
|
|
122
131
|
}
|
|
123
132
|
_modifiedValue(value) {
|
|
124
|
-
|
|
125
|
-
const str = this.items.map(s => s.label);
|
|
126
|
-
const reg = new RegExp(str.join('|'), 'g');
|
|
127
|
-
return value.replace(reg, match => `{${labelsMap[match]}}`);
|
|
133
|
+
return value.replace(this._modifiedItemList.regExp, match => `{${this._modifiedItemList.items[match]}}`);
|
|
128
134
|
}
|
|
129
135
|
_transformValue(content, analise = false) {
|
|
130
136
|
const valueArray = content.split(/[\s\u00A0]+/).filter(Boolean);
|
|
@@ -134,16 +140,16 @@ export class FormulaEditorComponent {
|
|
|
134
140
|
let searchText = '';
|
|
135
141
|
valueArray.forEach((item) => {
|
|
136
142
|
const clearedItem = item.trim();
|
|
137
|
-
const findItem = this.
|
|
143
|
+
const findItem = this._itemList.find(v => clearedItem.includes(v.sysName));
|
|
138
144
|
if (findItem) {
|
|
139
145
|
visibleValueArray.push(createTag(findItem.label));
|
|
140
146
|
originalValueArray.push(createTagOutside(findItem.sysName));
|
|
141
147
|
}
|
|
142
|
-
else if (this.
|
|
148
|
+
else if (this._bracketList.find(v => v === clearedItem)) {
|
|
143
149
|
visibleValueArray.push(createBracket(clearedItem));
|
|
144
150
|
originalValueArray.push(clearedItem);
|
|
145
151
|
}
|
|
146
|
-
else if (this.
|
|
152
|
+
else if (this._operatorList.find(v => v === clearedItem)) {
|
|
147
153
|
visibleValueArray.push(createOperator(clearedItem));
|
|
148
154
|
originalValueArray.push(clearedItem);
|
|
149
155
|
}
|
|
@@ -161,8 +167,6 @@ export class FormulaEditorComponent {
|
|
|
161
167
|
if (analise) {
|
|
162
168
|
this._checkErrors(originalValueArray, isInterpretationError);
|
|
163
169
|
}
|
|
164
|
-
console.log(visibleValueArray);
|
|
165
|
-
console.log(originalValueArray);
|
|
166
170
|
return {
|
|
167
171
|
value: originalValueArray.join(' '),
|
|
168
172
|
visibleValue: visibleValueArray.join(' '),
|
|
@@ -172,8 +176,8 @@ export class FormulaEditorComponent {
|
|
|
172
176
|
_checkErrors(valueArray, isInterpretationError) {
|
|
173
177
|
this._disableError();
|
|
174
178
|
this._toggleError(checkBracketErrors(valueArray));
|
|
175
|
-
this._toggleError(checkDividerErrors(valueArray, this.
|
|
176
|
-
this._toggleError(checkSequenceErrors(valueArray, this.
|
|
179
|
+
this._toggleError(checkDividerErrors(valueArray, this._itemList));
|
|
180
|
+
this._toggleError(checkSequenceErrors(valueArray, this._operatorList, this._bracketList));
|
|
177
181
|
this._toggleError(checkInterpretationErrors(isInterpretationError));
|
|
178
182
|
}
|
|
179
183
|
_toggleError(errorModel) {
|
|
@@ -241,27 +245,12 @@ export class FormulaEditorComponent {
|
|
|
241
245
|
});
|
|
242
246
|
}
|
|
243
247
|
clickOut(event) {
|
|
244
|
-
// console.dir(event);
|
|
245
|
-
// console.log(this._modifiedValue(this._inputValue));
|
|
246
248
|
if (!this.eRef.nativeElement.contains(event.target)) {
|
|
247
|
-
const {
|
|
248
|
-
//
|
|
249
|
-
// this.updateValue(value);
|
|
249
|
+
const { visibleValue } = this._transformValue(this._modifiedValue(this._inputValue), true);
|
|
250
250
|
this.updateVisibleValue(visibleValue);
|
|
251
|
-
//
|
|
252
251
|
this.isFocused = false;
|
|
253
252
|
this._detector.detectChanges();
|
|
254
253
|
}
|
|
255
|
-
// if (!this.eRef.nativeElement.contains(event.target)) {
|
|
256
|
-
// console.log(this._inputValue);
|
|
257
|
-
// const {value, visibleValue} = this._transformValue(this._inputValue, true);
|
|
258
|
-
//
|
|
259
|
-
// this.updateValue(value);
|
|
260
|
-
// this.updateVisibleValue(visibleValue);
|
|
261
|
-
//
|
|
262
|
-
// this.isFocused = false;
|
|
263
|
-
// this._detector.detectChanges();
|
|
264
|
-
// }
|
|
265
254
|
}
|
|
266
255
|
registerOnChange(fn) {
|
|
267
256
|
this.onChange = fn;
|
|
@@ -271,7 +260,7 @@ export class FormulaEditorComponent {
|
|
|
271
260
|
}
|
|
272
261
|
}
|
|
273
262
|
FormulaEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FormulaEditorComponent, deps: [{ token: DOCUMENT }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
274
|
-
FormulaEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: FormulaEditorComponent, selector: "mrx-formula-editor", inputs: { fields: "fields",
|
|
263
|
+
FormulaEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: FormulaEditorComponent, selector: "mrx-formula-editor", inputs: { fields: "fields", disabled: "disabled", readonly: "readonly", placeholder: "placeholder", customClasses: "customClasses", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid", items: "items" }, outputs: { changed: "changed", blurred: "blurred", modelChange: "modelChange" }, host: { listeners: { "document:click": "clickOut($event)" } }, providers: [{
|
|
275
264
|
provide: NG_VALUE_ACCESSOR,
|
|
276
265
|
useExisting: forwardRef(() => FormulaEditorComponent),
|
|
277
266
|
multi: true
|
|
@@ -288,8 +277,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
288
277
|
args: [DOCUMENT]
|
|
289
278
|
}] }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }]; }, propDecorators: { fields: [{
|
|
290
279
|
type: Input
|
|
291
|
-
}], items: [{
|
|
292
|
-
type: Input
|
|
293
280
|
}], disabled: [{
|
|
294
281
|
type: Input
|
|
295
282
|
}], readonly: [{
|
|
@@ -304,6 +291,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
304
291
|
type: Input
|
|
305
292
|
}], checkInvalid: [{
|
|
306
293
|
type: Input
|
|
294
|
+
}], items: [{
|
|
295
|
+
type: Input
|
|
307
296
|
}], inputElement: [{
|
|
308
297
|
type: ViewChild,
|
|
309
298
|
args: ['inputElement', { static: true }]
|
|
@@ -317,4 +306,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
317
306
|
type: HostListener,
|
|
318
307
|
args: ['document:click', ['$event']]
|
|
319
308
|
}] } });
|
|
320
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formula-editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/formula-editor/formula-editor.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/formula-editor/formula-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy, ChangeDetectorRef,\r\n  Component, ElementRef, EventEmitter,\r\n  forwardRef, HostListener, Inject, Input,\r\n  Output, ViewChild,\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { ErrorMessagesEnum, ErrorTypeEnum } from './enums/error-messages.enum';\r\nimport { createBracket, createNumber, createOperator, createTag, createTagOutside } from './helpers/create-tags.helper';\r\nimport { isAn } from '../../../helpers/is-number.helper';\r\nimport { WhiteListItemModel } from './models/white-list-item.model';\r\nimport {\r\n  checkBracketErrors,\r\n  checkDividerErrors,\r\n  checkInterpretationErrors,\r\n  checkSequenceErrors\r\n} from './helpers/check-errors.helper';\r\nimport { CheckErrorResultModel } from './models/check-error-result.model';\r\nimport { FormulaEditorValueTypes, FormulaEditorValueWithId } from './models';\r\nimport { InputTextSizesEnum } from '../input-text/input-text.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-formula-editor',\r\n  templateUrl: './formula-editor.component.html',\r\n  styleUrls: ['./formula-editor.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => FormulaEditorComponent),\r\n    multi: true\r\n  }]\r\n})\r\nexport class FormulaEditorComponent implements ControlValueAccessor {\r\n  private _range: any;\r\n  private _selection: Selection | null = null;\r\n  private _cursorPosition: {\r\n    startContainer: Node | null,\r\n    endContainer: Node | null,\r\n    startOffset: number,\r\n    endOffset: number\r\n  } = {\r\n    startContainer: null,\r\n    endContainer: null,\r\n    startOffset: 0,\r\n    endOffset: 0\r\n  };\r\n\r\n  private searchText: string = '';\r\n\r\n  private operatorList: string[] = ['+', '-', '*', '/'];\r\n  private bracketList: string[] = ['(', ')'];\r\n\r\n  public value = '';\r\n  public visibleValue = '';\r\n\r\n  public isFocused = false;\r\n\r\n  public errorModel: CheckErrorResultModel = {\r\n    isError: false,\r\n    errorType: ErrorTypeEnum.Default\r\n  };\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  // TODO items\r\n  @Input() public items: WhiteListItemModel[] = [];\r\n\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public placeholder = '';\r\n  @Input() public customClasses = '';\r\n\r\n  // VALIDATE\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @ViewChild('inputElement', {static: true}) inputElement!: ElementRef<HTMLInputElement>;\r\n\r\n  @Output() public changed: EventEmitter<FormulaEditorValueTypes> = new EventEmitter<FormulaEditorValueTypes>();\r\n  @Output() public blurred: EventEmitter<FormulaEditorValueWithId> = new EventEmitter<FormulaEditorValueWithId>();\r\n  @Output() public modelChange: EventEmitter<FormulaEditorValueWithId> = new EventEmitter<FormulaEditorValueWithId>();\r\n\r\n  constructor(\r\n    @Inject(DOCUMENT) private document: Document,\r\n    private _detector: ChangeDetectorRef,\r\n    private eRef: ElementRef\r\n  ) {\r\n  }\r\n\r\n  public get getErrorMessage(): string | string[] {\r\n    return this.invalidMessage || ErrorMessagesEnum[this.errorModel.errorType];\r\n  }\r\n\r\n  public get filteredList(): WhiteListItemModel[] {\r\n    return this.items.filter(item => item.label.includes(this.searchText))\r\n  }\r\n\r\n  public get getInvalid(): boolean {\r\n    return this.errorModel.isError || this.invalid\r\n  }\r\n\r\n  public get readonlyClass(): string {\r\n    return this.readonly ? 'mrx-input__readonly' : '';\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ? 'mrx-input-checked-success' : this.checkInvalid === true ? 'mrx-input-checked-error' : ''\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${this.customClasses} ${this.readonlyClass} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  private get _inputValue(): string {\r\n    return this.inputElement.nativeElement.textContent || '';\r\n  }\r\n\r\n  writeValue(outsideValue: FormulaEditorValueTypes): void {\r\n    if (outsideValue !== null) {\r\n      const {value, visibleValue} = this._transformValue(this._modifiedValue(outsideValue));\r\n\r\n      this.value = outsideValue;\r\n      this.visibleValue = visibleValue;\r\n\r\n      this._detector.detectChanges()\r\n    }\r\n  }\r\n\r\n  onInput(event: Event) {\r\n    const {value, searchText} = this._transformValue(this._modifiedValue(this._inputValue), false);\r\n\r\n    this.updateValue(value);\r\n    this.searchText = searchText\r\n\r\n    this._storeCursorPosition();\r\n  }\r\n\r\n  onBlur(event: Event) {\r\n    this._storeCursorPosition();\r\n    this.blurred.emit({value: this.value, id: this.uuid})\r\n  }\r\n\r\n  onFocus(event: Event) {\r\n    this.isFocused = true;\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  insertTag(whiteListItem: WhiteListItemModel) {\r\n    this._restoreCursorPosition(this.inputElement.nativeElement);\r\n    this._insertPositionText(`{${whiteListItem.sysName}}`);\r\n\r\n    setTimeout(() => {\r\n      const {value, visibleValue} = this._transformValue(this._modifiedValue(this._inputValue), false);\r\n\r\n      this.updateValue(value);\r\n      this.updateVisibleValue(visibleValue);\r\n    });\r\n\r\n    this._placeCaretAtEnd();\r\n    this.searchText = ''\r\n  }\r\n\r\n  updateVisibleValue(insideValue: string) {\r\n    this.visibleValue = insideValue;\r\n\r\n    this._storeCursorPosition();\r\n\r\n    this._detector.detectChanges()\r\n  }\r\n\r\n  updateValue(insideValue: string) {\r\n    this.value = insideValue;\r\n    this.changed.emit(insideValue);\r\n    this.modelChange.emit({value: insideValue, id: this.uuid});\r\n    this.onChange(insideValue);\r\n    this.onTouched();\r\n  }\r\n\r\n  private _modifiedValue(value: string): string {\r\n    const labelsMap = Object.fromEntries(this.items.map(obj => [obj.label, obj.sysName]));\r\n    const str = this.items.map(s => s.label)\r\n    const reg = new RegExp(str.join('|'), 'g')\r\n\r\n    return value.replace(reg, match => `{${labelsMap[match]}}`)\r\n  }\r\n\r\n  private _transformValue(content: string, analise: boolean = false) {\r\n    const valueArray = content.split(/[\\s\\u00A0]+/).filter(Boolean)\r\n\r\n    const visibleValueArray: string[] = [];\r\n    const originalValueArray: string[] = [];\r\n\r\n    let isInterpretationError = false;\r\n\r\n    let searchText = ''\r\n\r\n    valueArray.forEach((item) => {\r\n      const clearedItem = item.trim();\r\n      const findItem = this.items.find(v => clearedItem.includes(v.sysName) );\r\n\r\n      if (findItem) {\r\n        visibleValueArray.push(createTag(findItem.label));\r\n        originalValueArray.push(createTagOutside(findItem.sysName));\r\n      } else if (this.bracketList.find(v => v === clearedItem)) {\r\n        visibleValueArray.push(createBracket(clearedItem));\r\n        originalValueArray.push(clearedItem);\r\n      } else if (this.operatorList.find(v => v === clearedItem)) {\r\n        visibleValueArray.push(createOperator(clearedItem));\r\n        originalValueArray.push(clearedItem);\r\n      } else if (isAn(clearedItem)) {\r\n        visibleValueArray.push(createNumber(clearedItem));\r\n        originalValueArray.push(clearedItem);\r\n      } else {\r\n        visibleValueArray.push(clearedItem);\r\n        originalValueArray.push(clearedItem);\r\n        searchText = clearedItem\r\n\r\n        isInterpretationError = true;\r\n      }\r\n    });\r\n\r\n    if (analise) {\r\n      this._checkErrors(originalValueArray, isInterpretationError);\r\n    }\r\n\r\n    console.log(visibleValueArray);\r\n    console.log(originalValueArray);\r\n\r\n    return {\r\n      value: originalValueArray.join(' '),\r\n      visibleValue: visibleValueArray.join(' '),\r\n      searchText: searchText\r\n    };\r\n  }\r\n\r\n  private _checkErrors(valueArray: string[], isInterpretationError: boolean) {\r\n    this._disableError();\r\n\r\n    this._toggleError(checkBracketErrors(valueArray));\r\n    this._toggleError(checkDividerErrors(valueArray, this.items));\r\n    this._toggleError(checkSequenceErrors(valueArray, this.operatorList, this.bracketList));\r\n    this._toggleError(checkInterpretationErrors(isInterpretationError));\r\n  }\r\n\r\n  private _toggleError(errorModel: CheckErrorResultModel) {\r\n    if (!this.errorModel.isError) {\r\n      this.errorModel = errorModel;\r\n    }\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  private _disableError() {\r\n    this.errorModel = {\r\n      isError: false,\r\n      errorType: ErrorTypeEnum.Default\r\n    };\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  private _insertPositionText(content: string) {\r\n    const node = document.createTextNode(content);\r\n\r\n    try {\r\n      if (this._range) {\r\n        this._range.deleteContents();\r\n        this._range.insertNode(node);\r\n        this._range = this._range.cloneRange();\r\n        this._range.selectNodeContents(node);\r\n        this._range.collapse(false);\r\n      }\r\n    } catch (e) {\r\n    }\r\n  }\r\n\r\n  private _storeCursorPosition() {\r\n    this._selection = window.getSelection();\r\n\r\n    if (this._selection && this._selection.rangeCount > 0) {\r\n      this._range = this._selection.getRangeAt(0);\r\n\r\n      this._cursorPosition.startContainer = this._range.startContainer;\r\n      this._cursorPosition.endContainer = this._range.endContainer;\r\n      this._cursorPosition.startOffset = this._range.startOffset;\r\n      this._cursorPosition.endOffset = this._range.endOffset;\r\n    }\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  private _restoreCursorPosition(element: HTMLInputElement) {\r\n    this._range = document.createRange();\r\n\r\n    if (this._cursorPosition.startContainer && this._cursorPosition.endContainer) {\r\n      this._range.setStart(this._cursorPosition.startContainer, this._cursorPosition.startOffset);\r\n      this._range.setEnd(this._cursorPosition.endContainer, this._cursorPosition.endOffset);\r\n    }\r\n\r\n    this._selection = document.getSelection();\r\n\r\n    if (this._selection) {\r\n      // this._selection.removeAllRanges();\r\n      // this._selection.addRange(this._range);\r\n      // element.focus();\r\n    }\r\n  }\r\n\r\n  private _placeCaretAtEnd() {\r\n    setTimeout(() => {\r\n      this._range = document.createRange();\r\n      this._selection = document.getSelection();\r\n\r\n      if (this._selection) {\r\n        this._range.selectNodeContents(this.inputElement.nativeElement);\r\n        this._range.collapse(false);\r\n        this._selection.removeAllRanges();\r\n        this._selection.addRange(this._range);\r\n        this.inputElement.nativeElement.focus();\r\n      }\r\n    });\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  clickOut(event: Event) {\r\n    // console.dir(event);\r\n    // console.log(this._modifiedValue(this._inputValue));\r\n    if (!this.eRef.nativeElement.contains(event.target)) {\r\n      const {value, visibleValue} = this._transformValue(this._modifiedValue(this._inputValue), true);\r\n      //\r\n      // this.updateValue(value);\r\n      this.updateVisibleValue(visibleValue);\r\n      //\r\n      this.isFocused = false;\r\n      this._detector.detectChanges();\r\n    }\r\n\r\n\r\n    // if (!this.eRef.nativeElement.contains(event.target)) {\r\n    //   console.log(this._inputValue);\r\n    //   const {value, visibleValue} = this._transformValue(this._inputValue, true);\r\n    //\r\n    //   this.updateValue(value);\r\n    //   this.updateVisibleValue(visibleValue);\r\n    //\r\n    //   this.isFocused = false;\r\n    //   this._detector.detectChanges();\r\n    // }\r\n  }\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => {}): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  private onChange = (value: any) => {\r\n  };\r\n  private onTouched = () => {\r\n  };\r\n}\r\n","<div\r\n  class=\"mrx-formula-editor\"\r\n  [class.mrx-input-error]=\"getInvalid\"\r\n  [class.-disabled]=\"disabled\"\r\n  [class.-readonly]=\"readonly\"\r\n  [class]=\"getClasses\"\r\n>\r\n  <div class=\"mrx-formula-editor__wrapper\">\r\n    <div\r\n      [innerHTML]=\"visibleValue.trim() | safe\"\r\n      #inputElement\r\n      class=\"mrx-formula-editor__box\"\r\n      contenteditable=\"true\"\r\n      [attr.data-ph]=\"placeholder\"\r\n      (input)=\"onInput($event)\"\r\n      (blur)=\"onBlur($event)\"\r\n      (focus)=\"onFocus($event)\"\r\n    ></div>\r\n\r\n    <div class=\"mrx-formula-editor__popup\" *ngIf=\"isFocused\">\r\n      <ng-container *ngIf=\"errorModel.isError && isFocused\">\r\n        <div class=\"mrx-formula-editor__popup--error\">\r\n          {{ getErrorMessage }}\r\n        </div>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"filteredList.length; else emptyList\">\r\n        <div\r\n          class=\"mrx-formula-editor__popup--row\"\r\n          *ngFor=\"let item of filteredList\"\r\n          (click)=\"insertTag(item); $event.stopPropagation()\"\r\n        >\r\n          {{ item.label }}\r\n        </div>\r\n      </ng-container>\r\n      <ng-template #emptyList>\r\n        <div class=\"mrx-formula-editor__popup--row\">\r\n          Нет результатов\r\n        </div>\r\n      </ng-template>\r\n    </div>\r\n  </div>\r\n\r\n    <mrx-error-message\r\n      *ngIf=\"getInvalid && getErrorMessage && !isFocused\"\r\n      [invalidMessage]=\"getErrorMessage\"\r\n    ></mrx-error-message>\r\n\r\n    <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
|
|
309
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formula-editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/formula-editor/formula-editor.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/formula-editor/formula-editor.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EAAc,YAAY,EACnC,UAAU,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EACvC,MAAM,EAAE,SAAS,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;AAEpC,OAAO,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAC/E,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,cAAc,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AACxH,OAAO,EAAE,IAAI,EAAE,MAAM,mCAAmC,CAAC;AAEzD,OAAO,EACL,kBAAkB,EAClB,kBAAkB,EAClB,yBAAyB,EACzB,mBAAmB,EACpB,MAAM,+BAA+B,CAAC;;;;;;AAcvC,MAAM,OAAO,sBAAsB;IAiEjC,YAC4B,QAAkB,EACpC,SAA4B,EAC5B,IAAgB;QAFE,aAAQ,GAAR,QAAQ,CAAU;QACpC,cAAS,GAAT,SAAS,CAAmB;QAC5B,SAAI,GAAJ,IAAI,CAAY;QAlElB,eAAU,GAAqB,IAAI,CAAC;QACpC,oBAAe,GAKnB;YACF,cAAc,EAAE,IAAI;YACpB,YAAY,EAAE,IAAI;YAClB,WAAW,EAAE,CAAC;YACd,SAAS,EAAE,CAAC;SACb,CAAC;QAEM,eAAU,GAAW,EAAE,CAAC;QAGxB,kBAAa,GAAa,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QAC/C,iBAAY,GAAa,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QACpC,cAAS,GAAyB,EAAE,CAAC;QACrC,sBAAiB,GAAuD;YAC9E,KAAK,EAAE,EAAE;YACT,MAAM,EAAE,IAAI,MAAM,CAAC,EAAE,CAAC;SACvB,CAAC;QAEK,UAAK,GAAG,EAAE,CAAC;QACX,iBAAY,GAAG,EAAE,CAAC;QAElB,cAAS,GAAG,KAAK,CAAC;QAElB,eAAU,GAA0B;YACzC,OAAO,EAAE,KAAK;YACd,SAAS,EAAE,aAAa,CAAC,OAAO;SACjC,CAAC;QAEF,aAAa;QACN,SAAI,GAAW,MAAM,EAAE,CAAC;QACf,WAAM,GAAY,EAAE,CAAC;QAErB,aAAQ,GAAG,KAAK,CAAC;QACjB,aAAQ,GAAG,KAAK,CAAC;QACjB,gBAAW,GAAG,EAAE,CAAC;QACjB,kBAAa,GAAG,EAAE,CAAC;QAEnC,WAAW;QACK,YAAO,GAAG,KAAK,CAAC;QAChB,mBAAc,GAAsB,EAAE,CAAC;QACvC,iBAAY,GAAwB,IAAI,CAAC;QAaxC,YAAO,GAA0C,IAAI,YAAY,EAA2B,CAAC;QAC7F,YAAO,GAA2C,IAAI,YAAY,EAA4B,CAAC;QAC/F,gBAAW,GAA2C,IAAI,YAAY,EAA4B,CAAC;QA+P5G,aAAQ,GAAG,CAAC,KAAU,EAAE,EAAE;QAClC,CAAC,CAAC;QACM,cAAS,GAAG,GAAG,EAAE;QACzB,CAAC,CAAC;IA3PF,CAAC;IApBD,IACI,KAAK,CAAC,KAA2B;QACnC,MAAM,QAAQ,GAAG,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAEhF,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,iBAAiB,CAAC,KAAK,GAAG,QAAQ,CAAC;QACxC,IAAI,CAAC,iBAAiB,CAAC,MAAM,GAAG,IAAI,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;IACrF,CAAC;IAeD,IAAW,eAAe;QACxB,OAAO,IAAI,CAAC,cAAc,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;IAC7E,CAAC;IAED,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;IAC7E,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,UAAU,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC;IACjD,CAAC;IAED,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC;IACpD,CAAC;IAED,IAAW,iBAAiB;QAC1B,OAAO,IAAI,CAAC,YAAY,KAAK,KAAK,CAAC,CAAC,CAAC,2BAA2B,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,KAAK,IAAI,CAAC,CAAC,CAAC,yBAAyB,CAAC,CAAC,CAAC,EAAE,CAAC;IACjI,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,GAAG,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;IACjF,CAAC;IAED,IAAY,WAAW;QACrB,OAAO,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,WAAW,IAAI,EAAE,CAAC;IAC3D,CAAC;IAED,UAAU,CAAC,YAAqC;QAC9C,IAAI,YAAY,KAAK,IAAI,EAAE;YACzB,MAAM,EAAC,YAAY,EAAC,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC,CAAC;YAE/E,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC;YAC1B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;YAEjC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,CAAC;SAChC;IACH,CAAC;IAED,OAAO,CAAC,KAAY;QAClB,MAAM,EAAC,UAAU,EAAC,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,KAAK,CAAC,CAAC;QAExF,2BAA2B;QAC3B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAE7B,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED,MAAM,CAAC,KAAY;QACjB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAC,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,EAAE,EAAE,IAAI,CAAC,IAAI,EAAC,CAAC,CAAC;IACxD,CAAC;IAED,OAAO,CAAC,KAAY;QAClB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC;IAChC,CAAC;IAED,SAAS,CAAC,aAAiC;QACzC,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;QAC7D,IAAI,CAAC,mBAAmB,CAAC,IAAI,aAAa,CAAC,OAAO,GAAG,CAAC,CAAC;QAEvD,UAAU,CAAC,GAAG,EAAE;YACd,MAAM,EAAC,KAAK,EAAE,YAAY,EAAC,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,KAAK,CAAC,CAAC;YAEjG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YACxB,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAExB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;IAED,kBAAkB,CAAC,WAAmB;QACpC,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;QAEhC,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE5B,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,CAAC;IACjC,CAAC;IAED,WAAW,CAAC,WAAmB;QAC7B,IAAI,CAAC,KAAK,GAAG,WAAW,CAAC;QACzB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC/B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAC,KAAK,EAAE,WAAW,EAAE,EAAE,EAAE,IAAI,CAAC,IAAI,EAAC,CAAC,CAAC;QAC3D,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;QAC3B,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAEO,cAAc,CAAC,KAAa;QAClC,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC3G,CAAC;IAEO,eAAe,CAAC,OAAe,EAAE,UAAmB,KAAK;QAC/D,MAAM,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAEhE,MAAM,iBAAiB,GAAa,EAAE,CAAC;QACvC,MAAM,kBAAkB,GAAa,EAAE,CAAC;QAExC,IAAI,qBAAqB,GAAG,KAAK,CAAC;QAElC,IAAI,UAAU,GAAG,EAAE,CAAC;QAEpB,UAAU,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC1B,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;YAChC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;YAE3E,IAAI,QAAQ,EAAE;gBACZ,iBAAiB,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;gBAClD,kBAAkB,CAAC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;aAC7D;iBAAM,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,WAAW,CAAC,EAAE;gBACzD,iBAAiB,CAAC,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC,CAAC;gBACnD,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aACtC;iBAAM,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,WAAW,CAAC,EAAE;gBAC1D,iBAAiB,CAAC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,CAAC;gBACpD,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aACtC;iBAAM,IAAI,IAAI,CAAC,WAAW,CAAC,EAAE;gBAC5B,iBAAiB,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC,CAAC;gBAClD,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aACtC;iBAAM;gBACL,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBACpC,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBACrC,UAAU,GAAG,WAAW,CAAC;gBAEzB,qBAAqB,GAAG,IAAI,CAAC;aAC9B;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,OAAO,EAAE;YACX,IAAI,CAAC,YAAY,CAAC,kBAAkB,EAAE,qBAAqB,CAAC,CAAC;SAC9D;QAED,OAAO;YACL,KAAK,EAAE,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC;YACnC,YAAY,EAAE,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC;YACzC,UAAU,EAAE,UAAU;SACvB,CAAC;IACJ,CAAC;IAEO,YAAY,CAAC,UAAoB,EAAE,qBAA8B;QACvE,IAAI,CAAC,aAAa,EAAE,CAAC;QAErB,IAAI,CAAC,YAAY,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC,CAAC;QAClD,IAAI,CAAC,YAAY,CAAC,kBAAkB,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;QAClE,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,UAAU,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;QAC1F,IAAI,CAAC,YAAY,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,CAAC,CAAC;IACtE,CAAC;IAEO,YAAY,CAAC,UAAiC;QACpD,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE;YAC5B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;SAC9B;QAED,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,CAAC;IACjC,CAAC;IAEO,aAAa;QACnB,IAAI,CAAC,UAAU,GAAG;YAChB,OAAO,EAAE,KAAK;YACd,SAAS,EAAE,aAAa,CAAC,OAAO;SACjC,CAAC;QACF,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,CAAC;IACjC,CAAC;IAEO,mBAAmB,CAAC,OAAe;QACzC,MAAM,IAAI,GAAG,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;QAE9C,IAAI;YACF,IAAI,IAAI,CAAC,MAAM,EAAE;gBACf,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;gBAC7B,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;gBAC7B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;gBACvC,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;gBACrC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;aAC7B;SACF;QAAC,OAAO,CAAC,EAAE;SACX;IACH,CAAC;IAEO,oBAAoB;QAC1B,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QAExC,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,GAAG,CAAC,EAAE;YACrD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YAE5C,IAAI,CAAC,eAAe,CAAC,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC;YACjE,IAAI,CAAC,eAAe,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC;YAC7D,IAAI,CAAC,eAAe,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC;YAC3D,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;SACxD;QACD,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,CAAC;IACjC,CAAC;IAEO,sBAAsB,CAAC,OAAyB;QACtD,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;QAErC,IAAI,IAAI,CAAC,eAAe,CAAC,cAAc,IAAI,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE;YAC5E,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,cAAc,EAAE,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;YAC5F,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;SACvF;QAED,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,YAAY,EAAE,CAAC;QAE1C,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,qCAAqC;YACrC,yCAAyC;YACzC,mBAAmB;SACpB;IACH,CAAC;IAEO,gBAAgB;QACtB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;YACrC,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,YAAY,EAAE,CAAC;YAE1C,IAAI,IAAI,CAAC,UAAU,EAAE;gBACnB,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;gBAChE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;gBAC5B,IAAI,CAAC,UAAU,CAAC,eAAe,EAAE,CAAC;gBAClC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBACtC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;aACzC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAGD,QAAQ,CAAC,KAAY;QACnB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;YACnD,MAAM,EAAC,YAAY,EAAC,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,IAAI,CAAC,CAAC;YAEzF,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,CAAC;YAEtC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,CAAC;SAChC;IACH,CAAC;IAEM,gBAAgB,CAAC,EAAO;QAC7B,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAEM,iBAAiB,CAAC,EAAY;QACnC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;;mHA5TU,sBAAsB,kBAkEvB,QAAQ;uGAlEP,sBAAsB,uaANtB,CAAC;YACV,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC;YACrD,KAAK,EAAE,IAAI;SACZ,CAAC,sJC/BJ,yqDAiDA;2FDhBa,sBAAsB;kBAXlC,SAAS;+BACE,oBAAoB,mBAGb,uBAAuB,CAAC,MAAM,aACpC,CAAC;4BACV,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,uBAAuB,CAAC;4BACrD,KAAK,EAAE,IAAI;yBACZ,CAAC;0DAoEoC,QAAQ;0BAA3C,MAAM;2BAAC,QAAQ;qGA5BF,MAAM;sBAArB,KAAK;gBAEU,QAAQ;sBAAvB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,aAAa;sBAA5B,KAAK;gBAGU,OAAO;sBAAtB,KAAK;gBACU,cAAc;sBAA7B,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBAGF,KAAK;sBADR,KAAK;gBASqC,YAAY;sBAAtD,SAAS;uBAAC,cAAc,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;gBAExB,OAAO;sBAAvB,MAAM;gBACU,OAAO;sBAAvB,MAAM;gBACU,WAAW;sBAA3B,MAAM;gBA4OP,QAAQ;sBADP,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\r\n  ChangeDetectionStrategy, ChangeDetectorRef,\r\n  Component, ElementRef, EventEmitter,\r\n  forwardRef, HostListener, Inject, Input,\r\n  Output, ViewChild,\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { ErrorMessagesEnum, ErrorTypeEnum } from './enums/error-messages.enum';\r\nimport { createBracket, createNumber, createOperator, createTag, createTagOutside } from './helpers/create-tags.helper';\r\nimport { isAn } from '../../../helpers/is-number.helper';\r\nimport { WhiteListItemModel, CheckErrorResultModel } from './models';\r\nimport {\r\n  checkBracketErrors,\r\n  checkDividerErrors,\r\n  checkInterpretationErrors,\r\n  checkSequenceErrors\r\n} from './helpers/check-errors.helper';\r\nimport { FormulaEditorValueTypes, FormulaEditorValueWithId } from './models';\r\n\r\n@Component({\r\n  selector: 'mrx-formula-editor',\r\n  templateUrl: './formula-editor.component.html',\r\n  styleUrls: ['./formula-editor.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => FormulaEditorComponent),\r\n    multi: true\r\n  }]\r\n})\r\nexport class FormulaEditorComponent implements ControlValueAccessor {\r\n  private _range: any;\r\n  private _selection: Selection | null = null;\r\n  private _cursorPosition: {\r\n    startContainer: Node | null,\r\n    endContainer: Node | null,\r\n    startOffset: number,\r\n    endOffset: number\r\n  } = {\r\n    startContainer: null,\r\n    endContainer: null,\r\n    startOffset: 0,\r\n    endOffset: 0\r\n  };\r\n\r\n  private searchText: string = '';\r\n\r\n\r\n  private _operatorList: string[] = ['+', '-', '*', '/'];\r\n  private _bracketList: string[] = ['(', ')'];\r\n  private _itemList: WhiteListItemModel[] = [];\r\n  private _modifiedItemList: { items: { [p: string]: string }, regExp: RegExp } = {\r\n    items: {},\r\n    regExp: new RegExp(''),\r\n  };\r\n\r\n  public value = '';\r\n  public visibleValue = '';\r\n\r\n  public isFocused = false;\r\n\r\n  public errorModel: CheckErrorResultModel = {\r\n    isError: false,\r\n    errorType: ErrorTypeEnum.Default\r\n  };\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public placeholder = '';\r\n  @Input() public customClasses = '';\r\n\r\n  // VALIDATE\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @Input()\r\n  set items(items: WhiteListItemModel[]) {\r\n    const itemsMap = Object.fromEntries(items.map(obj => [obj.label, obj.sysName]));\r\n\r\n    this._itemList = items;\r\n    this._modifiedItemList.items = itemsMap;\r\n    this._modifiedItemList.regExp = new RegExp(items.map(s => s.label).join('|'), 'g');\r\n  }\r\n\r\n  @ViewChild('inputElement', {static: true}) inputElement!: ElementRef<HTMLInputElement>;\r\n\r\n  @Output() public changed: EventEmitter<FormulaEditorValueTypes> = new EventEmitter<FormulaEditorValueTypes>();\r\n  @Output() public blurred: EventEmitter<FormulaEditorValueWithId> = new EventEmitter<FormulaEditorValueWithId>();\r\n  @Output() public modelChange: EventEmitter<FormulaEditorValueWithId> = new EventEmitter<FormulaEditorValueWithId>();\r\n\r\n  constructor(\r\n    @Inject(DOCUMENT) private document: Document,\r\n    private _detector: ChangeDetectorRef,\r\n    private eRef: ElementRef\r\n  ) {\r\n  }\r\n\r\n  public get getErrorMessage(): string | string[] {\r\n    return this.invalidMessage || ErrorMessagesEnum[this.errorModel.errorType];\r\n  }\r\n\r\n  public get filteredList(): WhiteListItemModel[] {\r\n    return this._itemList.filter(item => item.label.includes(this.searchText));\r\n  }\r\n\r\n  public get getInvalid(): boolean {\r\n    return this.errorModel.isError || this.invalid;\r\n  }\r\n\r\n  public get readonlyClass(): string {\r\n    return this.readonly ? 'mrx-input__readonly' : '';\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ? 'mrx-input-checked-success' : this.checkInvalid === true ? 'mrx-input-checked-error' : '';\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${this.customClasses} ${this.readonlyClass} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  private get _inputValue(): string {\r\n    return this.inputElement.nativeElement.textContent || '';\r\n  }\r\n\r\n  writeValue(outsideValue: FormulaEditorValueTypes): void {\r\n    if (outsideValue !== null) {\r\n      const {visibleValue} = this._transformValue(this._modifiedValue(outsideValue));\r\n\r\n      this.value = outsideValue;\r\n      this.visibleValue = visibleValue;\r\n\r\n      this._detector.detectChanges();\r\n    }\r\n  }\r\n\r\n  onInput(event: Event) {\r\n    const {searchText} = this._transformValue(this._modifiedValue(this._inputValue), false);\r\n\r\n    // this.updateValue(value);\r\n    this.searchText = searchText;\r\n\r\n    this._storeCursorPosition();\r\n  }\r\n\r\n  onBlur(event: Event) {\r\n    this._storeCursorPosition();\r\n    this.blurred.emit({value: this.value, id: this.uuid});\r\n  }\r\n\r\n  onFocus(event: Event) {\r\n    this.isFocused = true;\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  insertTag(whiteListItem: WhiteListItemModel) {\r\n    this._restoreCursorPosition(this.inputElement.nativeElement);\r\n    this._insertPositionText(`{${whiteListItem.sysName}}`);\r\n\r\n    setTimeout(() => {\r\n      const {value, visibleValue} = this._transformValue(this._modifiedValue(this._inputValue), false);\r\n\r\n      this.updateValue(value);\r\n      this.updateVisibleValue(visibleValue);\r\n    });\r\n\r\n    this._placeCaretAtEnd();\r\n\r\n    this.searchText = '';\r\n  }\r\n\r\n  updateVisibleValue(insideValue: string) {\r\n    this.visibleValue = insideValue;\r\n\r\n    this._storeCursorPosition();\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  updateValue(insideValue: string) {\r\n    this.value = insideValue;\r\n    this.changed.emit(insideValue);\r\n    this.modelChange.emit({value: insideValue, id: this.uuid});\r\n    this.onChange(insideValue);\r\n    this.onTouched();\r\n  }\r\n\r\n  private _modifiedValue(value: string): string {\r\n    return value.replace(this._modifiedItemList.regExp, match => `{${this._modifiedItemList.items[match]}}`);\r\n  }\r\n\r\n  private _transformValue(content: string, analise: boolean = false) {\r\n    const valueArray = content.split(/[\\s\\u00A0]+/).filter(Boolean);\r\n\r\n    const visibleValueArray: string[] = [];\r\n    const originalValueArray: string[] = [];\r\n\r\n    let isInterpretationError = false;\r\n\r\n    let searchText = '';\r\n\r\n    valueArray.forEach((item) => {\r\n      const clearedItem = item.trim();\r\n      const findItem = this._itemList.find(v => clearedItem.includes(v.sysName));\r\n\r\n      if (findItem) {\r\n        visibleValueArray.push(createTag(findItem.label));\r\n        originalValueArray.push(createTagOutside(findItem.sysName));\r\n      } else if (this._bracketList.find(v => v === clearedItem)) {\r\n        visibleValueArray.push(createBracket(clearedItem));\r\n        originalValueArray.push(clearedItem);\r\n      } else if (this._operatorList.find(v => v === clearedItem)) {\r\n        visibleValueArray.push(createOperator(clearedItem));\r\n        originalValueArray.push(clearedItem);\r\n      } else if (isAn(clearedItem)) {\r\n        visibleValueArray.push(createNumber(clearedItem));\r\n        originalValueArray.push(clearedItem);\r\n      } else {\r\n        visibleValueArray.push(clearedItem);\r\n        originalValueArray.push(clearedItem);\r\n        searchText = clearedItem;\r\n\r\n        isInterpretationError = true;\r\n      }\r\n    });\r\n\r\n    if (analise) {\r\n      this._checkErrors(originalValueArray, isInterpretationError);\r\n    }\r\n\r\n    return {\r\n      value: originalValueArray.join(' '),\r\n      visibleValue: visibleValueArray.join(' '),\r\n      searchText: searchText\r\n    };\r\n  }\r\n\r\n  private _checkErrors(valueArray: string[], isInterpretationError: boolean) {\r\n    this._disableError();\r\n\r\n    this._toggleError(checkBracketErrors(valueArray));\r\n    this._toggleError(checkDividerErrors(valueArray, this._itemList));\r\n    this._toggleError(checkSequenceErrors(valueArray, this._operatorList, this._bracketList));\r\n    this._toggleError(checkInterpretationErrors(isInterpretationError));\r\n  }\r\n\r\n  private _toggleError(errorModel: CheckErrorResultModel) {\r\n    if (!this.errorModel.isError) {\r\n      this.errorModel = errorModel;\r\n    }\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  private _disableError() {\r\n    this.errorModel = {\r\n      isError: false,\r\n      errorType: ErrorTypeEnum.Default\r\n    };\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  private _insertPositionText(content: string) {\r\n    const node = document.createTextNode(content);\r\n\r\n    try {\r\n      if (this._range) {\r\n        this._range.deleteContents();\r\n        this._range.insertNode(node);\r\n        this._range = this._range.cloneRange();\r\n        this._range.selectNodeContents(node);\r\n        this._range.collapse(false);\r\n      }\r\n    } catch (e) {\r\n    }\r\n  }\r\n\r\n  private _storeCursorPosition() {\r\n    this._selection = window.getSelection();\r\n\r\n    if (this._selection && this._selection.rangeCount > 0) {\r\n      this._range = this._selection.getRangeAt(0);\r\n\r\n      this._cursorPosition.startContainer = this._range.startContainer;\r\n      this._cursorPosition.endContainer = this._range.endContainer;\r\n      this._cursorPosition.startOffset = this._range.startOffset;\r\n      this._cursorPosition.endOffset = this._range.endOffset;\r\n    }\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  private _restoreCursorPosition(element: HTMLInputElement) {\r\n    this._range = document.createRange();\r\n\r\n    if (this._cursorPosition.startContainer && this._cursorPosition.endContainer) {\r\n      this._range.setStart(this._cursorPosition.startContainer, this._cursorPosition.startOffset);\r\n      this._range.setEnd(this._cursorPosition.endContainer, this._cursorPosition.endOffset);\r\n    }\r\n\r\n    this._selection = document.getSelection();\r\n\r\n    if (this._selection) {\r\n      // this._selection.removeAllRanges();\r\n      // this._selection.addRange(this._range);\r\n      // element.focus();\r\n    }\r\n  }\r\n\r\n  private _placeCaretAtEnd() {\r\n    setTimeout(() => {\r\n      this._range = document.createRange();\r\n      this._selection = document.getSelection();\r\n\r\n      if (this._selection) {\r\n        this._range.selectNodeContents(this.inputElement.nativeElement);\r\n        this._range.collapse(false);\r\n        this._selection.removeAllRanges();\r\n        this._selection.addRange(this._range);\r\n        this.inputElement.nativeElement.focus();\r\n      }\r\n    });\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  clickOut(event: Event) {\r\n    if (!this.eRef.nativeElement.contains(event.target)) {\r\n      const {visibleValue} = this._transformValue(this._modifiedValue(this._inputValue), true);\r\n\r\n      this.updateVisibleValue(visibleValue);\r\n\r\n      this.isFocused = false;\r\n      this._detector.detectChanges();\r\n    }\r\n  }\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => {}): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  private onChange = (value: any) => {\r\n  };\r\n  private onTouched = () => {\r\n  };\r\n}\r\n","<div\r\n  class=\"mrx-formula-editor\"\r\n  [class.mrx-input-error]=\"getInvalid\"\r\n  [class.-disabled]=\"disabled\"\r\n  [class.-readonly]=\"readonly\"\r\n  [class]=\"getClasses\"\r\n>\r\n  <div class=\"mrx-formula-editor__wrapper\">\r\n    <div\r\n      [innerHTML]=\"visibleValue.trim() | safe\"\r\n      #inputElement\r\n      class=\"mrx-formula-editor__box\"\r\n      contenteditable=\"true\"\r\n      [attr.data-ph]=\"placeholder\"\r\n      (input)=\"onInput($event)\"\r\n      (blur)=\"onBlur($event)\"\r\n      (focus)=\"onFocus($event)\"\r\n    ></div>\r\n\r\n    <div class=\"mrx-formula-editor__popup\" *ngIf=\"isFocused\">\r\n      <ng-container *ngIf=\"errorModel.isError && isFocused\">\r\n        <div class=\"mrx-formula-editor__popup--error\">\r\n          {{ getErrorMessage }}\r\n        </div>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"filteredList.length; else emptyList\">\r\n        <div\r\n          class=\"mrx-formula-editor__popup--row\"\r\n          *ngFor=\"let item of filteredList\"\r\n          (click)=\"insertTag(item); $event.stopPropagation()\"\r\n        >\r\n          {{ item.label }}\r\n        </div>\r\n      </ng-container>\r\n      <ng-template #emptyList>\r\n        <div class=\"mrx-formula-editor__popup--row\">\r\n          Нет результатов\r\n        </div>\r\n      </ng-template>\r\n    </div>\r\n  </div>\r\n\r\n    <mrx-error-message\r\n      *ngIf=\"getInvalid && getErrorMessage && !isFocused\"\r\n      [invalidMessage]=\"getErrorMessage\"\r\n    ></mrx-error-message>\r\n\r\n    <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ValidationTypesEnum } from '../models
|
|
1
|
+
import { ValidationTypesEnum } from '../models';
|
|
2
2
|
import { getErrorMessageHelper } from '../helpers/get-error-message.helper';
|
|
3
3
|
export const callbackValidation = (value, validations, key, invalidMessages) => {
|
|
4
4
|
const result = { isValid: true, message: null };
|
|
@@ -12,4 +12,4 @@ export const callbackValidation = (value, validations, key, invalidMessages) =>
|
|
|
12
12
|
}
|
|
13
13
|
return result;
|
|
14
14
|
};
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsbGJhY2sudmFsaWRhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRhLXVpL3NyYy9saWIvc2VydmljZXMvbXJ4LWZvcm0tdmFsaWRhdG9yL3ZhbGlkYXRpb25zL2NhbGxiYWNrLnZhbGlkYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUE4QixtQkFBbUIsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUM1RSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUU1RSxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxDQUNoQyxLQUFhLEVBQ2IsV0FBNEIsRUFDNUIsR0FBd0IsRUFDeEIsZUFBMEIsRUFDb0IsRUFBRTtJQUVoRCxNQUFNLE1BQU0sR0FBaUQsRUFBQyxPQUFPLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUMsQ0FBQztJQUU1RixJQUFJLFdBQVcsQ0FBQyxtQkFBbUIsQ0FBQyxRQUFRLENBQUMsSUFBSSxPQUFPLFdBQVcsQ0FBQyxtQkFBbUIsQ0FBQyxRQUFRLENBQUMsS0FBSyxVQUFVLEVBQUU7UUFDaEgsTUFBTSxVQUFVLEdBQUcsV0FBVyxDQUFDLG1CQUFtQixDQUFDLFFBQVEsQ0FBYSxDQUFBO1FBQ3hFLE1BQU0sY0FBYyxHQUFHLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUV4QyxJQUFJLGNBQWMsS0FBSyxJQUFJLEVBQUU7WUFDM0IsTUFBTSxDQUFDLE9BQU8sR0FBRyxxQkFBcUIsQ0FBQyxHQUFHLEVBQUUsZUFBZSxFQUFFLFdBQVcsQ0FBQyxRQUFRLENBQUMsQ0FBQTtZQUNsRixNQUFNLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztTQUN4QjtLQUNGO0lBRUQsT0FBTyxNQUFNLENBQUE7QUFDZixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJTWVzc2FnZXMsIFZhbGlkYXRpb25zVHlwZSwgVmFsaWRhdGlvblR5cGVzRW51bSB9IGZyb20gJy4uL21vZGVscyc7XHJcbmltcG9ydCB7IGdldEVycm9yTWVzc2FnZUhlbHBlciB9IGZyb20gJy4uL2hlbHBlcnMvZ2V0LWVycm9yLW1lc3NhZ2UuaGVscGVyJztcclxuXHJcbmV4cG9ydCBjb25zdCBjYWxsYmFja1ZhbGlkYXRpb24gPSAoXHJcbiAgdmFsdWU6IHN0cmluZyxcclxuICB2YWxpZGF0aW9uczogVmFsaWRhdGlvbnNUeXBlLFxyXG4gIGtleTogVmFsaWRhdGlvblR5cGVzRW51bSxcclxuICBpbnZhbGlkTWVzc2FnZXM6IElNZXNzYWdlc1xyXG4pOiB7IGlzVmFsaWQ6IGJvb2xlYW4sIG1lc3NhZ2U6IHN0cmluZyB8IG51bGwgfSA9PiB7XHJcblxyXG4gIGNvbnN0IHJlc3VsdDogeyBpc1ZhbGlkOiBib29sZWFuLCBtZXNzYWdlOiBzdHJpbmcgfCBudWxsIH0gPSB7aXNWYWxpZDogdHJ1ZSwgbWVzc2FnZTogbnVsbH07XHJcblxyXG4gIGlmICh2YWxpZGF0aW9uc1tWYWxpZGF0aW9uVHlwZXNFbnVtLkNhbGxiYWNrXSAmJiB0eXBlb2YgdmFsaWRhdGlvbnNbVmFsaWRhdGlvblR5cGVzRW51bS5DYWxsYmFja10gPT09ICdmdW5jdGlvbicpIHtcclxuICAgIGNvbnN0IHZhbGlkYXRpb24gPSB2YWxpZGF0aW9uc1tWYWxpZGF0aW9uVHlwZXNFbnVtLkNhbGxiYWNrXSBhcyBGdW5jdGlvblxyXG4gICAgY29uc3QgY2FsbGJhY2tSZXN1bHQgPSB2YWxpZGF0aW9uKHZhbHVlKVxyXG5cclxuICAgIGlmIChjYWxsYmFja1Jlc3VsdCAhPT0gbnVsbCkge1xyXG4gICAgICByZXN1bHQubWVzc2FnZSA9IGdldEVycm9yTWVzc2FnZUhlbHBlcihrZXksIGludmFsaWRNZXNzYWdlcywgdmFsaWRhdGlvbnMubWVzc2FnZXMpXHJcbiAgICAgIHJlc3VsdC5pc1ZhbGlkID0gZmFsc2U7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICByZXR1cm4gcmVzdWx0XHJcbn07XHJcbiJdfQ==
|
|
@@ -8,4 +8,4 @@ export const emailValidation = (value, validations, key, invalidMessages) => {
|
|
|
8
8
|
}
|
|
9
9
|
return result;
|
|
10
10
|
};
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1haWwudmFsaWRhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRhLXVpL3NyYy9saWIvc2VydmljZXMvbXJ4LWZvcm0tdmFsaWRhdG9yL3ZhbGlkYXRpb25zL2VtYWlsLnZhbGlkYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFFNUUsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHLENBQzdCLEtBQWEsRUFDYixXQUE0QixFQUM1QixHQUF3QixFQUN4QixlQUEwQixFQUNvQixFQUFFO0lBRWhELE1BQU0sV0FBVyxHQUFHLG9FQUFvRSxDQUFBO0lBQ3hGLE1BQU0sTUFBTSxHQUFpRCxFQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBQyxDQUFDO0lBRTVGLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFO1FBQzVCLE1BQU0sQ0FBQyxPQUFPLEdBQUcscUJBQXFCLENBQUMsR0FBRyxFQUFFLGVBQWUsRUFBRSxXQUFXLENBQUMsUUFBUSxDQUFDLENBQUE7UUFDbEYsTUFBTSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7S0FDeEI7SUFFRCxPQUFPLE1BQU0sQ0FBQTtBQUNmLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElNZXNzYWdlcywgVmFsaWRhdGlvbnNUeXBlLCBWYWxpZGF0aW9uVHlwZXNFbnVtIH0gZnJvbSAnLi4vbW9kZWxzJztcclxuaW1wb3J0IHsgZ2V0RXJyb3JNZXNzYWdlSGVscGVyIH0gZnJvbSAnLi4vaGVscGVycy9nZXQtZXJyb3ItbWVzc2FnZS5oZWxwZXInO1xyXG5cclxuZXhwb3J0IGNvbnN0IGVtYWlsVmFsaWRhdGlvbiA9IChcclxuICB2YWx1ZTogc3RyaW5nLFxyXG4gIHZhbGlkYXRpb25zOiBWYWxpZGF0aW9uc1R5cGUsXHJcbiAga2V5OiBWYWxpZGF0aW9uVHlwZXNFbnVtLFxyXG4gIGludmFsaWRNZXNzYWdlczogSU1lc3NhZ2VzXHJcbik6IHsgaXNWYWxpZDogYm9vbGVhbiwgbWVzc2FnZTogc3RyaW5nIHwgbnVsbCB9ID0+IHtcclxuXHJcbiAgY29uc3QgZW1haWxSZWdFeHAgPSAvXlthLXpBLVowLTkuX9CwLdGP0JAt0K8tXStAW2EtekEtWtCwLdGP0JAt0K8wLTkuLV0rXFwuW2EtekEtWtCwLdGP0JAt0K9dezIsMTB9JC9cclxuICBjb25zdCByZXN1bHQ6IHsgaXNWYWxpZDogYm9vbGVhbiwgbWVzc2FnZTogc3RyaW5nIHwgbnVsbCB9ID0ge2lzVmFsaWQ6IHRydWUsIG1lc3NhZ2U6IG51bGx9O1xyXG5cclxuICBpZiAoIWVtYWlsUmVnRXhwLnRlc3QodmFsdWUpKSB7XHJcbiAgICByZXN1bHQubWVzc2FnZSA9IGdldEVycm9yTWVzc2FnZUhlbHBlcihrZXksIGludmFsaWRNZXNzYWdlcywgdmFsaWRhdGlvbnMubWVzc2FnZXMpXHJcbiAgICByZXN1bHQuaXNWYWxpZCA9IGZhbHNlO1xyXG4gIH1cclxuXHJcbiAgcmV0dXJuIHJlc3VsdFxyXG59O1xyXG4iXX0=
|
|
@@ -7,4 +7,4 @@ export const maxLengthValidation = (value, validations, key, invalidMessages) =>
|
|
|
7
7
|
}
|
|
8
8
|
return result;
|
|
9
9
|
};
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF4LWxlbmd0aC52YWxpZGF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9zZXJ2aWNlcy9tcngtZm9ybS12YWxpZGF0b3IvdmFsaWRhdGlvbnMvbWF4LWxlbmd0aC52YWxpZGF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBRTVFLE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHLENBQ2pDLEtBQXdCLEVBQ3hCLFdBQTRCLEVBQzVCLEdBQXdCLEVBQ3hCLGVBQTBCLEVBQ29CLEVBQUU7SUFFaEQsTUFBTSxNQUFNLEdBQWlELEVBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFDLENBQUM7SUFFNUYsSUFBSSxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRTtRQUNuRCxNQUFNLENBQUMsT0FBTyxHQUFHLHFCQUFxQixDQUFDLEdBQUcsRUFBRSxlQUFlLEVBQUUsV0FBVyxDQUFDLFFBQVEsRUFBRSxNQUFNLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQTtRQUM1RyxNQUFNLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztLQUN4QjtJQUVELE9BQU8sTUFBTSxDQUFBO0FBQ2YsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSU1lc3NhZ2VzLCBWYWxpZGF0aW9uc1R5cGUsIFZhbGlkYXRpb25UeXBlc0VudW0gfSBmcm9tICcuLi9tb2RlbHMnO1xyXG5pbXBvcnQgeyBnZXRFcnJvck1lc3NhZ2VIZWxwZXIgfSBmcm9tICcuLi9oZWxwZXJzL2dldC1lcnJvci1tZXNzYWdlLmhlbHBlcic7XHJcblxyXG5leHBvcnQgY29uc3QgbWF4TGVuZ3RoVmFsaWRhdGlvbiA9IChcclxuICB2YWx1ZTogc3RyaW5nIHwgc3RyaW5nW10sXHJcbiAgdmFsaWRhdGlvbnM6IFZhbGlkYXRpb25zVHlwZSxcclxuICBrZXk6IFZhbGlkYXRpb25UeXBlc0VudW0sXHJcbiAgaW52YWxpZE1lc3NhZ2VzOiBJTWVzc2FnZXNcclxuKTogeyBpc1ZhbGlkOiBib29sZWFuLCBtZXNzYWdlOiBzdHJpbmcgfCBudWxsIH0gPT4ge1xyXG5cclxuICBjb25zdCByZXN1bHQ6IHsgaXNWYWxpZDogYm9vbGVhbiwgbWVzc2FnZTogc3RyaW5nIHwgbnVsbCB9ID0ge2lzVmFsaWQ6IHRydWUsIG1lc3NhZ2U6IG51bGx9O1xyXG5cclxuICBpZiAoU3RyaW5nKHZhbHVlKS5sZW5ndGggPiBOdW1iZXIodmFsaWRhdGlvbnNba2V5XSkpIHtcclxuICAgIHJlc3VsdC5tZXNzYWdlID0gZ2V0RXJyb3JNZXNzYWdlSGVscGVyKGtleSwgaW52YWxpZE1lc3NhZ2VzLCB2YWxpZGF0aW9ucy5tZXNzYWdlcywgTnVtYmVyKHZhbGlkYXRpb25zW2tleV0pKVxyXG4gICAgcmVzdWx0LmlzVmFsaWQgPSBmYWxzZTtcclxuICB9XHJcblxyXG4gIHJldHVybiByZXN1bHRcclxufTtcclxuIl19
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ValidationTypesEnum } from '../models
|
|
1
|
+
import { ValidationTypesEnum } from '../models';
|
|
2
2
|
import { getErrorMessageHelper } from '../helpers/get-error-message.helper';
|
|
3
3
|
export const minLengthValidation = (value, validations, key, invalidMessages) => {
|
|
4
4
|
const result = { isValid: true, message: null };
|
|
@@ -8,4 +8,4 @@ export const minLengthValidation = (value, validations, key, invalidMessages) =>
|
|
|
8
8
|
}
|
|
9
9
|
return result;
|
|
10
10
|
};
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWluLWxlbmd0aC52YWxpZGF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9zZXJ2aWNlcy9tcngtZm9ybS12YWxpZGF0b3IvdmFsaWRhdGlvbnMvbWluLWxlbmd0aC52YWxpZGF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBOEIsbUJBQW1CLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDNUUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFFNUUsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsQ0FDakMsS0FBYSxFQUNiLFdBQTRCLEVBQzVCLEdBQXdCLEVBQ3hCLGVBQTBCLEVBQ29CLEVBQUU7SUFFaEQsTUFBTSxNQUFNLEdBQWlELEVBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFDLENBQUM7SUFFNUYsSUFBSSxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsV0FBVyxDQUFDLG1CQUFtQixDQUFDLFFBQVEsQ0FBQyxFQUFFO1FBQ2xHLE1BQU0sQ0FBQyxPQUFPLEdBQUcscUJBQXFCLENBQUMsR0FBRyxFQUFFLGVBQWUsRUFBRSxXQUFXLENBQUMsUUFBUSxFQUFFLE1BQU0sQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFBO1FBQzVHLE1BQU0sQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO0tBQ3hCO0lBRUQsT0FBTyxNQUFNLENBQUE7QUFDZixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJTWVzc2FnZXMsIFZhbGlkYXRpb25zVHlwZSwgVmFsaWRhdGlvblR5cGVzRW51bSB9IGZyb20gJy4uL21vZGVscyc7XHJcbmltcG9ydCB7IGdldEVycm9yTWVzc2FnZUhlbHBlciB9IGZyb20gJy4uL2hlbHBlcnMvZ2V0LWVycm9yLW1lc3NhZ2UuaGVscGVyJztcclxuXHJcbmV4cG9ydCBjb25zdCBtaW5MZW5ndGhWYWxpZGF0aW9uID0gKFxyXG4gIHZhbHVlOiBzdHJpbmcsXHJcbiAgdmFsaWRhdGlvbnM6IFZhbGlkYXRpb25zVHlwZSxcclxuICBrZXk6IFZhbGlkYXRpb25UeXBlc0VudW0sXHJcbiAgaW52YWxpZE1lc3NhZ2VzOiBJTWVzc2FnZXNcclxuKTogeyBpc1ZhbGlkOiBib29sZWFuLCBtZXNzYWdlOiBzdHJpbmcgfCBudWxsIH0gPT4ge1xyXG5cclxuICBjb25zdCByZXN1bHQ6IHsgaXNWYWxpZDogYm9vbGVhbiwgbWVzc2FnZTogc3RyaW5nIHwgbnVsbCB9ID0ge2lzVmFsaWQ6IHRydWUsIG1lc3NhZ2U6IG51bGx9O1xyXG5cclxuICBpZiAoU3RyaW5nKHZhbHVlKS5sZW5ndGggPCBOdW1iZXIodmFsaWRhdGlvbnNba2V5XSkgJiYgISF2YWxpZGF0aW9uc1tWYWxpZGF0aW9uVHlwZXNFbnVtLlJlcXVpcmVkXSkge1xyXG4gICAgcmVzdWx0Lm1lc3NhZ2UgPSBnZXRFcnJvck1lc3NhZ2VIZWxwZXIoa2V5LCBpbnZhbGlkTWVzc2FnZXMsIHZhbGlkYXRpb25zLm1lc3NhZ2VzLCBOdW1iZXIodmFsaWRhdGlvbnNba2V5XSkpXHJcbiAgICByZXN1bHQuaXNWYWxpZCA9IGZhbHNlO1xyXG4gIH1cclxuXHJcbiAgcmV0dXJuIHJlc3VsdFxyXG59O1xyXG4iXX0=
|
|
@@ -8,4 +8,4 @@ export const patternValidation = (value, validations, key, invalidMessages) => {
|
|
|
8
8
|
}
|
|
9
9
|
return result;
|
|
10
10
|
};
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF0dGVybi52YWxpZGF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9zZXJ2aWNlcy9tcngtZm9ybS12YWxpZGF0b3IvdmFsaWRhdGlvbnMvcGF0dGVybi52YWxpZGF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBRTVFLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLENBQy9CLEtBQWEsRUFDYixXQUE0QixFQUM1QixHQUF3QixFQUN4QixlQUEwQixFQUNvQixFQUFFO0lBRWhELE1BQU0sVUFBVSxHQUFHLFdBQVcsQ0FBQyxHQUFHLENBQVcsQ0FBQTtJQUM3QyxNQUFNLE1BQU0sR0FBaUQsRUFBQyxPQUFPLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUMsQ0FBQztJQUU1RixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRTtRQUMzQixNQUFNLENBQUMsT0FBTyxHQUFHLHFCQUFxQixDQUFDLEdBQUcsRUFBRSxlQUFlLEVBQUUsV0FBVyxDQUFDLFFBQVEsQ0FBQyxDQUFBO1FBQ2xGLE1BQU0sQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO0tBQ3hCO0lBRUQsT0FBTyxNQUFNLENBQUE7QUFDZixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJTWVzc2FnZXMsIFZhbGlkYXRpb25zVHlwZSwgVmFsaWRhdGlvblR5cGVzRW51bSB9IGZyb20gJy4uL21vZGVscyc7XHJcbmltcG9ydCB7IGdldEVycm9yTWVzc2FnZUhlbHBlciB9IGZyb20gJy4uL2hlbHBlcnMvZ2V0LWVycm9yLW1lc3NhZ2UuaGVscGVyJztcclxuXHJcbmV4cG9ydCBjb25zdCBwYXR0ZXJuVmFsaWRhdGlvbiA9IChcclxuICB2YWx1ZTogc3RyaW5nLFxyXG4gIHZhbGlkYXRpb25zOiBWYWxpZGF0aW9uc1R5cGUsXHJcbiAga2V5OiBWYWxpZGF0aW9uVHlwZXNFbnVtLFxyXG4gIGludmFsaWRNZXNzYWdlczogSU1lc3NhZ2VzXHJcbik6IHsgaXNWYWxpZDogYm9vbGVhbiwgbWVzc2FnZTogc3RyaW5nIHwgbnVsbCB9ID0+IHtcclxuXHJcbiAgY29uc3QgdmFsaWRhdGlvbiA9IHZhbGlkYXRpb25zW2tleV0gYXMgUmVnRXhwXHJcbiAgY29uc3QgcmVzdWx0OiB7IGlzVmFsaWQ6IGJvb2xlYW4sIG1lc3NhZ2U6IHN0cmluZyB8IG51bGwgfSA9IHtpc1ZhbGlkOiB0cnVlLCBtZXNzYWdlOiBudWxsfTtcclxuXHJcbiAgaWYgKCF2YWxpZGF0aW9uLnRlc3QodmFsdWUpKSB7XHJcbiAgICByZXN1bHQubWVzc2FnZSA9IGdldEVycm9yTWVzc2FnZUhlbHBlcihrZXksIGludmFsaWRNZXNzYWdlcywgdmFsaWRhdGlvbnMubWVzc2FnZXMpXHJcbiAgICByZXN1bHQuaXNWYWxpZCA9IGZhbHNlO1xyXG4gIH1cclxuXHJcbiAgcmV0dXJuIHJlc3VsdFxyXG59O1xyXG4iXX0=
|
|
@@ -1,9 +1,6 @@
|
|
|
1
1
|
import { getErrorMessageHelper } from '../helpers/get-error-message.helper';
|
|
2
2
|
export const requiredValidation = (value, validations, key, invalidMessages) => {
|
|
3
3
|
const result = { isValid: true, message: null };
|
|
4
|
-
console.log(validations);
|
|
5
|
-
console.log(key);
|
|
6
|
-
console.log();
|
|
7
4
|
if (Array.isArray(value) && validations.type !== 'single' && validations[key]) {
|
|
8
5
|
value.forEach((field, idx) => {
|
|
9
6
|
if ((field === '' || field === null || field === undefined)) {
|
|
@@ -22,4 +19,4 @@ export const requiredValidation = (value, validations, key, invalidMessages) =>
|
|
|
22
19
|
}
|
|
23
20
|
return result;
|
|
24
21
|
};
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVxdWlyZWQudmFsaWRhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRhLXVpL3NyYy9saWIvc2VydmljZXMvbXJ4LWZvcm0tdmFsaWRhdG9yL3ZhbGlkYXRpb25zL3JlcXVpcmVkLnZhbGlkYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFFNUUsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUcsQ0FDaEMsS0FBd0IsRUFDeEIsV0FBNEIsRUFDNUIsR0FBd0IsRUFDeEIsZUFBMEIsRUFDb0IsRUFBRTtJQUVoRCxNQUFNLE1BQU0sR0FBaUQsRUFBQyxPQUFPLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUMsQ0FBQztJQUU1RixJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLElBQUksV0FBVyxDQUFDLElBQUksS0FBSyxRQUFRLElBQUksV0FBVyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1FBRTdFLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxLQUFLLEVBQUUsR0FBRyxFQUFFLEVBQUU7WUFDM0IsSUFBSSxDQUFDLEtBQUssS0FBSyxFQUFFLElBQUksS0FBSyxLQUFLLElBQUksSUFBSSxLQUFLLEtBQUssU0FBUyxDQUFDLEVBQUU7Z0JBQzNELE1BQU0sQ0FBQyxPQUFPLEdBQUcscUJBQXFCLENBQUMsR0FBRyxFQUFFLGVBQWUsRUFBRSxXQUFXLENBQUMsUUFBUSxDQUFDLENBQUM7Z0JBQ25GLE1BQU0sQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO2FBQ3hCO1FBQ0gsQ0FBQyxDQUFDLENBQUM7S0FFSjtTQUFNLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxXQUFXLENBQUMsSUFBSSxLQUFLLFFBQVEsSUFBSSxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSxXQUFXLENBQUMsR0FBRyxDQUFDLEVBQUU7UUFFMUcsTUFBTSxDQUFDLE9BQU8sR0FBRyxxQkFBcUIsQ0FBQyxHQUFHLEVBQUUsZUFBZSxFQUFFLFdBQVcsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUNuRixNQUFNLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztLQUV4QjtTQUFNLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEtBQUssRUFBRSxJQUFJLE1BQU0sQ0FBQyxLQUFLLENBQUMsS0FBSyxPQUFPLElBQUksS0FBSyxLQUFLLElBQUksSUFBSSxLQUFLLEtBQUssU0FBUyxJQUFJLE1BQU0sQ0FBQyxLQUFLLENBQUMsS0FBSyxhQUFhLENBQUMsSUFBSSxXQUFXLENBQUMsR0FBRyxDQUFDLEVBQUU7UUFFOUosTUFBTSxDQUFDLE9BQU8sR0FBRyxxQkFBcUIsQ0FBQyxHQUFHLEVBQUUsZUFBZSxFQUFFLFdBQVcsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUNuRixNQUFNLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztLQUV4QjtJQUVELE9BQU8sTUFBTSxDQUFDO0FBQ2hCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElNZXNzYWdlcywgVmFsaWRhdGlvbnNUeXBlLCBWYWxpZGF0aW9uVHlwZXNFbnVtIH0gZnJvbSAnLi4vbW9kZWxzJztcclxuaW1wb3J0IHsgZ2V0RXJyb3JNZXNzYWdlSGVscGVyIH0gZnJvbSAnLi4vaGVscGVycy9nZXQtZXJyb3ItbWVzc2FnZS5oZWxwZXInO1xyXG5cclxuZXhwb3J0IGNvbnN0IHJlcXVpcmVkVmFsaWRhdGlvbiA9IChcclxuICB2YWx1ZTogc3RyaW5nIHwgc3RyaW5nW10sXHJcbiAgdmFsaWRhdGlvbnM6IFZhbGlkYXRpb25zVHlwZSxcclxuICBrZXk6IFZhbGlkYXRpb25UeXBlc0VudW0sXHJcbiAgaW52YWxpZE1lc3NhZ2VzOiBJTWVzc2FnZXNcclxuKTogeyBpc1ZhbGlkOiBib29sZWFuLCBtZXNzYWdlOiBzdHJpbmcgfCBudWxsIH0gPT4ge1xyXG5cclxuICBjb25zdCByZXN1bHQ6IHsgaXNWYWxpZDogYm9vbGVhbiwgbWVzc2FnZTogc3RyaW5nIHwgbnVsbCB9ID0ge2lzVmFsaWQ6IHRydWUsIG1lc3NhZ2U6IG51bGx9O1xyXG5cclxuICBpZiAoQXJyYXkuaXNBcnJheSh2YWx1ZSkgJiYgdmFsaWRhdGlvbnMudHlwZSAhPT0gJ3NpbmdsZScgJiYgdmFsaWRhdGlvbnNba2V5XSkge1xyXG5cclxuICAgIHZhbHVlLmZvckVhY2goKGZpZWxkLCBpZHgpID0+IHtcclxuICAgICAgaWYgKChmaWVsZCA9PT0gJycgfHwgZmllbGQgPT09IG51bGwgfHwgZmllbGQgPT09IHVuZGVmaW5lZCkpIHtcclxuICAgICAgICByZXN1bHQubWVzc2FnZSA9IGdldEVycm9yTWVzc2FnZUhlbHBlcihrZXksIGludmFsaWRNZXNzYWdlcywgdmFsaWRhdGlvbnMubWVzc2FnZXMpO1xyXG4gICAgICAgIHJlc3VsdC5pc1ZhbGlkID0gZmFsc2U7XHJcbiAgICAgIH1cclxuICAgIH0pO1xyXG5cclxuICB9IGVsc2UgaWYgKEFycmF5LmlzQXJyYXkodmFsdWUpICYmIHZhbGlkYXRpb25zLnR5cGUgPT09ICdzaW5nbGUnICYmIHZhbHVlLmxlbmd0aCA9PT0gMCAmJiB2YWxpZGF0aW9uc1trZXldKSB7XHJcblxyXG4gICAgcmVzdWx0Lm1lc3NhZ2UgPSBnZXRFcnJvck1lc3NhZ2VIZWxwZXIoa2V5LCBpbnZhbGlkTWVzc2FnZXMsIHZhbGlkYXRpb25zLm1lc3NhZ2VzKTtcclxuICAgIHJlc3VsdC5pc1ZhbGlkID0gZmFsc2U7XHJcblxyXG4gIH0gZWxzZSBpZiAoKFN0cmluZyh2YWx1ZSkgPT09ICcnIHx8IFN0cmluZyh2YWx1ZSkgPT09ICdmYWxzZScgfHwgdmFsdWUgPT09IG51bGwgfHwgdmFsdWUgPT09IHVuZGVmaW5lZCB8fCBTdHJpbmcodmFsdWUpID09PSAnPHA+PGJyPjwvcD4nKSAmJiB2YWxpZGF0aW9uc1trZXldKSB7XHJcblxyXG4gICAgcmVzdWx0Lm1lc3NhZ2UgPSBnZXRFcnJvck1lc3NhZ2VIZWxwZXIoa2V5LCBpbnZhbGlkTWVzc2FnZXMsIHZhbGlkYXRpb25zLm1lc3NhZ2VzKTtcclxuICAgIHJlc3VsdC5pc1ZhbGlkID0gZmFsc2U7XHJcblxyXG4gIH1cclxuXHJcbiAgcmV0dXJuIHJlc3VsdDtcclxufTtcclxuIl19
|
package/fesm2015/myrta-ui.mjs
CHANGED
|
@@ -4265,9 +4265,6 @@ const getErrorMessageHelper = (key, invalidMessages, messages, params) => {
|
|
|
4265
4265
|
|
|
4266
4266
|
const requiredValidation = (value, validations, key, invalidMessages) => {
|
|
4267
4267
|
const result = { isValid: true, message: null };
|
|
4268
|
-
console.log(validations);
|
|
4269
|
-
console.log(key);
|
|
4270
|
-
console.log();
|
|
4271
4268
|
if (Array.isArray(value) && validations.type !== 'single' && validations[key]) {
|
|
4272
4269
|
value.forEach((field, idx) => {
|
|
4273
4270
|
if ((field === '' || field === null || field === undefined)) {
|
|
@@ -17390,8 +17387,13 @@ class FormulaEditorComponent {
|
|
|
17390
17387
|
endOffset: 0
|
|
17391
17388
|
};
|
|
17392
17389
|
this.searchText = '';
|
|
17393
|
-
this.
|
|
17394
|
-
this.
|
|
17390
|
+
this._operatorList = ['+', '-', '*', '/'];
|
|
17391
|
+
this._bracketList = ['(', ')'];
|
|
17392
|
+
this._itemList = [];
|
|
17393
|
+
this._modifiedItemList = {
|
|
17394
|
+
items: {},
|
|
17395
|
+
regExp: new RegExp(''),
|
|
17396
|
+
};
|
|
17395
17397
|
this.value = '';
|
|
17396
17398
|
this.visibleValue = '';
|
|
17397
17399
|
this.isFocused = false;
|
|
@@ -17402,8 +17404,6 @@ class FormulaEditorComponent {
|
|
|
17402
17404
|
// SAVE STATE
|
|
17403
17405
|
this.uuid = v4();
|
|
17404
17406
|
this.fields = [];
|
|
17405
|
-
// TODO items
|
|
17406
|
-
this.items = [];
|
|
17407
17407
|
this.disabled = false;
|
|
17408
17408
|
this.readonly = false;
|
|
17409
17409
|
this.placeholder = '';
|
|
@@ -17420,11 +17420,17 @@ class FormulaEditorComponent {
|
|
|
17420
17420
|
this.onTouched = () => {
|
|
17421
17421
|
};
|
|
17422
17422
|
}
|
|
17423
|
+
set items(items) {
|
|
17424
|
+
const itemsMap = Object.fromEntries(items.map(obj => [obj.label, obj.sysName]));
|
|
17425
|
+
this._itemList = items;
|
|
17426
|
+
this._modifiedItemList.items = itemsMap;
|
|
17427
|
+
this._modifiedItemList.regExp = new RegExp(items.map(s => s.label).join('|'), 'g');
|
|
17428
|
+
}
|
|
17423
17429
|
get getErrorMessage() {
|
|
17424
17430
|
return this.invalidMessage || ErrorMessagesEnum[this.errorModel.errorType];
|
|
17425
17431
|
}
|
|
17426
17432
|
get filteredList() {
|
|
17427
|
-
return this.
|
|
17433
|
+
return this._itemList.filter(item => item.label.includes(this.searchText));
|
|
17428
17434
|
}
|
|
17429
17435
|
get getInvalid() {
|
|
17430
17436
|
return this.errorModel.isError || this.invalid;
|
|
@@ -17443,15 +17449,15 @@ class FormulaEditorComponent {
|
|
|
17443
17449
|
}
|
|
17444
17450
|
writeValue(outsideValue) {
|
|
17445
17451
|
if (outsideValue !== null) {
|
|
17446
|
-
const {
|
|
17452
|
+
const { visibleValue } = this._transformValue(this._modifiedValue(outsideValue));
|
|
17447
17453
|
this.value = outsideValue;
|
|
17448
17454
|
this.visibleValue = visibleValue;
|
|
17449
17455
|
this._detector.detectChanges();
|
|
17450
17456
|
}
|
|
17451
17457
|
}
|
|
17452
17458
|
onInput(event) {
|
|
17453
|
-
const {
|
|
17454
|
-
this.updateValue(value);
|
|
17459
|
+
const { searchText } = this._transformValue(this._modifiedValue(this._inputValue), false);
|
|
17460
|
+
// this.updateValue(value);
|
|
17455
17461
|
this.searchText = searchText;
|
|
17456
17462
|
this._storeCursorPosition();
|
|
17457
17463
|
}
|
|
@@ -17487,10 +17493,7 @@ class FormulaEditorComponent {
|
|
|
17487
17493
|
this.onTouched();
|
|
17488
17494
|
}
|
|
17489
17495
|
_modifiedValue(value) {
|
|
17490
|
-
|
|
17491
|
-
const str = this.items.map(s => s.label);
|
|
17492
|
-
const reg = new RegExp(str.join('|'), 'g');
|
|
17493
|
-
return value.replace(reg, match => `{${labelsMap[match]}}`);
|
|
17496
|
+
return value.replace(this._modifiedItemList.regExp, match => `{${this._modifiedItemList.items[match]}}`);
|
|
17494
17497
|
}
|
|
17495
17498
|
_transformValue(content, analise = false) {
|
|
17496
17499
|
const valueArray = content.split(/[\s\u00A0]+/).filter(Boolean);
|
|
@@ -17500,16 +17503,16 @@ class FormulaEditorComponent {
|
|
|
17500
17503
|
let searchText = '';
|
|
17501
17504
|
valueArray.forEach((item) => {
|
|
17502
17505
|
const clearedItem = item.trim();
|
|
17503
|
-
const findItem = this.
|
|
17506
|
+
const findItem = this._itemList.find(v => clearedItem.includes(v.sysName));
|
|
17504
17507
|
if (findItem) {
|
|
17505
17508
|
visibleValueArray.push(createTag(findItem.label));
|
|
17506
17509
|
originalValueArray.push(createTagOutside(findItem.sysName));
|
|
17507
17510
|
}
|
|
17508
|
-
else if (this.
|
|
17511
|
+
else if (this._bracketList.find(v => v === clearedItem)) {
|
|
17509
17512
|
visibleValueArray.push(createBracket(clearedItem));
|
|
17510
17513
|
originalValueArray.push(clearedItem);
|
|
17511
17514
|
}
|
|
17512
|
-
else if (this.
|
|
17515
|
+
else if (this._operatorList.find(v => v === clearedItem)) {
|
|
17513
17516
|
visibleValueArray.push(createOperator(clearedItem));
|
|
17514
17517
|
originalValueArray.push(clearedItem);
|
|
17515
17518
|
}
|
|
@@ -17527,8 +17530,6 @@ class FormulaEditorComponent {
|
|
|
17527
17530
|
if (analise) {
|
|
17528
17531
|
this._checkErrors(originalValueArray, isInterpretationError);
|
|
17529
17532
|
}
|
|
17530
|
-
console.log(visibleValueArray);
|
|
17531
|
-
console.log(originalValueArray);
|
|
17532
17533
|
return {
|
|
17533
17534
|
value: originalValueArray.join(' '),
|
|
17534
17535
|
visibleValue: visibleValueArray.join(' '),
|
|
@@ -17538,8 +17539,8 @@ class FormulaEditorComponent {
|
|
|
17538
17539
|
_checkErrors(valueArray, isInterpretationError) {
|
|
17539
17540
|
this._disableError();
|
|
17540
17541
|
this._toggleError(checkBracketErrors(valueArray));
|
|
17541
|
-
this._toggleError(checkDividerErrors(valueArray, this.
|
|
17542
|
-
this._toggleError(checkSequenceErrors(valueArray, this.
|
|
17542
|
+
this._toggleError(checkDividerErrors(valueArray, this._itemList));
|
|
17543
|
+
this._toggleError(checkSequenceErrors(valueArray, this._operatorList, this._bracketList));
|
|
17543
17544
|
this._toggleError(checkInterpretationErrors(isInterpretationError));
|
|
17544
17545
|
}
|
|
17545
17546
|
_toggleError(errorModel) {
|
|
@@ -17607,27 +17608,12 @@ class FormulaEditorComponent {
|
|
|
17607
17608
|
});
|
|
17608
17609
|
}
|
|
17609
17610
|
clickOut(event) {
|
|
17610
|
-
// console.dir(event);
|
|
17611
|
-
// console.log(this._modifiedValue(this._inputValue));
|
|
17612
17611
|
if (!this.eRef.nativeElement.contains(event.target)) {
|
|
17613
|
-
const {
|
|
17614
|
-
//
|
|
17615
|
-
// this.updateValue(value);
|
|
17612
|
+
const { visibleValue } = this._transformValue(this._modifiedValue(this._inputValue), true);
|
|
17616
17613
|
this.updateVisibleValue(visibleValue);
|
|
17617
|
-
//
|
|
17618
17614
|
this.isFocused = false;
|
|
17619
17615
|
this._detector.detectChanges();
|
|
17620
17616
|
}
|
|
17621
|
-
// if (!this.eRef.nativeElement.contains(event.target)) {
|
|
17622
|
-
// console.log(this._inputValue);
|
|
17623
|
-
// const {value, visibleValue} = this._transformValue(this._inputValue, true);
|
|
17624
|
-
//
|
|
17625
|
-
// this.updateValue(value);
|
|
17626
|
-
// this.updateVisibleValue(visibleValue);
|
|
17627
|
-
//
|
|
17628
|
-
// this.isFocused = false;
|
|
17629
|
-
// this._detector.detectChanges();
|
|
17630
|
-
// }
|
|
17631
17617
|
}
|
|
17632
17618
|
registerOnChange(fn) {
|
|
17633
17619
|
this.onChange = fn;
|
|
@@ -17637,7 +17623,7 @@ class FormulaEditorComponent {
|
|
|
17637
17623
|
}
|
|
17638
17624
|
}
|
|
17639
17625
|
FormulaEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FormulaEditorComponent, deps: [{ token: DOCUMENT }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
17640
|
-
FormulaEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: FormulaEditorComponent, selector: "mrx-formula-editor", inputs: { fields: "fields",
|
|
17626
|
+
FormulaEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: FormulaEditorComponent, selector: "mrx-formula-editor", inputs: { fields: "fields", disabled: "disabled", readonly: "readonly", placeholder: "placeholder", customClasses: "customClasses", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid", items: "items" }, outputs: { changed: "changed", blurred: "blurred", modelChange: "modelChange" }, host: { listeners: { "document:click": "clickOut($event)" } }, providers: [{
|
|
17641
17627
|
provide: NG_VALUE_ACCESSOR,
|
|
17642
17628
|
useExisting: forwardRef(() => FormulaEditorComponent),
|
|
17643
17629
|
multi: true
|
|
@@ -17656,8 +17642,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
17656
17642
|
}] }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }];
|
|
17657
17643
|
}, propDecorators: { fields: [{
|
|
17658
17644
|
type: Input
|
|
17659
|
-
}], items: [{
|
|
17660
|
-
type: Input
|
|
17661
17645
|
}], disabled: [{
|
|
17662
17646
|
type: Input
|
|
17663
17647
|
}], readonly: [{
|
|
@@ -17672,6 +17656,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
17672
17656
|
type: Input
|
|
17673
17657
|
}], checkInvalid: [{
|
|
17674
17658
|
type: Input
|
|
17659
|
+
}], items: [{
|
|
17660
|
+
type: Input
|
|
17675
17661
|
}], inputElement: [{
|
|
17676
17662
|
type: ViewChild,
|
|
17677
17663
|
args: ['inputElement', { static: true }]
|