@fundamental-ngx/cdk 0.54.5 → 0.54.6

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.
@@ -37,7 +37,7 @@ export class AutoCompleteDirective {
37
37
  * By ensuring that we set all properties we can proceed with stable data.
38
38
  */
39
39
  this._zone.runOutsideAngular(() => {
40
- const keyupEvent = fromEvent(this._elementRef.nativeElement, 'keyup');
40
+ const keyupEvent = fromEvent(this._elementRef.nativeElement, 'keydown');
41
41
  const compositionStartEvent = fromEvent(this._elementRef.nativeElement, 'compositionstart');
42
42
  const compositionEndEvent = fromEvent(this._elementRef.nativeElement, 'compositionend');
43
43
  keyupEvent
@@ -132,4 +132,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
132
132
  }], matcher: [{
133
133
  type: Input
134
134
  }] } });
135
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auto-complete.directive.js","sourceRoot":"","sources":["../../../../../../../libs/cdk/utils/directives/auto-complete/auto-complete.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { BACKSPACE, CONTROL, DELETE, ENTER, ESCAPE, LEFT_ARROW, RIGHT_ARROW } from '@angular/cdk/keycodes';\nimport { Directive, ElementRef, EventEmitter, Input, NgZone, Output, inject } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { fromEvent, map, switchMap } from 'rxjs';\nimport { first } from 'rxjs/operators';\nimport { KeyUtil } from '../../functions';\n\nexport interface AutoCompleteEvent {\n    term: string;\n    forceClose: boolean;\n}\n\n@Directive({\n    selector: '[fdkAutoComplete]',\n    standalone: true\n})\nexport class AutoCompleteDirective {\n    /** Values that will fill missing text in the input. */\n    @Input()\n    options: any[];\n\n    /**\n     * Input text, that is taken from ngModel of formControl,\n     * there has to be difference between native input value and model value\n     */\n    @Input()\n    inputText: string;\n\n    /** Whether the auto complete directive should be enabled */\n    @Input()\n    enable = true;\n\n    /** Display function. Accepts an object of the same type as the\n     * items passed to dropdownValues as argument, and outputs a string.\n     * An arrow function can be used to access the *this* keyword in the calling component.\n     * See search input examples for details. */\n    @Input()\n    displayFn = this._defaultDisplay;\n\n    /** Event thrown, when the auto ahead text is accepted */\n    @Output()\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    readonly onComplete: EventEmitter<AutoCompleteEvent> = new EventEmitter<AutoCompleteEvent>();\n\n    /** @hidden */\n    private readonly _completeKeys: number[] = [ENTER];\n\n    /** @hidden */\n    private readonly _fillKeys: number[] = [LEFT_ARROW, RIGHT_ARROW];\n\n    /** @hidden */\n    private readonly _stopKeys: number[] = [BACKSPACE, DELETE, ESCAPE];\n\n    /** @hidden */\n    private oldValue: string;\n\n    /** @hidden */\n    private lastKeyUpEvent: KeyboardEvent;\n\n    /** @hidden */\n    private _isComposing = false;\n\n    /** @hidden */\n    private readonly _elementRef = inject(ElementRef);\n\n    private readonly _zone = inject(NgZone);\n\n    /** @hidden */\n    // eslint-disable-next-line @typescript-eslint/member-ordering\n    constructor() {\n        /**\n         * Fixes #10710\n         * With chinese characters inputText property update was triggered after the keyup event trigger.\n         * By ensuring that we set all properties we can proceed with stable data.\n         */\n        this._zone.runOutsideAngular(() => {\n            const keyupEvent = fromEvent<KeyboardEvent>(this._elementRef.nativeElement, 'keyup');\n            const compositionStartEvent = fromEvent<CompositionEvent>(\n                this._elementRef.nativeElement,\n                'compositionstart'\n            );\n            const compositionEndEvent = fromEvent<CompositionEvent>(this._elementRef.nativeElement, 'compositionend');\n\n            keyupEvent\n                .pipe(\n                    switchMap((evt) =>\n                        this._zone.onStable.pipe(\n                            first(),\n                            map(() => evt)\n                        )\n                    ),\n                    takeUntilDestroyed()\n                )\n                .subscribe((evt) => this._handleKeyboardEvent(evt));\n\n            compositionStartEvent.pipe(takeUntilDestroyed()).subscribe(() => {\n                this._isComposing = true;\n            });\n\n            compositionEndEvent.pipe(takeUntilDestroyed()).subscribe(() => {\n                this._isComposing = false;\n                this.inputText = this._elementRef.nativeElement.value;\n            });\n        });\n    }\n\n    /** Matcher function for testing the str for a search term */\n    @Input()\n    matcher = (str: string, searchTerm: string): boolean => str.startsWith(searchTerm);\n\n    /** @hidden */\n    _handleKeyboardEvent(event: KeyboardEvent): void {\n        if (this.enable && !this._isComposing) {\n            if (KeyUtil.isKeyCode(event, this._stopKeys)) {\n                this._elementRef.nativeElement.value = this.inputText;\n            } else if (KeyUtil.isKeyCode(event, this._completeKeys)) {\n                this._sendCompleteEvent(true);\n                this._moveIndicatorToLastCharacter();\n            } else if (KeyUtil.isKeyCode(event, this._fillKeys)) {\n                this._sendCompleteEvent(false);\n            } else if (!this._isControlKey(event) && this.inputText) {\n                if (!this._triggerTypeAhead()) {\n                    return;\n                }\n\n                this.oldValue = this.inputText;\n\n                const item = this.options.find((option) =>\n                    this.matcher(this.displayFn(option).toLocaleLowerCase(), this.inputText.toLocaleLowerCase())\n                );\n\n                if (item) {\n                    this._typeahead(this.displayFn(item));\n                }\n            }\n        }\n        this.lastKeyUpEvent = event;\n    }\n\n    /** @hidden */\n    private _typeahead(displayedValue: string): void {\n        this._elementRef.nativeElement.value = displayedValue;\n        const selectionStartIndex = this.inputText.length;\n        this._elementRef.nativeElement.setSelectionRange(selectionStartIndex, displayedValue.length);\n    }\n\n    /** @hidden */\n    private _isControlKey(event: KeyboardEvent): boolean {\n        return KeyUtil.isKeyCode(event, CONTROL) || event.ctrlKey;\n    }\n\n    /** @hidden */\n    private _defaultDisplay(value: any): string {\n        return value;\n    }\n\n    /** @hidden */\n    private _triggerTypeAhead(): boolean {\n        return !(\n            this.lastKeyUpEvent &&\n            KeyUtil.isKeyCode(this.lastKeyUpEvent, CONTROL) &&\n            this.inputText === this.oldValue\n        );\n    }\n\n    /** @hidden */\n    private _sendCompleteEvent(forceClose: boolean): void {\n        this.onComplete.emit({\n            term: this._elementRef.nativeElement.value,\n            forceClose\n        });\n    }\n\n    /** @hidden */\n    private _moveIndicatorToLastCharacter(): void {\n        const inputTextLength = this.inputText?.length ?? 0;\n        this._elementRef.nativeElement.setSelectionRange(inputTextLength, inputTextLength);\n    }\n}\n"]}
135
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auto-complete.directive.js","sourceRoot":"","sources":["../../../../../../../libs/cdk/utils/directives/auto-complete/auto-complete.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { BACKSPACE, CONTROL, DELETE, ENTER, ESCAPE, LEFT_ARROW, RIGHT_ARROW } from '@angular/cdk/keycodes';\nimport { Directive, ElementRef, EventEmitter, Input, NgZone, Output, inject } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { fromEvent, map, switchMap } from 'rxjs';\nimport { first } from 'rxjs/operators';\nimport { KeyUtil } from '../../functions';\n\nexport interface AutoCompleteEvent {\n    term: string;\n    forceClose: boolean;\n}\n\n@Directive({\n    selector: '[fdkAutoComplete]',\n    standalone: true\n})\nexport class AutoCompleteDirective {\n    /** Values that will fill missing text in the input. */\n    @Input()\n    options: any[];\n\n    /**\n     * Input text, that is taken from ngModel of formControl,\n     * there has to be difference between native input value and model value\n     */\n    @Input()\n    inputText: string;\n\n    /** Whether the auto complete directive should be enabled */\n    @Input()\n    enable = true;\n\n    /** Display function. Accepts an object of the same type as the\n     * items passed to dropdownValues as argument, and outputs a string.\n     * An arrow function can be used to access the *this* keyword in the calling component.\n     * See search input examples for details. */\n    @Input()\n    displayFn = this._defaultDisplay;\n\n    /** Event thrown, when the auto ahead text is accepted */\n    @Output()\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    readonly onComplete: EventEmitter<AutoCompleteEvent> = new EventEmitter<AutoCompleteEvent>();\n\n    /** @hidden */\n    private readonly _completeKeys: number[] = [ENTER];\n\n    /** @hidden */\n    private readonly _fillKeys: number[] = [LEFT_ARROW, RIGHT_ARROW];\n\n    /** @hidden */\n    private readonly _stopKeys: number[] = [BACKSPACE, DELETE, ESCAPE];\n\n    /** @hidden */\n    private oldValue: string;\n\n    /** @hidden */\n    private lastKeyUpEvent: KeyboardEvent;\n\n    /** @hidden */\n    private _isComposing = false;\n\n    /** @hidden */\n    private readonly _elementRef = inject(ElementRef);\n\n    private readonly _zone = inject(NgZone);\n\n    /** @hidden */\n    // eslint-disable-next-line @typescript-eslint/member-ordering\n    constructor() {\n        /**\n         * Fixes #10710\n         * With chinese characters inputText property update was triggered after the keyup event trigger.\n         * By ensuring that we set all properties we can proceed with stable data.\n         */\n        this._zone.runOutsideAngular(() => {\n            const keyupEvent = fromEvent<KeyboardEvent>(this._elementRef.nativeElement, 'keydown');\n            const compositionStartEvent = fromEvent<CompositionEvent>(\n                this._elementRef.nativeElement,\n                'compositionstart'\n            );\n            const compositionEndEvent = fromEvent<CompositionEvent>(this._elementRef.nativeElement, 'compositionend');\n\n            keyupEvent\n                .pipe(\n                    switchMap((evt) =>\n                        this._zone.onStable.pipe(\n                            first(),\n                            map(() => evt)\n                        )\n                    ),\n                    takeUntilDestroyed()\n                )\n                .subscribe((evt) => this._handleKeyboardEvent(evt));\n\n            compositionStartEvent.pipe(takeUntilDestroyed()).subscribe(() => {\n                this._isComposing = true;\n            });\n\n            compositionEndEvent.pipe(takeUntilDestroyed()).subscribe(() => {\n                this._isComposing = false;\n                this.inputText = this._elementRef.nativeElement.value;\n            });\n        });\n    }\n\n    /** Matcher function for testing the str for a search term */\n    @Input()\n    matcher = (str: string, searchTerm: string): boolean => str.startsWith(searchTerm);\n\n    /** @hidden */\n    _handleKeyboardEvent(event: KeyboardEvent): void {\n        if (this.enable && !this._isComposing) {\n            if (KeyUtil.isKeyCode(event, this._stopKeys)) {\n                this._elementRef.nativeElement.value = this.inputText;\n            } else if (KeyUtil.isKeyCode(event, this._completeKeys)) {\n                this._sendCompleteEvent(true);\n                this._moveIndicatorToLastCharacter();\n            } else if (KeyUtil.isKeyCode(event, this._fillKeys)) {\n                this._sendCompleteEvent(false);\n            } else if (!this._isControlKey(event) && this.inputText) {\n                if (!this._triggerTypeAhead()) {\n                    return;\n                }\n\n                this.oldValue = this.inputText;\n\n                const item = this.options.find((option) =>\n                    this.matcher(this.displayFn(option).toLocaleLowerCase(), this.inputText.toLocaleLowerCase())\n                );\n\n                if (item) {\n                    this._typeahead(this.displayFn(item));\n                }\n            }\n        }\n        this.lastKeyUpEvent = event;\n    }\n\n    /** @hidden */\n    private _typeahead(displayedValue: string): void {\n        this._elementRef.nativeElement.value = displayedValue;\n        const selectionStartIndex = this.inputText.length;\n        this._elementRef.nativeElement.setSelectionRange(selectionStartIndex, displayedValue.length);\n    }\n\n    /** @hidden */\n    private _isControlKey(event: KeyboardEvent): boolean {\n        return KeyUtil.isKeyCode(event, CONTROL) || event.ctrlKey;\n    }\n\n    /** @hidden */\n    private _defaultDisplay(value: any): string {\n        return value;\n    }\n\n    /** @hidden */\n    private _triggerTypeAhead(): boolean {\n        return !(\n            this.lastKeyUpEvent &&\n            KeyUtil.isKeyCode(this.lastKeyUpEvent, CONTROL) &&\n            this.inputText === this.oldValue\n        );\n    }\n\n    /** @hidden */\n    private _sendCompleteEvent(forceClose: boolean): void {\n        this.onComplete.emit({\n            term: this._elementRef.nativeElement.value,\n            forceClose\n        });\n    }\n\n    /** @hidden */\n    private _moveIndicatorToLastCharacter(): void {\n        const inputTextLength = this.inputText?.length ?? 0;\n        this._elementRef.nativeElement.setSelectionRange(inputTextLength, inputTextLength);\n    }\n}\n"]}
@@ -353,7 +353,7 @@ class AutoCompleteDirective {
353
353
  * By ensuring that we set all properties we can proceed with stable data.
354
354
  */
355
355
  this._zone.runOutsideAngular(() => {
356
- const keyupEvent = fromEvent(this._elementRef.nativeElement, 'keyup');
356
+ const keyupEvent = fromEvent(this._elementRef.nativeElement, 'keydown');
357
357
  const compositionStartEvent = fromEvent(this._elementRef.nativeElement, 'compositionstart');
358
358
  const compositionEndEvent = fromEvent(this._elementRef.nativeElement, 'compositionend');
359
359
  keyupEvent