myrta-ui 1.1.63 → 1.1.64

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.
@@ -17,6 +17,7 @@ export class InputTextComponent {
17
17
  this.uuid = uuidv4();
18
18
  this.fields = [];
19
19
  this.disabled = false;
20
+ this.allowPattern = null;
20
21
  this.required = false;
21
22
  this.readonly = false;
22
23
  this.maxlength = 0;
@@ -40,11 +41,10 @@ export class InputTextComponent {
40
41
  this.changed = new EventEmitter();
41
42
  this.blurred = new EventEmitter();
42
43
  this.modelChange = new EventEmitter();
43
- this.onChange = (value) => { };
44
- this.onTouched = () => { };
45
- }
46
- get _isInvalidValueLength() {
47
- return this.maxlength < this.value?.length && this.maxlength > 0;
44
+ this.onChange = (value) => {
45
+ };
46
+ this.onTouched = () => {
47
+ };
48
48
  }
49
49
  get getInvalid() {
50
50
  return this._isInvalidValueLength || this.invalid;
@@ -112,20 +112,29 @@ export class InputTextComponent {
112
112
  setDisabledState(isDisabled) {
113
113
  this.disabled = isDisabled;
114
114
  }
115
- updateValue(insideValue) {
116
- this.value = insideValue;
117
- this.changed.emit(this.formatValue(insideValue));
118
- this.modelChange.emit({ value: this.formatValue(insideValue), id: this.uuid });
119
- this.onChange(this.formatValue(insideValue));
120
- this.onTouched();
121
- }
122
115
  onBlur(event) {
123
116
  this.updateSelection(event);
124
117
  this.blurred.emit({ value: this.formatValue(this.value), id: this.uuid });
125
118
  }
119
+ updateValue(insideValue) {
120
+ this.changed.emit(this._normalizeValue(this.formatValue(insideValue)));
121
+ this.modelChange.emit({ value: this._normalizeValue(this.formatValue(insideValue)), id: this.uuid });
122
+ this.onChange(this._normalizeValue(this.formatValue(insideValue)));
123
+ this.onTouched();
124
+ }
125
+ get _isInvalidValueLength() {
126
+ return this.maxlength < this.value?.length && this.maxlength > 0;
127
+ }
128
+ _normalizeValue(value) {
129
+ if (!this.allowPattern) {
130
+ return value;
131
+ }
132
+ this.inputElement.nativeElement.value = value.replace(this.allowPattern, '');
133
+ return this.inputElement.nativeElement.value;
134
+ }
126
135
  }
127
136
  InputTextComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: InputTextComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
128
- InputTextComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: InputTextComponent, selector: "mrx-input-text", inputs: { fields: "fields", disabled: "disabled", required: "required", readonly: "readonly", maxlength: "maxlength", minlength: "minlength", placeholder: "placeholder", customClasses: "customClasses", size: "size", isTooltipValue: "isTooltipValue", icon: "icon", iconColor: "iconColor", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid", restrictInput: "restrictInput", mask: "mask", maskPrefix: "maskPrefix", showMaskTyped: "showMaskTyped", maskDropSpecialCharacters: "maskDropSpecialCharacters" }, outputs: { changed: "changed", blurred: "blurred", modelChange: "modelChange" }, providers: [
137
+ InputTextComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: InputTextComponent, selector: "mrx-input-text", inputs: { fields: "fields", disabled: "disabled", allowPattern: "allowPattern", required: "required", readonly: "readonly", maxlength: "maxlength", minlength: "minlength", placeholder: "placeholder", customClasses: "customClasses", size: "size", isTooltipValue: "isTooltipValue", icon: "icon", iconColor: "iconColor", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid", restrictInput: "restrictInput", mask: "mask", maskPrefix: "maskPrefix", showMaskTyped: "showMaskTyped", maskDropSpecialCharacters: "maskDropSpecialCharacters" }, outputs: { changed: "changed", blurred: "blurred", modelChange: "modelChange" }, providers: [
129
138
  {
130
139
  provide: NG_VALUE_ACCESSOR,
131
140
  useExisting: forwardRef(() => InputTextComponent),
@@ -145,6 +154,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
145
154
  type: Input
146
155
  }], disabled: [{
147
156
  type: Input
157
+ }], allowPattern: [{
158
+ type: Input
148
159
  }], required: [{
149
160
  type: Input
150
161
  }], readonly: [{
@@ -191,4 +202,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
191
202
  }], modelChange: [{
192
203
  type: Output
193
204
  }] } });
194
- //# 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 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  private get _isInvalidValueLength(): boolean {\r\n    return this.maxlength < this.value?.length && this.maxlength > 0\r\n  }\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  private onTouched = () => {};\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 updateValue(insideValue: InputTextValueTypes) {\r\n    this.value = insideValue;\r\n    this.changed.emit(this.formatValue(insideValue));\r\n    this.modelChange.emit({value: this.formatValue(insideValue), id: this.uuid})\r\n    this.onChange(this.formatValue(insideValue));\r\n    this.onTouched();\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","<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"]}
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"]}
@@ -30,6 +30,7 @@ export class InputTextareaComponent {
30
30
  this.invalidMessage = '';
31
31
  this.checkInvalid = null;
32
32
  this.restrictInput = true;
33
+ this.allowPattern = null;
33
34
  this.changed = new EventEmitter();
34
35
  this.blurred = new EventEmitter();
35
36
  this.modelChange = new EventEmitter();
@@ -38,9 +39,6 @@ export class InputTextareaComponent {
38
39
  this.onTouched = () => {
39
40
  };
40
41
  }
41
- get _isInvalidValueLength() {
42
- return this.maxlength < this.value?.length && this.maxlength > 0;
43
- }
44
42
  get getInvalid() {
45
43
  return this._isInvalidValueLength || this.invalid;
46
44
  }
@@ -102,20 +100,29 @@ export class InputTextareaComponent {
102
100
  return;
103
101
  }
104
102
  }
105
- updateValue(insideValue) {
106
- this.value = insideValue;
107
- this.changed.emit(insideValue);
108
- this.modelChange.emit({ value: insideValue, id: this.uuid });
109
- this.onChange(insideValue);
110
- this.onTouched();
111
- }
112
103
  onBlur(event) {
113
104
  this.updateSelection(event);
114
105
  this.blurred.emit({ value: this.value, id: this.uuid });
115
106
  }
107
+ updateValue(insideValue) {
108
+ this.changed.emit(this._normalizeValue(insideValue));
109
+ this.modelChange.emit({ value: this._normalizeValue(insideValue), id: this.uuid });
110
+ this.onChange(this._normalizeValue(insideValue));
111
+ this.onTouched();
112
+ }
113
+ _normalizeValue(value) {
114
+ if (!this.allowPattern) {
115
+ return value;
116
+ }
117
+ this.inputElement.nativeElement.value = value.replace(this.allowPattern, '');
118
+ return this.inputElement.nativeElement.value;
119
+ }
120
+ get _isInvalidValueLength() {
121
+ return this.maxlength < this.value?.length && this.maxlength > 0;
122
+ }
116
123
  }
117
124
  InputTextareaComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: InputTextareaComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
118
- InputTextareaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: InputTextareaComponent, selector: "mrx-input-textarea", inputs: { fields: "fields", disabled: "disabled", readonly: "readonly", autosize: "autosize", maxlength: "maxlength", minlength: "minlength", rows: "rows", placeholder: "placeholder", customClasses: "customClasses", mask: "mask", size: "size", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid", restrictInput: "restrictInput" }, outputs: { changed: "changed", blurred: "blurred", modelChange: "modelChange" }, providers: [
125
+ InputTextareaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: InputTextareaComponent, selector: "mrx-input-textarea", inputs: { fields: "fields", disabled: "disabled", readonly: "readonly", autosize: "autosize", maxlength: "maxlength", minlength: "minlength", rows: "rows", placeholder: "placeholder", customClasses: "customClasses", mask: "mask", size: "size", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid", restrictInput: "restrictInput", allowPattern: "allowPattern" }, outputs: { changed: "changed", blurred: "blurred", modelChange: "modelChange" }, providers: [
119
126
  {
120
127
  provide: NG_VALUE_ACCESSOR,
121
128
  useExisting: forwardRef(() => InputTextareaComponent),
@@ -161,6 +168,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
161
168
  type: Input
162
169
  }], restrictInput: [{
163
170
  type: Input
171
+ }], allowPattern: [{
172
+ type: Input
164
173
  }], inputElement: [{
165
174
  type: ViewChild,
166
175
  args: ['inputElement']
@@ -171,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
171
180
  }], modelChange: [{
172
181
  type: Output
173
182
  }] } });
174
- //# 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\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  @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  private get _isInvalidValueLength(): boolean {\r\n    return this.maxlength < this.value?.length && this.maxlength > 0\r\n  }\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 updateValue(insideValue: InputTextareaValueTypes): void {\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  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","<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"]}
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"]}
@@ -71,7 +71,7 @@ export class GalleryItemComponent {
71
71
  }
72
72
  }
73
73
  GalleryItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: GalleryItemComponent, deps: [{ token: i1.GalleryService }, { token: i2.SimpleModalService }, { token: i3.Store }], target: i0.ɵɵFactoryTarget.Component });
74
- GalleryItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: GalleryItemComponent, selector: "mrx-gallery-item", inputs: { preview: "preview", index: "index", isEditing: "isEditing", descriptionMaxLength: "descriptionMaxLength", deleteEndPoint: "deleteEndPoint", updateEndPoint: "updateEndPoint", rotateSlides: "rotateSlides", setIsLoading: ["isLoading", "setIsLoading"] }, outputs: { openGalleryModal: "openGalleryModal", deletePhoto: "deletePhoto", updatePhoto: "updatePhoto" }, providers: [MrxAutosaveService], ngImport: i0, template: "<div class=\"mrx-gallery-item\">\r\n <div class=\"mrx-gallery-item__preview\" (click)=\"onOpenGalleryModal()\">\r\n\r\n <img [src]=\"getImageUrl()\" [alt]=\"preview.imageName || 'image'\" *ngIf=\"!isLoadingImage; else skeletonTemplate\">\r\n\r\n <ng-template #skeletonTemplate>\r\n <div class=\"d-flex align-items-center justify-content-center w-100 h-100\">\r\n <mrx-loader size=\"medium\" color=\"brand\"></mrx-loader>\r\n </div>\r\n </ng-template>\r\n\r\n <div class=\"mrx-gallery-item__preview-overlay\" *ngIf=\"!isLoadingImage\"></div>\r\n\r\n <div class=\"mrx-gallery-item__preview-controls\" *ngIf=\"!isLoadingImage\">\r\n <a class=\"mrx-gallery-item__preview-controls--icon\" [href]=\"yandexCheckUrl\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_12346_12076)\">\r\n <path d=\"M8.00031 15.9838C12.4096 15.9838 15.984 12.4093 15.984 8.00006C15.984 3.59078 12.4096 0.0163574 8.00031 0.0163574C3.59103 0.0163574 0.0166016 3.59078 0.0166016 8.00006C0.0166016 12.4093 3.59103 15.9838 8.00031 15.9838Z\" fill=\"white\"/>\r\n <path d=\"M10.8893 13.0118H9.1367V4.34361H8.35596C6.92484 4.34361 6.17521 5.05916 6.17521 6.12731C6.17521 7.33916 6.69225 7.90065 7.76188 8.6162L8.64336 9.21028L6.11003 13.0103H4.22559L6.50559 9.61768C5.19447 8.68139 4.4567 7.76731 4.4567 6.22509C4.4567 4.29768 5.8004 2.98657 8.3441 2.98657H10.8774V13.0088H10.8893V13.0118Z\" fill=\"#FC3F1D\"/>\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_12346_12076\">\r\n <rect width=\"16\" height=\"16\" fill=\"white\"/>\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </a>\r\n\r\n <a class=\"mrx-gallery-item__preview-controls--icon\" [href]=\"googleCheckUrl\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M11.5561 4.8901H11.0997V4.86659H5.99967V7.13325H9.20219C8.73497 8.45273 7.47952 9.39992 5.99967 9.39992C4.12202 9.39992 2.59967 7.87757 2.59967 5.99992C2.59967 4.12227 4.12202 2.59992 5.99967 2.59992C6.86639 2.59992 7.65491 2.92689 8.25529 3.46097L9.85811 1.85815C8.84604 0.914935 7.49227 0.333252 5.99967 0.333252C2.87026 0.333252 0.333008 2.8705 0.333008 5.99992C0.333008 9.12934 2.87026 11.6666 5.99967 11.6666C9.12909 11.6666 11.6663 9.12934 11.6663 5.99992C11.6663 5.61997 11.6272 5.24909 11.5561 4.8901Z\" fill=\"#FBC02D\"/>\r\n <path d=\"M0.987305 3.36237L2.84909 4.72775C3.35285 3.48052 4.57289 2.59992 6.0006 2.59992C6.86732 2.59992 7.65584 2.92689 8.25622 3.46097L9.85904 1.85815C8.84697 0.914935 7.4932 0.333252 6.0006 0.333252C3.82404 0.333252 1.93647 1.56207 0.987305 3.36237Z\" fill=\"#E53935\"/>\r\n <path d=\"M6.0008 11.6665C7.4645 11.6665 8.79447 11.1063 9.80002 10.1954L8.04619 8.7113C7.47725 9.14225 6.77005 9.3998 6.0008 9.3998C4.5269 9.3998 3.27542 8.45999 2.80395 7.14844L0.956055 8.57219C1.89389 10.4073 3.79845 11.6665 6.0008 11.6665Z\" fill=\"#4CAF50\"/>\r\n <path d=\"M11.5564 4.88997L11.5519 4.86646H11.1H6V7.13312H9.20252C8.97812 7.76694 8.5704 8.31349 8.04453 8.71157C8.04482 8.71129 8.0451 8.71129 8.04538 8.71101L9.79922 10.1951C9.67512 10.3079 11.6667 8.83312 11.6667 5.99979C11.6667 5.61984 11.6276 5.24896 11.5564 4.88997Z\" fill=\"#1565C0\"/>\r\n </svg>\r\n </a>\r\n\r\n <div class=\"mrx-gallery-item__preview-controls__button d-flex align-items-center justify-content-center\" *ngIf=\"isEditing\" (click)=\"$event.stopPropagation()\">\r\n <span class=\"mrx-icon icon-delete icon-font-16 text-bold\" (click)=\"deleteImage()\"></span>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"mrx-gallery-item__description\">\r\n <mrx-input-textarea\r\n *ngIf=\"isEditing; else textTemplate\"\r\n [fields]=\"(fields$ | async)!\"\r\n [ngModel]=\"preview.description\"\r\n [autosize]=\"false\"\r\n [rows]=\"2\"\r\n [maxlength]=\"descriptionMaxLength\"\r\n (modelChange)=\"changeDescription($event)\"\r\n ></mrx-input-textarea>\r\n\r\n <ng-template #textTemplate>\r\n {{ preview.description }}\r\n </ng-template>\r\n </div>\r\n</div>\r\n", styles: [".mrx-gallery-item{cursor:pointer}.mrx-gallery-item__preview{width:100%;height:180px;border-radius:4px;overflow:hidden;position:relative;margin-bottom:8px}.mrx-gallery-item__preview img{width:100%;height:100%;object-fit:cover;object-position:center top}.mrx-gallery-item__preview-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,0) 78.93%,rgba(0,0,0,.35) 91.52%)}.mrx-gallery-item__preview-controls{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:8px;display:flex;align-items:center;justify-content:flex-end;gap:8px}.mrx-gallery-item__preview-controls--text{font-family:var(--body-sm-font-family);font-size:var(--body-sm-font-size);font-weight:var(--body-sm-font-weight);line-height:var(--body-sm-line-height);color:var(--neutral-text-inverse);opacity:.8}.mrx-gallery-item__preview-controls--icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;background-color:#fff;border-radius:50%}.mrx-gallery-item__preview-controls__button{padding:4px;border-radius:4px;background:var(--system-white, #FFF)}.mrx-gallery-item__description{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height);color:var(--neutral-text-primary)}\n"], components: [{ type: i4.LoaderComponent, selector: "mrx-loader", inputs: ["size", "color", "customClasses"] }, { type: i5.InputTextareaComponent, selector: "mrx-input-textarea", inputs: ["fields", "disabled", "readonly", "autosize", "maxlength", "minlength", "rows", "placeholder", "customClasses", "mask", "size", "invalid", "invalidMessage", "checkInvalid", "restrictInput"], outputs: ["changed", "blurred", "modelChange"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i7.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }], pipes: { "async": i6.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
74
+ GalleryItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: GalleryItemComponent, selector: "mrx-gallery-item", inputs: { preview: "preview", index: "index", isEditing: "isEditing", descriptionMaxLength: "descriptionMaxLength", deleteEndPoint: "deleteEndPoint", updateEndPoint: "updateEndPoint", rotateSlides: "rotateSlides", setIsLoading: ["isLoading", "setIsLoading"] }, outputs: { openGalleryModal: "openGalleryModal", deletePhoto: "deletePhoto", updatePhoto: "updatePhoto" }, providers: [MrxAutosaveService], ngImport: i0, template: "<div class=\"mrx-gallery-item\">\r\n <div class=\"mrx-gallery-item__preview\" (click)=\"onOpenGalleryModal()\">\r\n\r\n <img [src]=\"getImageUrl()\" [alt]=\"preview.imageName || 'image'\" *ngIf=\"!isLoadingImage; else skeletonTemplate\">\r\n\r\n <ng-template #skeletonTemplate>\r\n <div class=\"d-flex align-items-center justify-content-center w-100 h-100\">\r\n <mrx-loader size=\"medium\" color=\"brand\"></mrx-loader>\r\n </div>\r\n </ng-template>\r\n\r\n <div class=\"mrx-gallery-item__preview-overlay\" *ngIf=\"!isLoadingImage\"></div>\r\n\r\n <div class=\"mrx-gallery-item__preview-controls\" *ngIf=\"!isLoadingImage\">\r\n <a class=\"mrx-gallery-item__preview-controls--icon\" [href]=\"yandexCheckUrl\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_12346_12076)\">\r\n <path d=\"M8.00031 15.9838C12.4096 15.9838 15.984 12.4093 15.984 8.00006C15.984 3.59078 12.4096 0.0163574 8.00031 0.0163574C3.59103 0.0163574 0.0166016 3.59078 0.0166016 8.00006C0.0166016 12.4093 3.59103 15.9838 8.00031 15.9838Z\" fill=\"white\"/>\r\n <path d=\"M10.8893 13.0118H9.1367V4.34361H8.35596C6.92484 4.34361 6.17521 5.05916 6.17521 6.12731C6.17521 7.33916 6.69225 7.90065 7.76188 8.6162L8.64336 9.21028L6.11003 13.0103H4.22559L6.50559 9.61768C5.19447 8.68139 4.4567 7.76731 4.4567 6.22509C4.4567 4.29768 5.8004 2.98657 8.3441 2.98657H10.8774V13.0088H10.8893V13.0118Z\" fill=\"#FC3F1D\"/>\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_12346_12076\">\r\n <rect width=\"16\" height=\"16\" fill=\"white\"/>\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </a>\r\n\r\n <a class=\"mrx-gallery-item__preview-controls--icon\" [href]=\"googleCheckUrl\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M11.5561 4.8901H11.0997V4.86659H5.99967V7.13325H9.20219C8.73497 8.45273 7.47952 9.39992 5.99967 9.39992C4.12202 9.39992 2.59967 7.87757 2.59967 5.99992C2.59967 4.12227 4.12202 2.59992 5.99967 2.59992C6.86639 2.59992 7.65491 2.92689 8.25529 3.46097L9.85811 1.85815C8.84604 0.914935 7.49227 0.333252 5.99967 0.333252C2.87026 0.333252 0.333008 2.8705 0.333008 5.99992C0.333008 9.12934 2.87026 11.6666 5.99967 11.6666C9.12909 11.6666 11.6663 9.12934 11.6663 5.99992C11.6663 5.61997 11.6272 5.24909 11.5561 4.8901Z\" fill=\"#FBC02D\"/>\r\n <path d=\"M0.987305 3.36237L2.84909 4.72775C3.35285 3.48052 4.57289 2.59992 6.0006 2.59992C6.86732 2.59992 7.65584 2.92689 8.25622 3.46097L9.85904 1.85815C8.84697 0.914935 7.4932 0.333252 6.0006 0.333252C3.82404 0.333252 1.93647 1.56207 0.987305 3.36237Z\" fill=\"#E53935\"/>\r\n <path d=\"M6.0008 11.6665C7.4645 11.6665 8.79447 11.1063 9.80002 10.1954L8.04619 8.7113C7.47725 9.14225 6.77005 9.3998 6.0008 9.3998C4.5269 9.3998 3.27542 8.45999 2.80395 7.14844L0.956055 8.57219C1.89389 10.4073 3.79845 11.6665 6.0008 11.6665Z\" fill=\"#4CAF50\"/>\r\n <path d=\"M11.5564 4.88997L11.5519 4.86646H11.1H6V7.13312H9.20252C8.97812 7.76694 8.5704 8.31349 8.04453 8.71157C8.04482 8.71129 8.0451 8.71129 8.04538 8.71101L9.79922 10.1951C9.67512 10.3079 11.6667 8.83312 11.6667 5.99979C11.6667 5.61984 11.6276 5.24896 11.5564 4.88997Z\" fill=\"#1565C0\"/>\r\n </svg>\r\n </a>\r\n\r\n <div class=\"mrx-gallery-item__preview-controls__button d-flex align-items-center justify-content-center\" *ngIf=\"isEditing\" (click)=\"$event.stopPropagation()\">\r\n <span class=\"mrx-icon icon-delete icon-font-16 text-bold\" (click)=\"deleteImage()\"></span>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"mrx-gallery-item__description\">\r\n <mrx-input-textarea\r\n *ngIf=\"isEditing; else textTemplate\"\r\n [fields]=\"(fields$ | async)!\"\r\n [ngModel]=\"preview.description\"\r\n [autosize]=\"false\"\r\n [rows]=\"2\"\r\n [maxlength]=\"descriptionMaxLength\"\r\n (modelChange)=\"changeDescription($event)\"\r\n ></mrx-input-textarea>\r\n\r\n <ng-template #textTemplate>\r\n {{ preview.description }}\r\n </ng-template>\r\n </div>\r\n</div>\r\n", styles: [".mrx-gallery-item{cursor:pointer}.mrx-gallery-item__preview{width:100%;height:180px;border-radius:4px;overflow:hidden;position:relative;margin-bottom:8px}.mrx-gallery-item__preview img{width:100%;height:100%;object-fit:cover;object-position:center top}.mrx-gallery-item__preview-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,0) 78.93%,rgba(0,0,0,.35) 91.52%)}.mrx-gallery-item__preview-controls{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:8px;display:flex;align-items:center;justify-content:flex-end;gap:8px}.mrx-gallery-item__preview-controls--text{font-family:var(--body-sm-font-family);font-size:var(--body-sm-font-size);font-weight:var(--body-sm-font-weight);line-height:var(--body-sm-line-height);color:var(--neutral-text-inverse);opacity:.8}.mrx-gallery-item__preview-controls--icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;background-color:#fff;border-radius:50%}.mrx-gallery-item__preview-controls__button{padding:4px;border-radius:4px;background:var(--system-white, #FFF)}.mrx-gallery-item__description{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height);color:var(--neutral-text-primary)}\n"], components: [{ type: i4.LoaderComponent, selector: "mrx-loader", inputs: ["size", "color", "customClasses"] }, { type: i5.InputTextareaComponent, selector: "mrx-input-textarea", inputs: ["fields", "disabled", "readonly", "autosize", "maxlength", "minlength", "rows", "placeholder", "customClasses", "mask", "size", "invalid", "invalidMessage", "checkInvalid", "restrictInput", "allowPattern"], outputs: ["changed", "blurred", "modelChange"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i7.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }], pipes: { "async": i6.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
75
75
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: GalleryItemComponent, decorators: [{
76
76
  type: Component,
77
77
  args: [{ selector: 'mrx-gallery-item', changeDetection: ChangeDetectionStrategy.OnPush, providers: [MrxAutosaveService], template: "<div class=\"mrx-gallery-item\">\r\n <div class=\"mrx-gallery-item__preview\" (click)=\"onOpenGalleryModal()\">\r\n\r\n <img [src]=\"getImageUrl()\" [alt]=\"preview.imageName || 'image'\" *ngIf=\"!isLoadingImage; else skeletonTemplate\">\r\n\r\n <ng-template #skeletonTemplate>\r\n <div class=\"d-flex align-items-center justify-content-center w-100 h-100\">\r\n <mrx-loader size=\"medium\" color=\"brand\"></mrx-loader>\r\n </div>\r\n </ng-template>\r\n\r\n <div class=\"mrx-gallery-item__preview-overlay\" *ngIf=\"!isLoadingImage\"></div>\r\n\r\n <div class=\"mrx-gallery-item__preview-controls\" *ngIf=\"!isLoadingImage\">\r\n <a class=\"mrx-gallery-item__preview-controls--icon\" [href]=\"yandexCheckUrl\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_12346_12076)\">\r\n <path d=\"M8.00031 15.9838C12.4096 15.9838 15.984 12.4093 15.984 8.00006C15.984 3.59078 12.4096 0.0163574 8.00031 0.0163574C3.59103 0.0163574 0.0166016 3.59078 0.0166016 8.00006C0.0166016 12.4093 3.59103 15.9838 8.00031 15.9838Z\" fill=\"white\"/>\r\n <path d=\"M10.8893 13.0118H9.1367V4.34361H8.35596C6.92484 4.34361 6.17521 5.05916 6.17521 6.12731C6.17521 7.33916 6.69225 7.90065 7.76188 8.6162L8.64336 9.21028L6.11003 13.0103H4.22559L6.50559 9.61768C5.19447 8.68139 4.4567 7.76731 4.4567 6.22509C4.4567 4.29768 5.8004 2.98657 8.3441 2.98657H10.8774V13.0088H10.8893V13.0118Z\" fill=\"#FC3F1D\"/>\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_12346_12076\">\r\n <rect width=\"16\" height=\"16\" fill=\"white\"/>\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </a>\r\n\r\n <a class=\"mrx-gallery-item__preview-controls--icon\" [href]=\"googleCheckUrl\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M11.5561 4.8901H11.0997V4.86659H5.99967V7.13325H9.20219C8.73497 8.45273 7.47952 9.39992 5.99967 9.39992C4.12202 9.39992 2.59967 7.87757 2.59967 5.99992C2.59967 4.12227 4.12202 2.59992 5.99967 2.59992C6.86639 2.59992 7.65491 2.92689 8.25529 3.46097L9.85811 1.85815C8.84604 0.914935 7.49227 0.333252 5.99967 0.333252C2.87026 0.333252 0.333008 2.8705 0.333008 5.99992C0.333008 9.12934 2.87026 11.6666 5.99967 11.6666C9.12909 11.6666 11.6663 9.12934 11.6663 5.99992C11.6663 5.61997 11.6272 5.24909 11.5561 4.8901Z\" fill=\"#FBC02D\"/>\r\n <path d=\"M0.987305 3.36237L2.84909 4.72775C3.35285 3.48052 4.57289 2.59992 6.0006 2.59992C6.86732 2.59992 7.65584 2.92689 8.25622 3.46097L9.85904 1.85815C8.84697 0.914935 7.4932 0.333252 6.0006 0.333252C3.82404 0.333252 1.93647 1.56207 0.987305 3.36237Z\" fill=\"#E53935\"/>\r\n <path d=\"M6.0008 11.6665C7.4645 11.6665 8.79447 11.1063 9.80002 10.1954L8.04619 8.7113C7.47725 9.14225 6.77005 9.3998 6.0008 9.3998C4.5269 9.3998 3.27542 8.45999 2.80395 7.14844L0.956055 8.57219C1.89389 10.4073 3.79845 11.6665 6.0008 11.6665Z\" fill=\"#4CAF50\"/>\r\n <path d=\"M11.5564 4.88997L11.5519 4.86646H11.1H6V7.13312H9.20252C8.97812 7.76694 8.5704 8.31349 8.04453 8.71157C8.04482 8.71129 8.0451 8.71129 8.04538 8.71101L9.79922 10.1951C9.67512 10.3079 11.6667 8.83312 11.6667 5.99979C11.6667 5.61984 11.6276 5.24896 11.5564 4.88997Z\" fill=\"#1565C0\"/>\r\n </svg>\r\n </a>\r\n\r\n <div class=\"mrx-gallery-item__preview-controls__button d-flex align-items-center justify-content-center\" *ngIf=\"isEditing\" (click)=\"$event.stopPropagation()\">\r\n <span class=\"mrx-icon icon-delete icon-font-16 text-bold\" (click)=\"deleteImage()\"></span>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"mrx-gallery-item__description\">\r\n <mrx-input-textarea\r\n *ngIf=\"isEditing; else textTemplate\"\r\n [fields]=\"(fields$ | async)!\"\r\n [ngModel]=\"preview.description\"\r\n [autosize]=\"false\"\r\n [rows]=\"2\"\r\n [maxlength]=\"descriptionMaxLength\"\r\n (modelChange)=\"changeDescription($event)\"\r\n ></mrx-input-textarea>\r\n\r\n <ng-template #textTemplate>\r\n {{ preview.description }}\r\n </ng-template>\r\n </div>\r\n</div>\r\n", styles: [".mrx-gallery-item{cursor:pointer}.mrx-gallery-item__preview{width:100%;height:180px;border-radius:4px;overflow:hidden;position:relative;margin-bottom:8px}.mrx-gallery-item__preview img{width:100%;height:100%;object-fit:cover;object-position:center top}.mrx-gallery-item__preview-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,0) 78.93%,rgba(0,0,0,.35) 91.52%)}.mrx-gallery-item__preview-controls{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:8px;display:flex;align-items:center;justify-content:flex-end;gap:8px}.mrx-gallery-item__preview-controls--text{font-family:var(--body-sm-font-family);font-size:var(--body-sm-font-size);font-weight:var(--body-sm-font-weight);line-height:var(--body-sm-line-height);color:var(--neutral-text-inverse);opacity:.8}.mrx-gallery-item__preview-controls--icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;background-color:#fff;border-radius:50%}.mrx-gallery-item__preview-controls__button{padding:4px;border-radius:4px;background:var(--system-white, #FFF)}.mrx-gallery-item__description{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height);color:var(--neutral-text-primary)}\n"] }]