myrta-ui 1.1.66 → 1.1.68
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/input-text/input-text.component.mjs +2 -1
- package/esm2020/lib/components/form/input-textarea/input-textarea.component.mjs +2 -1
- package/esm2020/lib/components/table/table.component.mjs +4 -11
- package/fesm2015/myrta-ui.mjs +5 -11
- package/fesm2015/myrta-ui.mjs.map +1 -1
- package/fesm2020/myrta-ui.mjs +5 -10
- package/fesm2020/myrta-ui.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -117,6 +117,7 @@ export class InputTextComponent {
|
|
|
117
117
|
this.blurred.emit({ value: this.formatValue(this.value), id: this.uuid });
|
|
118
118
|
}
|
|
119
119
|
updateValue(insideValue) {
|
|
120
|
+
this.value = this._normalizeValue(insideValue);
|
|
120
121
|
this.changed.emit(this._normalizeValue(this.formatValue(insideValue)));
|
|
121
122
|
this.modelChange.emit({ value: this._normalizeValue(this.formatValue(insideValue)), id: this.uuid });
|
|
122
123
|
this.onChange(this._normalizeValue(this.formatValue(insideValue)));
|
|
@@ -202,4 +203,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
202
203
|
}], modelChange: [{
|
|
203
204
|
type: Output
|
|
204
205
|
}] } });
|
|
205
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-text.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-text/input-text.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-text/input-text.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport {\r\n  InputTextIconColorEnum,\r\n  InputTextIconColorTypes,\r\n  InputTextSizesEnum,\r\n  InputTextSizesTypes,\r\n  InputTextValueTypes,\r\n  InputTextValueWithId\r\n} from './input-text.enum';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\n\r\n@Component({\r\n  selector: 'mrx-input-text',\r\n  templateUrl: './input-text.component.html',\r\n  styleUrls: ['./input-text.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputTextComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class InputTextComponent implements ControlValueAccessor {\r\n  public value: InputTextValueTypes = '';\r\n  public selectionStart: number | undefined;\r\n  public selectionEnd: number | undefined;\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 allowPattern: RegExp | null = null;\r\n  @Input() public required = false;\r\n  @Input() public readonly = false;\r\n  @Input() public maxlength = 0;\r\n  @Input() public minlength = 0;\r\n  @Input() public placeholder = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public size: InputTextSizesTypes = 'large';\r\n  @Input() public isTooltipValue = false;\r\n  @Input() public icon: string | null = null;\r\n  @Input() public iconColor: InputTextIconColorTypes = 'default';\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() public restrictInput = true;\r\n\r\n  // MASK\r\n  @Input() mask = '';\r\n  @Input() maskPrefix = '';\r\n  @Input() showMaskTyped = false;\r\n  @Input() maskDropSpecialCharacters: boolean | string[] = true;\r\n\r\n  @ViewChild('inputElement') inputElement!: ElementRef;\r\n\r\n  @Output() public changed: EventEmitter<InputTextValueTypes> = new EventEmitter<InputTextValueTypes>();\r\n  @Output() public blurred: EventEmitter<InputTextValueWithId> = new EventEmitter<InputTextValueWithId>();\r\n  @Output() public modelChange: EventEmitter<InputTextValueWithId> = new EventEmitter<InputTextValueWithId>();\r\n\r\n  public get getInvalid(): boolean {\r\n    return this._isInvalidValueLength || this.invalid;\r\n  }\r\n\r\n  public get getInvalidMessage(): string | string[] {\r\n    return this._isInvalidValueLength ? 'Превышено допустимое значение символов' : this.invalidMessage;\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 `${InputTextSizesEnum[this.size]} ${this.customClasses} ${this.readonlyClass} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  public get getIconClass(): string {\r\n    return `${this.icon} ${this.size !== 'small' ? 'icon-font-24' : 'icon-font-16'} ${InputTextIconColorEnum[this.iconColor]}`;\r\n  }\r\n\r\n  public get getTooltipValue(): string {\r\n    return this.isTooltipValue ? this.value : '';\r\n  }\r\n\r\n  private _lengthValidate(): boolean {\r\n    return this.maxlength > this.value?.length;\r\n  }\r\n\r\n  private formatValue(value: string): string {\r\n    return value ? value.length === this.maskPrefix.length ? '' : value : '';\r\n  }\r\n\r\n  public insertPositionText(tagText: string): void {\r\n    if (this.selectionStart && this.selectionEnd) {\r\n      const firstText = this.value ? this.value.substring(0, this.selectionStart) : '';\r\n      const secondText = this.value.substring(this.selectionEnd);\r\n      const text = firstText + tagText + secondText;\r\n\r\n      this.updateValue(text);\r\n\r\n      setTimeout(() => {\r\n        this.inputElement.nativeElement.selectionStart = (firstText + tagText).length;\r\n        this.inputElement.nativeElement.selectionEnd = (firstText + tagText).length;\r\n        this.inputElement.nativeElement.focus();\r\n      }, 0);\r\n    } else {\r\n      const text = this.value ? this.value : '' + tagText;\r\n\r\n      this.updateValue(text);\r\n\r\n      setTimeout(() => {\r\n        this.inputElement.nativeElement.selectionStart = text.length;\r\n        this.inputElement.nativeElement.selectionEnd = text.length;\r\n        this.inputElement.nativeElement.focus();\r\n      }, 0);\r\n    }\r\n  }\r\n\r\n  public updateSelection(event: any) {\r\n    this.selectionStart = event.target.selectionStart;\r\n    this.selectionEnd = event.target.selectionEnd;\r\n\r\n    this.blurred.emit();\r\n  }\r\n\r\n  private onChange = (value: InputTextValueTypes) => {\r\n  };\r\n  private onTouched = () => {\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  public writeValue(outsideValue: InputTextValueTypes) {\r\n    this.value = outsideValue;\r\n  }\r\n\r\n  public setDisabledState(isDisabled: boolean) {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  public onBlur(event: FocusEvent) {\r\n    this.updateSelection(event);\r\n    this.blurred.emit({value: this.formatValue(this.value), id: this.uuid});\r\n  }\r\n\r\n  public updateValue(insideValue: InputTextValueTypes) {\r\n    this.changed.emit(this._normalizeValue(this.formatValue(insideValue)));\r\n    this.modelChange.emit({value: this._normalizeValue(this.formatValue(insideValue)), id: this.uuid});\r\n    this.onChange(this._normalizeValue(this.formatValue(insideValue)));\r\n    this.onTouched();\r\n  }\r\n\r\n  private get _isInvalidValueLength(): boolean {\r\n    return this.maxlength < this.value?.length && this.maxlength > 0;\r\n  }\r\n\r\n  public _normalizeValue(value: InputTextValueTypes) {\r\n    if (!this.allowPattern) {\r\n      return value\r\n    }\r\n\r\n    this.inputElement.nativeElement.value = value.replace(this.allowPattern, '');\r\n    return this.inputElement.nativeElement.value\r\n  }\r\n}\r\n","<div\r\n  class=\"mrx-input-text\"\r\n  [class]=\"getClasses\"\r\n  [class.mrx-input-error]=\"getInvalid\"\r\n  [class.mrx-input-text-with-icon]=\"icon\"\r\n  [class.-disabled]=\"disabled\"\r\n  [class.-readonly]=\"readonly\"\r\n  [mrxCdkTooltip]=\"getTooltipValue\"\r\n  [tooltipPosition]=\"'top-start'\"\r\n>\r\n  <div class=\"mrx-input-text__wrapper\">\r\n    <span *ngIf=\"icon\" class=\"mrx-icon mrx-input-text-icon\" [class]=\"getIconClass\"></span>\r\n\r\n    <input\r\n      autocomplete=\"nope\"\r\n      #inputElement\r\n      [type]=\"'text'\"\r\n      [id]=\"uuid\"\r\n      [ngModel]=\"value\"\r\n      [title]=\"placeholder || ''\"\r\n      [disabled]=\"disabled\"\r\n      [readOnly]=\"readonly\"\r\n      [placeholder]=\"!disabled && placeholder ? placeholder : ''\"\r\n      [mask]=\"mask\"\r\n      [prefix]=\"maskPrefix\"\r\n      [showMaskTyped]=\"showMaskTyped\"\r\n      [dropSpecialCharacters]=\"maskDropSpecialCharacters\"\r\n      [minlength]=\"minlength > 0 && restrictInput ? minlength : null\"\r\n      [maxlength]=\"maxlength > 0 && restrictInput ? maxlength : null\"\r\n      (ngModelChange)=\"updateValue($event)\"\r\n      (blur)=\"onBlur($event)\"\r\n    />\r\n\r\n    <mrx-chars-left\r\n      *ngIf=\"!disabled && maxlength\"\r\n      [value]=\"value\"\r\n      [maxlength]=\"maxlength\"\r\n    ></mrx-chars-left>\r\n  </div>\r\n\r\n  <mrx-error-message\r\n    *ngIf=\"getInvalid && getInvalidMessage\"\r\n    [invalidMessage]=\"getInvalidMessage\"\r\n  ></mrx-error-message>\r\n\r\n  <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
|
|
206
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-text.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-text/input-text.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-text/input-text.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport {\r\n  InputTextIconColorEnum,\r\n  InputTextIconColorTypes,\r\n  InputTextSizesEnum,\r\n  InputTextSizesTypes,\r\n  InputTextValueTypes,\r\n  InputTextValueWithId\r\n} from './input-text.enum';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\n\r\n@Component({\r\n  selector: 'mrx-input-text',\r\n  templateUrl: './input-text.component.html',\r\n  styleUrls: ['./input-text.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputTextComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class InputTextComponent implements ControlValueAccessor {\r\n  public value: InputTextValueTypes = '';\r\n  public selectionStart: number | undefined;\r\n  public selectionEnd: number | undefined;\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 allowPattern: RegExp | null = null;\r\n  @Input() public required = false;\r\n  @Input() public readonly = false;\r\n  @Input() public maxlength = 0;\r\n  @Input() public minlength = 0;\r\n  @Input() public placeholder = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public size: InputTextSizesTypes = 'large';\r\n  @Input() public isTooltipValue = false;\r\n  @Input() public icon: string | null = null;\r\n  @Input() public iconColor: InputTextIconColorTypes = 'default';\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() public restrictInput = true;\r\n\r\n  // MASK\r\n  @Input() mask = '';\r\n  @Input() maskPrefix = '';\r\n  @Input() showMaskTyped = false;\r\n  @Input() maskDropSpecialCharacters: boolean | string[] = true;\r\n\r\n  @ViewChild('inputElement') inputElement!: ElementRef;\r\n\r\n  @Output() public changed: EventEmitter<InputTextValueTypes> = new EventEmitter<InputTextValueTypes>();\r\n  @Output() public blurred: EventEmitter<InputTextValueWithId> = new EventEmitter<InputTextValueWithId>();\r\n  @Output() public modelChange: EventEmitter<InputTextValueWithId> = new EventEmitter<InputTextValueWithId>();\r\n\r\n  public get getInvalid(): boolean {\r\n    return this._isInvalidValueLength || this.invalid;\r\n  }\r\n\r\n  public get getInvalidMessage(): string | string[] {\r\n    return this._isInvalidValueLength ? 'Превышено допустимое значение символов' : this.invalidMessage;\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 `${InputTextSizesEnum[this.size]} ${this.customClasses} ${this.readonlyClass} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  public get getIconClass(): string {\r\n    return `${this.icon} ${this.size !== 'small' ? 'icon-font-24' : 'icon-font-16'} ${InputTextIconColorEnum[this.iconColor]}`;\r\n  }\r\n\r\n  public get getTooltipValue(): string {\r\n    return this.isTooltipValue ? this.value : '';\r\n  }\r\n\r\n  private _lengthValidate(): boolean {\r\n    return this.maxlength > this.value?.length;\r\n  }\r\n\r\n  private formatValue(value: string): string {\r\n    return value ? value.length === this.maskPrefix.length ? '' : value : '';\r\n  }\r\n\r\n  public insertPositionText(tagText: string): void {\r\n    if (this.selectionStart && this.selectionEnd) {\r\n      const firstText = this.value ? this.value.substring(0, this.selectionStart) : '';\r\n      const secondText = this.value.substring(this.selectionEnd);\r\n      const text = firstText + tagText + secondText;\r\n\r\n      this.updateValue(text);\r\n\r\n      setTimeout(() => {\r\n        this.inputElement.nativeElement.selectionStart = (firstText + tagText).length;\r\n        this.inputElement.nativeElement.selectionEnd = (firstText + tagText).length;\r\n        this.inputElement.nativeElement.focus();\r\n      }, 0);\r\n    } else {\r\n      const text = this.value ? this.value : '' + tagText;\r\n\r\n      this.updateValue(text);\r\n\r\n      setTimeout(() => {\r\n        this.inputElement.nativeElement.selectionStart = text.length;\r\n        this.inputElement.nativeElement.selectionEnd = text.length;\r\n        this.inputElement.nativeElement.focus();\r\n      }, 0);\r\n    }\r\n  }\r\n\r\n  public updateSelection(event: any) {\r\n    this.selectionStart = event.target.selectionStart;\r\n    this.selectionEnd = event.target.selectionEnd;\r\n\r\n    this.blurred.emit();\r\n  }\r\n\r\n  private onChange = (value: InputTextValueTypes) => {\r\n  };\r\n  private onTouched = () => {\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  public writeValue(outsideValue: InputTextValueTypes) {\r\n    this.value = outsideValue;\r\n  }\r\n\r\n  public setDisabledState(isDisabled: boolean) {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  public onBlur(event: FocusEvent) {\r\n    this.updateSelection(event);\r\n    this.blurred.emit({value: this.formatValue(this.value), id: this.uuid});\r\n  }\r\n\r\n  public updateValue(insideValue: InputTextValueTypes) {\r\n    this.value = this._normalizeValue(insideValue);\r\n    this.changed.emit(this._normalizeValue(this.formatValue(insideValue)));\r\n    this.modelChange.emit({value: this._normalizeValue(this.formatValue(insideValue)), id: this.uuid});\r\n    this.onChange(this._normalizeValue(this.formatValue(insideValue)));\r\n    this.onTouched();\r\n  }\r\n\r\n  private get _isInvalidValueLength(): boolean {\r\n    return this.maxlength < this.value?.length && this.maxlength > 0;\r\n  }\r\n\r\n  public _normalizeValue(value: InputTextValueTypes) {\r\n    if (!this.allowPattern) {\r\n      return value\r\n    }\r\n\r\n    this.inputElement.nativeElement.value = value.replace(this.allowPattern, '');\r\n    return this.inputElement.nativeElement.value\r\n  }\r\n}\r\n","<div\r\n  class=\"mrx-input-text\"\r\n  [class]=\"getClasses\"\r\n  [class.mrx-input-error]=\"getInvalid\"\r\n  [class.mrx-input-text-with-icon]=\"icon\"\r\n  [class.-disabled]=\"disabled\"\r\n  [class.-readonly]=\"readonly\"\r\n  [mrxCdkTooltip]=\"getTooltipValue\"\r\n  [tooltipPosition]=\"'top-start'\"\r\n>\r\n  <div class=\"mrx-input-text__wrapper\">\r\n    <span *ngIf=\"icon\" class=\"mrx-icon mrx-input-text-icon\" [class]=\"getIconClass\"></span>\r\n\r\n    <input\r\n      autocomplete=\"nope\"\r\n      #inputElement\r\n      [type]=\"'text'\"\r\n      [id]=\"uuid\"\r\n      [ngModel]=\"value\"\r\n      [title]=\"placeholder || ''\"\r\n      [disabled]=\"disabled\"\r\n      [readOnly]=\"readonly\"\r\n      [placeholder]=\"!disabled && placeholder ? placeholder : ''\"\r\n      [mask]=\"mask\"\r\n      [prefix]=\"maskPrefix\"\r\n      [showMaskTyped]=\"showMaskTyped\"\r\n      [dropSpecialCharacters]=\"maskDropSpecialCharacters\"\r\n      [minlength]=\"minlength > 0 && restrictInput ? minlength : null\"\r\n      [maxlength]=\"maxlength > 0 && restrictInput ? maxlength : null\"\r\n      (ngModelChange)=\"updateValue($event)\"\r\n      (blur)=\"onBlur($event)\"\r\n    />\r\n\r\n    <mrx-chars-left\r\n      *ngIf=\"!disabled && maxlength\"\r\n      [value]=\"value\"\r\n      [maxlength]=\"maxlength\"\r\n    ></mrx-chars-left>\r\n  </div>\r\n\r\n  <mrx-error-message\r\n    *ngIf=\"getInvalid && getInvalidMessage\"\r\n    [invalidMessage]=\"getInvalidMessage\"\r\n  ></mrx-error-message>\r\n\r\n  <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
|
|
@@ -105,6 +105,7 @@ export class InputTextareaComponent {
|
|
|
105
105
|
this.blurred.emit({ value: this.value, id: this.uuid });
|
|
106
106
|
}
|
|
107
107
|
updateValue(insideValue) {
|
|
108
|
+
this.value = this._normalizeValue(insideValue);
|
|
108
109
|
this.changed.emit(this._normalizeValue(insideValue));
|
|
109
110
|
this.modelChange.emit({ value: this._normalizeValue(insideValue), id: this.uuid });
|
|
110
111
|
this.onChange(this._normalizeValue(insideValue));
|
|
@@ -180,4 +181,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
180
181
|
}], modelChange: [{
|
|
181
182
|
type: Output
|
|
182
183
|
}] } });
|
|
183
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-textarea.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-textarea/input-textarea.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-textarea/input-textarea.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport {\r\n  InputTextareaSizesEnum,\r\n  InputTextareaSizesTypes,\r\n  InputTextareaValueTypes, InputTextareaValueWithId\r\n} from './input-textarea.enum';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { InputTextValueTypes } from '../input-text/input-text.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-input-textarea',\r\n  templateUrl: './input-textarea.component.html',\r\n  styleUrls: ['./input-textarea.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputTextareaComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class InputTextareaComponent implements ControlValueAccessor {\r\n  public value: InputTextareaValueTypes = '';\r\n  public selectionStart: number | undefined;\r\n  public selectionEnd: number | undefined;\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 autosize = true;\r\n  @Input() public maxlength = 0;\r\n  @Input() public minlength = 0;\r\n  @Input() public rows = 1;\r\n  @Input() public placeholder = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public mask = '';\r\n  @Input() public size: InputTextareaSizesTypes = 'large';\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() public restrictInput = true;\r\n\r\n  @Input() public allowPattern: RegExp | null = null;\r\n\r\n  @ViewChild('inputElement') inputElement!: ElementRef;\r\n\r\n  @Output() public changed: EventEmitter<InputTextareaValueTypes> = new EventEmitter<InputTextareaValueTypes>();\r\n  @Output() public blurred: EventEmitter<InputTextareaValueWithId> = new EventEmitter<InputTextareaValueWithId>();\r\n  @Output() public modelChange: EventEmitter<InputTextareaValueWithId> = new EventEmitter<InputTextareaValueWithId>();\r\n\r\n  public get getInvalid(): boolean {\r\n    return this._isInvalidValueLength || this.invalid\r\n  }\r\n\r\n  public get getInvalidMessage(): string | string[] {\r\n    return this._isInvalidValueLength ? 'Превышено допустимое значение символов' : this.invalidMessage\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 `${InputTextareaSizesEnum[this.size]} ${this.customClasses} ${this.readonlyClass} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  public updateSelection(event: any) {\r\n    this.selectionStart = event.target.selectionStart;\r\n    this.selectionEnd = event.target.selectionEnd;\r\n  }\r\n\r\n  public insertPositionText(tagText: string): void {\r\n    if (this.selectionStart && this.selectionEnd) {\r\n      const firstText = this.value ? this.value.substring(0, this.selectionStart) : ''\r\n      const secondText = this.value.substring(this.selectionEnd);\r\n      const text = firstText + tagText + secondText;\r\n\r\n      this.updateValue(text);\r\n\r\n      setTimeout(() => {\r\n        this.inputElement.nativeElement.selectionStart = (firstText + tagText).length;\r\n        this.inputElement.nativeElement.selectionEnd = (firstText + tagText).length;\r\n        this.inputElement.nativeElement.focus();\r\n      }, 0);\r\n    } else {\r\n      const text = this.value + tagText\r\n\r\n      this.updateValue(text);\r\n\r\n      setTimeout(() => {\r\n        this.inputElement.nativeElement.selectionStart = text.length;\r\n        this.inputElement.nativeElement.selectionEnd = text.length;\r\n        this.inputElement.nativeElement.focus();\r\n      }, 0);\r\n    }\r\n  }\r\n\r\n  public onFocus(): void {\r\n    this.inputElement.nativeElement.focus()\r\n  }\r\n\r\n  private onChange = (value: InputTextareaValueTypes) => {\r\n  };\r\n  private onTouched = () => {\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 processValueForViewOnly(value: string): void {\r\n\r\n  }\r\n\r\n  public writeValue(outsideValue: InputTextareaValueTypes): void {\r\n    if ((this.inputElement?.nativeElement && document.activeElement !== this.inputElement.nativeElement)) {\r\n      this.value = outsideValue;\r\n    }\r\n\r\n    if (this.disabled) {\r\n      this.processValueForViewOnly(outsideValue);\r\n      return;\r\n    }\r\n  }\r\n\r\n  public onBlur(event: FocusEvent) {\r\n    this.updateSelection(event)\r\n    this.blurred.emit({value: this.value, id: this.uuid})\r\n  }\r\n\r\n  public updateValue(insideValue: InputTextareaValueTypes) {\r\n    this.changed.emit(this._normalizeValue(insideValue));\r\n    this.modelChange.emit({ value: this._normalizeValue(insideValue), id: this.uuid });\r\n    this.onChange(this._normalizeValue(insideValue));\r\n    this.onTouched();\r\n  }\r\n\r\n  private _normalizeValue(value: InputTextValueTypes) {\r\n    if (!this.allowPattern) {\r\n      return value\r\n    }\r\n\r\n    this.inputElement.nativeElement.value = value.replace(this.allowPattern, '');\r\n    return this.inputElement.nativeElement.value\r\n  }\r\n\r\n  private get _isInvalidValueLength(): boolean {\r\n    return this.maxlength < this.value?.length && this.maxlength > 0\r\n  }\r\n}\r\n","<div\r\n  class=\"mrx-input-textarea\"\r\n  [class]=\"getClasses\"\r\n  [class.-disabled]=\"disabled\"\r\n  [class.-readonly]=\"readonly\"\r\n  [class.mrx-input-error]=\"getInvalid\"\r\n>\r\n  <div class=\"mrx-input-textarea__wrapper\">\r\n    <textarea\r\n      #inputElement\r\n      mrxAutosize\r\n      [id]=\"uuid\"\r\n      [ngModel]=\"value\"\r\n      [disabled]=\"disabled\"\r\n      [readonly]=\"readonly\"\r\n      [rows]=\"rows\"\r\n      [autosize]=\"autosize\"\r\n      [placeholder]=\"placeholder\"\r\n      [minlength]=\"minlength > 0 && restrictInput ? minlength : null\"\r\n      [maxlength]=\"maxlength > 0 && restrictInput ? maxlength : null\"\r\n      (ngModelChange)=\"updateValue($event)\"\r\n      (blur)=\"onBlur($event)\"\r\n    ></textarea>\r\n\r\n    <mrx-chars-left\r\n      *ngIf=\"!disabled && maxlength\"\r\n      [value]=\"value\"\r\n      [maxlength]=\"maxlength\"\r\n    ></mrx-chars-left>\r\n\r\n    <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n  </div>\r\n\r\n  <mrx-error-message\r\n    *ngIf=\"getInvalid && getInvalidMessage\"\r\n    [invalidMessage]=\"getInvalidMessage\"\r\n  ></mrx-error-message>\r\n</div>\r\n"]}
|
|
184
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-textarea.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-textarea/input-textarea.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-textarea/input-textarea.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport {\r\n  InputTextareaSizesEnum,\r\n  InputTextareaSizesTypes,\r\n  InputTextareaValueTypes, InputTextareaValueWithId\r\n} from './input-textarea.enum';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { InputTextValueTypes } from '../input-text/input-text.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-input-textarea',\r\n  templateUrl: './input-textarea.component.html',\r\n  styleUrls: ['./input-textarea.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputTextareaComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class InputTextareaComponent implements ControlValueAccessor {\r\n  public value: InputTextareaValueTypes = '';\r\n  public selectionStart: number | undefined;\r\n  public selectionEnd: number | undefined;\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 autosize = true;\r\n  @Input() public maxlength = 0;\r\n  @Input() public minlength = 0;\r\n  @Input() public rows = 1;\r\n  @Input() public placeholder = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public mask = '';\r\n  @Input() public size: InputTextareaSizesTypes = 'large';\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() public restrictInput = true;\r\n\r\n  @Input() public allowPattern: RegExp | null = null;\r\n\r\n  @ViewChild('inputElement') inputElement!: ElementRef;\r\n\r\n  @Output() public changed: EventEmitter<InputTextareaValueTypes> = new EventEmitter<InputTextareaValueTypes>();\r\n  @Output() public blurred: EventEmitter<InputTextareaValueWithId> = new EventEmitter<InputTextareaValueWithId>();\r\n  @Output() public modelChange: EventEmitter<InputTextareaValueWithId> = new EventEmitter<InputTextareaValueWithId>();\r\n\r\n  public get getInvalid(): boolean {\r\n    return this._isInvalidValueLength || this.invalid\r\n  }\r\n\r\n  public get getInvalidMessage(): string | string[] {\r\n    return this._isInvalidValueLength ? 'Превышено допустимое значение символов' : this.invalidMessage\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 `${InputTextareaSizesEnum[this.size]} ${this.customClasses} ${this.readonlyClass} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  public updateSelection(event: any) {\r\n    this.selectionStart = event.target.selectionStart;\r\n    this.selectionEnd = event.target.selectionEnd;\r\n  }\r\n\r\n  public insertPositionText(tagText: string): void {\r\n    if (this.selectionStart && this.selectionEnd) {\r\n      const firstText = this.value ? this.value.substring(0, this.selectionStart) : ''\r\n      const secondText = this.value.substring(this.selectionEnd);\r\n      const text = firstText + tagText + secondText;\r\n\r\n      this.updateValue(text);\r\n\r\n      setTimeout(() => {\r\n        this.inputElement.nativeElement.selectionStart = (firstText + tagText).length;\r\n        this.inputElement.nativeElement.selectionEnd = (firstText + tagText).length;\r\n        this.inputElement.nativeElement.focus();\r\n      }, 0);\r\n    } else {\r\n      const text = this.value + tagText\r\n\r\n      this.updateValue(text);\r\n\r\n      setTimeout(() => {\r\n        this.inputElement.nativeElement.selectionStart = text.length;\r\n        this.inputElement.nativeElement.selectionEnd = text.length;\r\n        this.inputElement.nativeElement.focus();\r\n      }, 0);\r\n    }\r\n  }\r\n\r\n  public onFocus(): void {\r\n    this.inputElement.nativeElement.focus()\r\n  }\r\n\r\n  private onChange = (value: InputTextareaValueTypes) => {\r\n  };\r\n  private onTouched = () => {\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 processValueForViewOnly(value: string): void {\r\n\r\n  }\r\n\r\n  public writeValue(outsideValue: InputTextareaValueTypes): void {\r\n    if ((this.inputElement?.nativeElement && document.activeElement !== this.inputElement.nativeElement)) {\r\n      this.value = outsideValue;\r\n    }\r\n\r\n    if (this.disabled) {\r\n      this.processValueForViewOnly(outsideValue);\r\n      return;\r\n    }\r\n  }\r\n\r\n  public onBlur(event: FocusEvent) {\r\n    this.updateSelection(event)\r\n    this.blurred.emit({value: this.value, id: this.uuid})\r\n  }\r\n\r\n  public updateValue(insideValue: InputTextareaValueTypes) {\r\n    this.value = this._normalizeValue(insideValue);\r\n    this.changed.emit(this._normalizeValue(insideValue));\r\n    this.modelChange.emit({ value: this._normalizeValue(insideValue), id: this.uuid });\r\n    this.onChange(this._normalizeValue(insideValue));\r\n    this.onTouched();\r\n  }\r\n\r\n  private _normalizeValue(value: InputTextValueTypes) {\r\n    if (!this.allowPattern) {\r\n      return value\r\n    }\r\n\r\n    this.inputElement.nativeElement.value = value.replace(this.allowPattern, '');\r\n    return this.inputElement.nativeElement.value\r\n  }\r\n\r\n  private get _isInvalidValueLength(): boolean {\r\n    return this.maxlength < this.value?.length && this.maxlength > 0\r\n  }\r\n}\r\n","<div\r\n  class=\"mrx-input-textarea\"\r\n  [class]=\"getClasses\"\r\n  [class.-disabled]=\"disabled\"\r\n  [class.-readonly]=\"readonly\"\r\n  [class.mrx-input-error]=\"getInvalid\"\r\n>\r\n  <div class=\"mrx-input-textarea__wrapper\">\r\n    <textarea\r\n      #inputElement\r\n      mrxAutosize\r\n      [id]=\"uuid\"\r\n      [ngModel]=\"value\"\r\n      [disabled]=\"disabled\"\r\n      [readonly]=\"readonly\"\r\n      [rows]=\"rows\"\r\n      [autosize]=\"autosize\"\r\n      [placeholder]=\"placeholder\"\r\n      [minlength]=\"minlength > 0 && restrictInput ? minlength : null\"\r\n      [maxlength]=\"maxlength > 0 && restrictInput ? maxlength : null\"\r\n      (ngModelChange)=\"updateValue($event)\"\r\n      (blur)=\"onBlur($event)\"\r\n    ></textarea>\r\n\r\n    <mrx-chars-left\r\n      *ngIf=\"!disabled && maxlength\"\r\n      [value]=\"value\"\r\n      [maxlength]=\"maxlength\"\r\n    ></mrx-chars-left>\r\n\r\n    <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n  </div>\r\n\r\n  <mrx-error-message\r\n    *ngIf=\"getInvalid && getInvalidMessage\"\r\n    [invalidMessage]=\"getInvalidMessage\"\r\n  ></mrx-error-message>\r\n</div>\r\n"]}
|