@fundamental-ngx/cdk 0.52.2-rc.9 → 0.52.3

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.
@@ -3,7 +3,7 @@ import { Directive, ElementRef, EventEmitter, Input, NgZone, Output, inject } fr
3
3
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
4
  import { fromEvent, map, switchMap } from 'rxjs';
5
5
  import { first } from 'rxjs/operators';
6
- import { KeyUtil } from '../../functions';
6
+ import { KeyUtil } from '../../functions/key-util';
7
7
  import * as i0 from "@angular/core";
8
8
  export class AutoCompleteDirective {
9
9
  /** @hidden */
@@ -25,8 +25,6 @@ export class AutoCompleteDirective {
25
25
  /** @hidden */
26
26
  this._stopKeys = [BACKSPACE, DELETE, ESCAPE];
27
27
  /** @hidden */
28
- this._isComposing = false;
29
- /** @hidden */
30
28
  this._elementRef = inject(ElementRef);
31
29
  this._zone = inject(NgZone);
32
30
  /** Matcher function for testing the str for a search term */
@@ -38,23 +36,14 @@ export class AutoCompleteDirective {
38
36
  */
39
37
  this._zone.runOutsideAngular(() => {
40
38
  const keyupEvent = fromEvent(this._elementRef.nativeElement, 'keyup');
41
- const compositionStartEvent = fromEvent(this._elementRef.nativeElement, 'compositionstart');
42
- const compositionEndEvent = fromEvent(this._elementRef.nativeElement, 'compositionend');
43
39
  keyupEvent
44
40
  .pipe(switchMap((evt) => this._zone.onStable.pipe(first(), map(() => evt))), takeUntilDestroyed())
45
41
  .subscribe((evt) => this._handleKeyboardEvent(evt));
46
- compositionStartEvent.pipe(takeUntilDestroyed()).subscribe(() => {
47
- this._isComposing = true;
48
- });
49
- compositionEndEvent.pipe(takeUntilDestroyed()).subscribe(() => {
50
- this._isComposing = false;
51
- this.inputText = this._elementRef.nativeElement.value;
52
- });
53
42
  });
54
43
  }
55
44
  /** @hidden */
56
45
  _handleKeyboardEvent(event) {
57
- if (this.enable && !this._isComposing) {
46
+ if (this.enable) {
58
47
  if (KeyUtil.isKeyCode(event, this._stopKeys)) {
59
48
  this._elementRef.nativeElement.value = this.inputText;
60
49
  }
@@ -66,6 +55,7 @@ export class AutoCompleteDirective {
66
55
  this._sendCompleteEvent(false);
67
56
  }
68
57
  else if (!this._isControlKey(event) && this.inputText) {
58
+ /** Prevention from triggering typeahead, when having crtl/cmd + keys */
69
59
  if (!this._triggerTypeAhead()) {
70
60
  return;
71
61
  }
@@ -132,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
132
122
  }], matcher: [{
133
123
  type: Input
134
124
  }] } });
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"]}
125
+ //# 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/key-util';\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 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            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    }\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) {\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                /** Prevention from triggering typeahead, when having crtl/cmd + keys */\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"]}