@ptsecurity/mosaic 17.5.3 → 17.5.4

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.
Files changed (36) hide show
  1. package/button/button.scss +1 -0
  2. package/core/styles/common/_animation.scss +29 -9
  3. package/esm2022/button/button.component.mjs +2 -2
  4. package/esm2022/button-toggle/button-toggle.component.mjs +2 -2
  5. package/esm2022/core/version.mjs +2 -2
  6. package/esm2022/dropdown/dropdown-item.component.mjs +2 -2
  7. package/esm2022/file-upload/multiple-file-upload.component.mjs +2 -2
  8. package/esm2022/file-upload/single-file-upload.component.mjs +2 -2
  9. package/esm2022/input/input-number.mjs +8 -2
  10. package/esm2022/list/list-selection.component.mjs +2 -2
  11. package/esm2022/list/list.component.mjs +2 -2
  12. package/esm2022/sidepanel/sidepanel-container.component.mjs +3 -3
  13. package/esm2022/tags/tag-input.mjs +11 -11
  14. package/esm2022/tree-select/tree-select.component.mjs +3 -3
  15. package/fesm2022/ptsecurity-mosaic-button-toggle.mjs +2 -2
  16. package/fesm2022/ptsecurity-mosaic-button-toggle.mjs.map +1 -1
  17. package/fesm2022/ptsecurity-mosaic-button.mjs +2 -2
  18. package/fesm2022/ptsecurity-mosaic-button.mjs.map +1 -1
  19. package/fesm2022/ptsecurity-mosaic-core.mjs +1 -1
  20. package/fesm2022/ptsecurity-mosaic-core.mjs.map +1 -1
  21. package/fesm2022/ptsecurity-mosaic-dropdown.mjs +2 -2
  22. package/fesm2022/ptsecurity-mosaic-dropdown.mjs.map +1 -1
  23. package/fesm2022/ptsecurity-mosaic-file-upload.mjs +4 -4
  24. package/fesm2022/ptsecurity-mosaic-file-upload.mjs.map +1 -1
  25. package/fesm2022/ptsecurity-mosaic-input.mjs +7 -1
  26. package/fesm2022/ptsecurity-mosaic-input.mjs.map +1 -1
  27. package/fesm2022/ptsecurity-mosaic-list.mjs +4 -4
  28. package/fesm2022/ptsecurity-mosaic-list.mjs.map +1 -1
  29. package/fesm2022/ptsecurity-mosaic-sidepanel.mjs +2 -2
  30. package/fesm2022/ptsecurity-mosaic-sidepanel.mjs.map +1 -1
  31. package/fesm2022/ptsecurity-mosaic-tags.mjs +10 -10
  32. package/fesm2022/ptsecurity-mosaic-tags.mjs.map +1 -1
  33. package/fesm2022/ptsecurity-mosaic-tree-select.mjs +2 -2
  34. package/fesm2022/ptsecurity-mosaic-tree-select.mjs.map +1 -1
  35. package/package.json +10 -10
  36. package/tags/tag-input.d.ts +1 -0
@@ -159,18 +159,13 @@ export class McTagInput {
159
159
  return;
160
160
  }
161
161
  const data = $event.clipboardData.getData('text');
162
- if (data && data.length === 0 || !this.addOnPaste) {
162
+ if (data && data?.length === 0 || !this.addOnPaste) {
163
163
  return;
164
164
  }
165
- const items = [];
166
- for (const separator of this.separators) {
167
- if (data.search(separator.symbol) > -1) {
168
- items.push(...data
169
- .split(separator.symbol)
170
- .map((item) => this.trimValue(item)));
171
- break;
172
- }
173
- }
165
+ const separatorsInString = this.getSeparatorsForString(data);
166
+ const dividedString = separatorsInString.length > 0 ?
167
+ [...data.split(new RegExp(`${separatorsInString.join('|')}`))] : [data];
168
+ const items = dividedString.map((item) => this.trimValue(item));
174
169
  if (items.length === 0) {
175
170
  items.push(data);
176
171
  }
@@ -201,6 +196,11 @@ export class McTagInput {
201
196
  focus() {
202
197
  this.inputElement.focus();
203
198
  }
199
+ getSeparatorsForString(value) {
200
+ return this.separators
201
+ .filter((separator) => value.search(separator.key) > -1)
202
+ .map((separator) => separator.key);
203
+ }
204
204
  trimValue(value) {
205
205
  return this.trimDirective ? this.trimDirective.trim(value) : value;
206
206
  }
@@ -281,4 +281,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.0", ngImpor
281
281
  }], disabled: [{
282
282
  type: Input
283
283
  }] } });
284
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tag-input.js","sourceRoot":"","sources":["../../../../packages/mosaic/tags/tag-input.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n    Directive,\n    ElementRef,\n    EventEmitter,\n    Inject,\n    Input,\n    OnChanges,\n    Optional,\n    Output,\n    Renderer2,\n    Self\n} from '@angular/core';\nimport { NgControl } from '@angular/forms';\nimport { COMMA, ENTER, SEMICOLON, SPACE, TAB } from '@ptsecurity/cdk/keycodes';\nimport { McAutocompleteTrigger } from '@ptsecurity/mosaic/autocomplete';\nimport { isBoolean } from '@ptsecurity/mosaic/core';\nimport { McTrim } from '@ptsecurity/mosaic/form-field';\n\nimport { MC_TAGS_DEFAULT_OPTIONS, McTagsDefaultOptions } from './tag-default-options';\nimport { McTagList } from './tag-list.component';\nimport { McTagTextControl } from './tag-text-control';\n\n\nconst McTagInputDefaultSeparators: { [key: number]: McTagSeparator } = {\n    [ENTER]: { symbol: /\\r?\\n/, key: 'Enter' },\n    [TAB]: { symbol: /\\t/, key: 'Tab' },\n    [SPACE]: { symbol: / /, key: ' ' },\n    [COMMA]: { symbol: /,/, key: ',' },\n    [SEMICOLON]: { symbol: /;/, key: ';' }\n};\n\n/** Represents an input event on a `mcTagInput`. */\n// tslint:disable-next-line: naming-convention\nexport interface McTagInputEvent {\n    /** The native `<input>` element that the event is being fired for. */\n    input: HTMLInputElement;\n\n    /** The value of the input. */\n    value: string;\n}\n\nexport interface McTagSeparator {\n    // tslint:disable-next-line:no-reserved-keywords\n    symbol: RegExp;\n    key: string;\n}\n// Increasing integer for generating unique ids.\nlet nextUniqueId = 0;\n\n/**\n * Directive that adds tag-specific behaviors to an input element inside `<mc-form-field>`.\n * May be placed inside or outside of an `<mc-tag-list>`.\n */\n@Directive({\n    selector: 'input[mcTagInputFor]',\n    exportAs: 'mcTagInput, mcTagInputFor',\n    host: {\n        class: 'mc-tag-input',\n\n        '[id]': 'id',\n        '[attr.disabled]': 'disabled || null',\n        '[attr.placeholder]': 'placeholder || null',\n\n        '(keydown)': 'onKeydown($event)',\n        '(blur)': 'blur($event)',\n        '(focus)': 'onFocus()',\n        '(input)': 'onInput()',\n        '(paste)': 'onPaste($event)'\n    }\n})\nexport class McTagInput implements McTagTextControl, OnChanges {\n    /** Whether the control is focused. */\n    focused: boolean = false;\n\n    /**\n     * The list of key codes that will trigger a tagEnd event.\n     *\n     * Defaults to `[ENTER]`.\n     */\n    @Input('mcTagInputSeparatorKeyCodes')\n    set separatorKeyCodes(value: number[]) {\n        this._separatorKeyCodes = value || [];\n    }\n\n    private _separatorKeyCodes: number[] = this.defaultOptions.separatorKeyCodes;\n\n\n    get separators(): McTagSeparator[] {\n        return this._separatorKeyCodes\n            .reduce(\n                (acc: any, key) => {\n                    const separator = this.getSeparatorByKeyCode(key);\n\n                    return separator ? [...acc, separator] : acc;\n                },\n                []\n            );\n    }\n\n    private _separators: { [key: number]: McTagSeparator };\n\n    /** Emitted when a tag is to be added. */\n    @Output('mcTagInputTokenEnd') tagEnd: EventEmitter<McTagInputEvent> = new EventEmitter<McTagInputEvent>();\n\n    /** A value indicating whether allow/prevent tags duplication  */\n    @Input() distinct: boolean = false;\n\n    /** The input's placeholder text. */\n    @Input() placeholder: string = '';\n\n    /** Unique id for the input. */\n    @Input() id: string = `mc-tag-list-input-${nextUniqueId++}`;\n\n    /** Register input for tag list */\n    @Input('mcTagInputFor')\n    set tagList(value: McTagList) {\n        if (value) {\n            this._tagList = value;\n            this._tagList.registerInput(this);\n        }\n    }\n\n    // tslint:disable-next-line: naming-convention\n    private _tagList: McTagList;\n\n    /**\n     * Whether or not the tagEnd event will be emitted when the input is blurred.\n     */\n    @Input('mcTagInputAddOnBlur')\n    get addOnBlur(): boolean {\n        return this._addOnBlur;\n    }\n\n    set addOnBlur(value: boolean) {\n        this._addOnBlur = coerceBooleanProperty(value);\n    }\n\n    private _addOnBlur: boolean = true;\n\n    /**\n     * Whether the tagEnd event will be emitted when the text pasted.\n     */\n    @Input('mcTagInputAddOnPaste')\n    get addOnPaste(): boolean {\n        return this._addOnPaste;\n    }\n\n    set addOnPaste(value: boolean) {\n        this._addOnPaste = coerceBooleanProperty(value);\n    }\n\n    private _addOnPaste: boolean;\n\n    /** Whether the input is disabled. */\n    @Input()\n    get disabled(): boolean {\n        return this._disabled || (this._tagList && this._tagList.disabled);\n    }\n\n    set disabled(value: boolean) {\n        this._disabled = coerceBooleanProperty(value);\n    }\n\n    private _disabled: boolean = false;\n\n    /** Whether the input is empty. */\n    get empty(): boolean {\n        return !this.inputElement.value;\n    }\n\n    countOfSymbolsForUpdateWidth: number = 3;\n\n    private oneSymbolWidth: number;\n\n    /** The native input element to which this directive is attached. */\n    private inputElement: HTMLInputElement;\n\n    constructor(\n        private elementRef: ElementRef<HTMLInputElement>,\n        private renderer: Renderer2,\n        @Inject(MC_TAGS_DEFAULT_OPTIONS) private defaultOptions: McTagsDefaultOptions,\n        @Optional() @Self() private trimDirective: McTrim,\n        @Optional() @Self() public ngControl: NgControl,\n        @Optional() @Self() public autocompleteTrigger?: McAutocompleteTrigger\n    ) {\n        // tslint:disable-next-line: no-unnecessary-type-assertion\n        this.inputElement = this.elementRef.nativeElement as HTMLInputElement;\n\n        this.setDefaultInputWidth();\n\n        this._separators = this.defaultOptions.separators || McTagInputDefaultSeparators;\n        this._addOnPaste = isBoolean(this.defaultOptions.addOnPaste) ? this.defaultOptions.addOnPaste : true;\n    }\n\n    ngOnChanges() {\n        this._tagList.stateChanges.next();\n    }\n\n    onKeydown(event: KeyboardEvent) {\n        if (!this.inputElement.value) {\n            this._tagList.keydown(event);\n        }\n\n        if (this.isSeparatorKey(event)) {\n            this.emitTagEnd();\n\n            event.preventDefault();\n        }\n    }\n\n    /** Checks to see if the blur should emit the (tagEnd) event. */\n    blur(event: FocusEvent) {\n        this.focused = false;\n        // Blur the tag list if it is not focused\n        if (!this._tagList.focused) {\n            this.triggerValidation();\n\n            this._tagList.blur();\n        }\n\n        // tslint:disable-next-line: no-unnecessary-type-assertion\n        if (this.addOnBlur && (this.autocompleteTrigger?.onInputBlur(event) || true)) {\n            this.emitTagEnd();\n        }\n\n        this._tagList.stateChanges.next();\n    }\n\n    triggerValidation() {\n        if (!this.hasControl()) { return; }\n\n        (this.ngControl.statusChanges as EventEmitter<string | null>).emit(this.ngControl.status);\n    }\n\n    /** Checks to see if the (tagEnd) event needs to be emitted. */\n    emitTagEnd() {\n        if (!this.hasControl() || (this.hasControl() && !this.ngControl.invalid)) {\n            if (this.distinct && this.hasDuplicates) { return; }\n\n            this.tagEnd.emit({ input: this.inputElement, value: this.trimValue(this.inputElement.value) });\n            this.updateInputWidth();\n        }\n    }\n\n    get hasDuplicates(): boolean {\n        return this._tagList.tags.map(({ value }) => value)\n            .some((tagValue) => tagValue === this.trimValue(this.inputElement.value));\n    }\n\n    onInput() {\n        this.updateInputWidth();\n        // Let tag list know whenever the value changes.\n        this._tagList.stateChanges.next();\n    }\n\n    onPaste($event: ClipboardEvent) {\n        if (!$event.clipboardData) { return; }\n\n        const data = $event.clipboardData.getData('text');\n\n        if (data && data.length === 0 || !this.addOnPaste) { return; }\n\n        const items: string[] = [];\n\n        for (const separator of this.separators) {\n            if (data.search(separator.symbol) > -1) {\n                items.push(\n                    ...data\n                        .split(separator.symbol)\n                        .map((item) => this.trimValue(item))\n                );\n\n                break;\n            }\n        }\n\n        if (items.length === 0) {\n            items.push(data);\n        }\n\n        const tagValues: string[] = this._tagList.tags.map(({ value }) => value);\n        items.filter((item) => !tagValues.includes(item))\n            .forEach((item) => this.tagEnd.emit({ input: this.inputElement, value: item }));\n\n        this.updateInputWidth();\n\n        $event.preventDefault();\n        $event.stopPropagation();\n    }\n\n    updateInputWidth(): void {\n        const length = this.inputElement.value.length;\n\n        this.renderer.setStyle(this.inputElement, 'max-width', 0);\n        this.oneSymbolWidth = this.inputElement.scrollWidth / length;\n        this.renderer.setStyle(this.inputElement, 'max-width', '');\n\n        if (length > this.countOfSymbolsForUpdateWidth) {\n            this.renderer.setStyle(this.inputElement, 'width', `${length * this.oneSymbolWidth}px`);\n        } else {\n            this.setDefaultInputWidth();\n        }\n    }\n\n    onFocus() {\n        this.focused = true;\n        this._tagList.stateChanges.next();\n    }\n\n    /** Focuses the input. */\n    focus(): void {\n        this.inputElement.focus();\n    }\n\n    private trimValue(value) {\n        return this.trimDirective ? this.trimDirective.trim(value) : value;\n    }\n\n    private getSeparatorByKeyCode(keyCode: number): McTagSeparator | null {\n        const sep = this._separators[keyCode];\n\n        if (sep) { return sep; }\n\n        return null;\n    }\n\n    private hasControl(): boolean {\n        return !!this.ngControl;\n    }\n\n    private setDefaultInputWidth() {\n        this.renderer.setStyle(this.inputElement, 'width', '30px');\n    }\n\n    /** Checks whether a keycode is one of the configured separators. */\n    private isSeparatorKey(event: KeyboardEvent) {\n        return this.separators\n            .some((separator) => separator.key === event.key && !event.shiftKey);\n    }\n}\n"]}
284
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tag-input.js","sourceRoot":"","sources":["../../../../packages/mosaic/tags/tag-input.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n    Directive,\n    ElementRef,\n    EventEmitter,\n    Inject,\n    Input,\n    OnChanges,\n    Optional,\n    Output,\n    Renderer2,\n    Self\n} from '@angular/core';\nimport { NgControl } from '@angular/forms';\nimport { COMMA, ENTER, SEMICOLON, SPACE, TAB } from '@ptsecurity/cdk/keycodes';\nimport { McAutocompleteTrigger } from '@ptsecurity/mosaic/autocomplete';\nimport { isBoolean } from '@ptsecurity/mosaic/core';\nimport { McTrim } from '@ptsecurity/mosaic/form-field';\n\nimport { MC_TAGS_DEFAULT_OPTIONS, McTagsDefaultOptions } from './tag-default-options';\nimport { McTagList } from './tag-list.component';\nimport { McTagTextControl } from './tag-text-control';\n\n\nconst McTagInputDefaultSeparators: { [key: number]: McTagSeparator } = {\n    [ENTER]: { symbol: /\\r?\\n/, key: 'Enter' },\n    [TAB]: { symbol: /\\t/, key: 'Tab' },\n    [SPACE]: { symbol: / /, key: ' ' },\n    [COMMA]: { symbol: /,/, key: ',' },\n    [SEMICOLON]: { symbol: /;/, key: ';' }\n};\n\n/** Represents an input event on a `mcTagInput`. */\n// tslint:disable-next-line: naming-convention\nexport interface McTagInputEvent {\n    /** The native `<input>` element that the event is being fired for. */\n    input: HTMLInputElement;\n\n    /** The value of the input. */\n    value: string;\n}\n\nexport interface McTagSeparator {\n    // tslint:disable-next-line:no-reserved-keywords\n    symbol: RegExp;\n    key: string;\n}\n// Increasing integer for generating unique ids.\nlet nextUniqueId = 0;\n\n/**\n * Directive that adds tag-specific behaviors to an input element inside `<mc-form-field>`.\n * May be placed inside or outside of an `<mc-tag-list>`.\n */\n@Directive({\n    selector: 'input[mcTagInputFor]',\n    exportAs: 'mcTagInput, mcTagInputFor',\n    host: {\n        class: 'mc-tag-input',\n\n        '[id]': 'id',\n        '[attr.disabled]': 'disabled || null',\n        '[attr.placeholder]': 'placeholder || null',\n\n        '(keydown)': 'onKeydown($event)',\n        '(blur)': 'blur($event)',\n        '(focus)': 'onFocus()',\n        '(input)': 'onInput()',\n        '(paste)': 'onPaste($event)'\n    }\n})\nexport class McTagInput implements McTagTextControl, OnChanges {\n    /** Whether the control is focused. */\n    focused: boolean = false;\n\n    /**\n     * The list of key codes that will trigger a tagEnd event.\n     *\n     * Defaults to `[ENTER]`.\n     */\n    @Input('mcTagInputSeparatorKeyCodes')\n    set separatorKeyCodes(value: number[]) {\n        this._separatorKeyCodes = value || [];\n    }\n\n    private _separatorKeyCodes: number[] = this.defaultOptions.separatorKeyCodes;\n\n\n    get separators(): McTagSeparator[] {\n        return this._separatorKeyCodes\n            .reduce(\n                (acc: any, key) => {\n                    const separator = this.getSeparatorByKeyCode(key);\n\n                    return separator ? [...acc, separator] : acc;\n                },\n                []\n            );\n    }\n\n    private _separators: { [key: number]: McTagSeparator };\n\n    /** Emitted when a tag is to be added. */\n    @Output('mcTagInputTokenEnd') tagEnd: EventEmitter<McTagInputEvent> = new EventEmitter<McTagInputEvent>();\n\n    /** A value indicating whether allow/prevent tags duplication  */\n    @Input() distinct: boolean = false;\n\n    /** The input's placeholder text. */\n    @Input() placeholder: string = '';\n\n    /** Unique id for the input. */\n    @Input() id: string = `mc-tag-list-input-${nextUniqueId++}`;\n\n    /** Register input for tag list */\n    @Input('mcTagInputFor')\n    set tagList(value: McTagList) {\n        if (value) {\n            this._tagList = value;\n            this._tagList.registerInput(this);\n        }\n    }\n\n    // tslint:disable-next-line: naming-convention\n    private _tagList: McTagList;\n\n    /**\n     * Whether or not the tagEnd event will be emitted when the input is blurred.\n     */\n    @Input('mcTagInputAddOnBlur')\n    get addOnBlur(): boolean {\n        return this._addOnBlur;\n    }\n\n    set addOnBlur(value: boolean) {\n        this._addOnBlur = coerceBooleanProperty(value);\n    }\n\n    private _addOnBlur: boolean = true;\n\n    /**\n     * Whether the tagEnd event will be emitted when the text pasted.\n     */\n    @Input('mcTagInputAddOnPaste')\n    get addOnPaste(): boolean {\n        return this._addOnPaste;\n    }\n\n    set addOnPaste(value: boolean) {\n        this._addOnPaste = coerceBooleanProperty(value);\n    }\n\n    private _addOnPaste: boolean;\n\n    /** Whether the input is disabled. */\n    @Input()\n    get disabled(): boolean {\n        return this._disabled || (this._tagList && this._tagList.disabled);\n    }\n\n    set disabled(value: boolean) {\n        this._disabled = coerceBooleanProperty(value);\n    }\n\n    private _disabled: boolean = false;\n\n    /** Whether the input is empty. */\n    get empty(): boolean {\n        return !this.inputElement.value;\n    }\n\n    countOfSymbolsForUpdateWidth: number = 3;\n\n    private oneSymbolWidth: number;\n\n    /** The native input element to which this directive is attached. */\n    private inputElement: HTMLInputElement;\n\n    constructor(\n        private elementRef: ElementRef<HTMLInputElement>,\n        private renderer: Renderer2,\n        @Inject(MC_TAGS_DEFAULT_OPTIONS) private defaultOptions: McTagsDefaultOptions,\n        @Optional() @Self() private trimDirective: McTrim,\n        @Optional() @Self() public ngControl: NgControl,\n        @Optional() @Self() public autocompleteTrigger?: McAutocompleteTrigger\n    ) {\n        // tslint:disable-next-line: no-unnecessary-type-assertion\n        this.inputElement = this.elementRef.nativeElement as HTMLInputElement;\n\n        this.setDefaultInputWidth();\n\n        this._separators = this.defaultOptions.separators || McTagInputDefaultSeparators;\n        this._addOnPaste = isBoolean(this.defaultOptions.addOnPaste) ? this.defaultOptions.addOnPaste : true;\n    }\n\n    ngOnChanges() {\n        this._tagList.stateChanges.next();\n    }\n\n    onKeydown(event: KeyboardEvent) {\n        if (!this.inputElement.value) {\n            this._tagList.keydown(event);\n        }\n\n        if (this.isSeparatorKey(event)) {\n            this.emitTagEnd();\n\n            event.preventDefault();\n        }\n    }\n\n    /** Checks to see if the blur should emit the (tagEnd) event. */\n    blur(event: FocusEvent) {\n        this.focused = false;\n        // Blur the tag list if it is not focused\n        if (!this._tagList.focused) {\n            this.triggerValidation();\n\n            this._tagList.blur();\n        }\n\n        // tslint:disable-next-line: no-unnecessary-type-assertion\n        if (this.addOnBlur && (this.autocompleteTrigger?.onInputBlur(event) || true)) {\n            this.emitTagEnd();\n        }\n\n        this._tagList.stateChanges.next();\n    }\n\n    triggerValidation() {\n        if (!this.hasControl()) { return; }\n\n        (this.ngControl.statusChanges as EventEmitter<string | null>).emit(this.ngControl.status);\n    }\n\n    /** Checks to see if the (tagEnd) event needs to be emitted. */\n    emitTagEnd() {\n        if (!this.hasControl() || (this.hasControl() && !this.ngControl.invalid)) {\n            if (this.distinct && this.hasDuplicates) { return; }\n\n            this.tagEnd.emit({ input: this.inputElement, value: this.trimValue(this.inputElement.value) });\n            this.updateInputWidth();\n        }\n    }\n\n    get hasDuplicates(): boolean {\n        return this._tagList.tags.map(({ value }) => value)\n            .some((tagValue) => tagValue === this.trimValue(this.inputElement.value));\n    }\n\n    onInput() {\n        this.updateInputWidth();\n        // Let tag list know whenever the value changes.\n        this._tagList.stateChanges.next();\n    }\n\n    onPaste($event: ClipboardEvent) {\n        if (!$event.clipboardData) { return; }\n\n        const data = $event.clipboardData.getData('text');\n\n        if (data && data?.length === 0 || !this.addOnPaste) { return; }\n\n        const separatorsInString = this.getSeparatorsForString(data);\n\n        const dividedString: string[] = separatorsInString.length > 0 ?\n            [...data.split(new RegExp(`${separatorsInString.join('|')}`))] : [data];\n\n        const items: string[] = dividedString.map((item) => this.trimValue(item));\n\n        if (items.length === 0) {\n            items.push(data);\n        }\n\n        const tagValues: string[] = this._tagList.tags.map(({ value }) => value);\n        items.filter((item) => !tagValues.includes(item))\n            .forEach((item) => this.tagEnd.emit({ input: this.inputElement, value: item }));\n\n        this.updateInputWidth();\n\n        $event.preventDefault();\n        $event.stopPropagation();\n    }\n\n    updateInputWidth(): void {\n        const length = this.inputElement.value.length;\n\n        this.renderer.setStyle(this.inputElement, 'max-width', 0);\n        this.oneSymbolWidth = this.inputElement.scrollWidth / length;\n        this.renderer.setStyle(this.inputElement, 'max-width', '');\n\n        if (length > this.countOfSymbolsForUpdateWidth) {\n            this.renderer.setStyle(this.inputElement, 'width', `${length * this.oneSymbolWidth}px`);\n        } else {\n            this.setDefaultInputWidth();\n        }\n    }\n\n    onFocus() {\n        this.focused = true;\n        this._tagList.stateChanges.next();\n    }\n\n    /** Focuses the input. */\n    focus(): void {\n        this.inputElement.focus();\n    }\n\n    private getSeparatorsForString(value: string): string[] {\n        return this.separators\n            .filter((separator) => value.search(separator.key) > -1)\n            .map((separator) => separator.key);\n    }\n\n    private trimValue(value) {\n        return this.trimDirective ? this.trimDirective.trim(value) : value;\n    }\n\n    private getSeparatorByKeyCode(keyCode: number): McTagSeparator | null {\n        const sep = this._separators[keyCode];\n\n        if (sep) { return sep; }\n\n        return null;\n    }\n\n    private hasControl(): boolean {\n        return !!this.ngControl;\n    }\n\n    private setDefaultInputWidth() {\n        this.renderer.setStyle(this.inputElement, 'width', '30px');\n    }\n\n    /** Checks whether a keycode is one of the configured separators. */\n    private isSeparatorKey(event: KeyboardEvent) {\n        return this.separators\n            .some((separator) => separator.key === event.key && !event.shiftKey);\n    }\n}\n"]}