@alauda/ui 6.5.7-beta.8 → 6.5.7-beta.9
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.
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, ContentChildren, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
2
|
-
import { ReplaySubject, combineLatest, of, debounceTime, distinctUntilChanged, map, startWith, switchMap, tap, withLatestFrom, } from 'rxjs';
|
|
2
|
+
import { ReplaySubject, combineLatest, of, debounceTime, distinctUntilChanged, map, startWith, switchMap, tap, withLatestFrom, first, } from 'rxjs';
|
|
3
3
|
import { publishRef } from '../utils';
|
|
4
4
|
import { AutocompletePlaceholderComponent } from './autocomplete-placeholder.component';
|
|
5
5
|
import { SuggestionComponent } from './suggestion/suggestion.component';
|
|
@@ -22,7 +22,15 @@ export class AutocompleteComponent {
|
|
|
22
22
|
this.hasContent$ = combineLatest([
|
|
23
23
|
this.hasVisibleSuggestion$,
|
|
24
24
|
this.placeholder.changes.pipe(startWith(this.placeholder), map((list) => !!list.length)),
|
|
25
|
-
]).pipe(map(([hasVisibleSuggestion, hasPlaceholder]) => hasVisibleSuggestion || hasPlaceholder))
|
|
25
|
+
]).pipe(map(([hasVisibleSuggestion, hasPlaceholder]) => hasVisibleSuggestion || hasPlaceholder), distinctUntilChanged(), tap(hasContent => {
|
|
26
|
+
if (hasContent) {
|
|
27
|
+
this.directive$$.pipe(first()).subscribe(directive => {
|
|
28
|
+
window.requestAnimationFrame(() => {
|
|
29
|
+
directive.overlayRef.updatePosition();
|
|
30
|
+
});
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
}));
|
|
26
34
|
}
|
|
27
35
|
}
|
|
28
36
|
AutocompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AutocompleteComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -43,4 +51,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
43
51
|
type: ViewChild,
|
|
44
52
|
args: ['suggestionListRef', { static: true }]
|
|
45
53
|
}] } });
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../src/autocomplete/autocomplete.component.ts","../../../src/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  Observable,\n  ReplaySubject,\n  combineLatest,\n  of,\n  debounceTime,\n  distinctUntilChanged,\n  map,\n  startWith,\n  switchMap,\n  tap,\n  withLatestFrom,\n  first,\n} from 'rxjs';\n\nimport { publishRef } from '../utils';\n\nimport { AutocompletePlaceholderComponent } from './autocomplete-placeholder.component';\nimport { AutoCompleteDirective } from './autocomplete.directive';\nimport { SuggestionComponent } from './suggestion/suggestion.component';\n\n@Component({\n  selector: 'aui-autocomplete',\n  templateUrl: './autocomplete.component.html',\n  styleUrls: ['./autocomplete.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n})\nexport class AutocompleteComponent implements AfterContentInit {\n  @ContentChildren(SuggestionComponent, { descendants: true })\n  suggestions: QueryList<SuggestionComponent>;\n\n  @ContentChildren(AutocompletePlaceholderComponent)\n  placeholder: QueryList<AutocompletePlaceholderComponent>;\n\n  @ViewChild(TemplateRef, { static: true })\n  template: TemplateRef<any>;\n\n  @ViewChild('suggestionListRef', { static: true })\n  suggestionListRef: ElementRef;\n\n  hasVisibleSuggestion$: Observable<boolean>;\n  hasContent$: Observable<boolean>;\n\n  directive$$ = new ReplaySubject<AutoCompleteDirective>(1);\n\n  constructor(private readonly cdr: ChangeDetectorRef) {}\n\n  ngAfterContentInit() {\n    this.hasVisibleSuggestion$ = this.suggestions.changes.pipe(\n      startWith(this.suggestions),\n      switchMap((suggestions: QueryList<SuggestionComponent>) =>\n        suggestions.length > 0\n          ? combineLatest(suggestions.map(suggestion => suggestion.visible$))\n          : of([] as boolean[]),\n      ),\n      debounceTime(0),\n      map(visible => visible.some(Boolean)),\n      withLatestFrom(this.directive$$),\n      map(([hasVisibleSuggestion, directive]) => {\n        if (hasVisibleSuggestion && directive.defaultFirstSuggestion) {\n          directive.autoFocusFirstSuggestion();\n        }\n        return hasVisibleSuggestion;\n      }),\n      distinctUntilChanged(),\n      tap(() => this.cdr.markForCheck()),\n      publishRef(),\n    );\n\n    this.hasContent$ = combineLatest([\n      this.hasVisibleSuggestion$,\n      this.placeholder.changes.pipe(\n        startWith(this.placeholder),\n        map(\n          (list: QueryList<AutocompletePlaceholderComponent>) => !!list.length,\n        ),\n      ),\n    ]).pipe(\n      map(\n        ([hasVisibleSuggestion, hasPlaceholder]) =>\n          hasVisibleSuggestion || hasPlaceholder,\n      ),\n      distinctUntilChanged(),\n      tap(hasContent => {\n        if (hasContent) {\n          this.directive$$.pipe(first()).subscribe(directive => {\n            window.requestAnimationFrame(() => {\n              directive.overlayRef.updatePosition();\n            });\n          });\n        }\n      }),\n    );\n  }\n}\n","<ng-template let-width=\"width\">\n  <div\n    [hidden]=\"!(hasContent$ | async)\"\n    class=\"aui-autocomplete\"\n    [style.minWidth]=\"width\"\n    (mousedown)=\"$event.preventDefault()\"\n  >\n    <div\n      #suggestionListRef\n      class=\"aui-autocomplete__content\"\n    >\n      <ng-content></ng-content>\n    </div>\n    <div\n      [hidden]=\"hasVisibleSuggestion$ | async\"\n      class=\"aui-autocomplete__placeholder\"\n    >\n      <ng-content select=\"aui-autocomplete-placeholder\"></ng-content>\n    </div>\n  </div>\n</ng-template>\n"]}
|
package/fesm2015/alauda-ui.mjs
CHANGED
|
@@ -5,7 +5,7 @@ import * as i2 from '@angular/common';
|
|
|
5
5
|
import { DOCUMENT, CommonModule } from '@angular/common';
|
|
6
6
|
import * as i2$1 from '@angular/cdk/a11y';
|
|
7
7
|
import { FocusKeyManager, A11yModule } from '@angular/cdk/a11y';
|
|
8
|
-
import { Observable, ReplaySubject, share, startWith, map, distinctUntilChanged, Subject, takeUntil, filter, take, merge, fromEvent, combineLatest, debounceTime, switchMap, of, EMPTY, tap, BehaviorSubject, withLatestFrom, throttleTime, pluck, firstValueFrom, NEVER, observeOn, animationFrameScheduler, repeat, takeWhile, endWith, Subscription } from 'rxjs';
|
|
8
|
+
import { Observable, ReplaySubject, share, startWith, map, distinctUntilChanged, Subject, takeUntil, filter, take, merge, fromEvent, combineLatest, debounceTime, switchMap, of, EMPTY, tap, BehaviorSubject, withLatestFrom, first, throttleTime, pluck, firstValueFrom, NEVER, observeOn, animationFrameScheduler, repeat, takeWhile, endWith, Subscription } from 'rxjs';
|
|
9
9
|
import * as i1 from '@angular/common/http';
|
|
10
10
|
import { HttpClient } from '@angular/common/http';
|
|
11
11
|
import { trigger, state, style, transition, animate, query } from '@angular/animations';
|
|
@@ -1229,7 +1229,15 @@ class AutocompleteComponent {
|
|
|
1229
1229
|
this.hasContent$ = combineLatest([
|
|
1230
1230
|
this.hasVisibleSuggestion$,
|
|
1231
1231
|
this.placeholder.changes.pipe(startWith(this.placeholder), map((list) => !!list.length)),
|
|
1232
|
-
]).pipe(map(([hasVisibleSuggestion, hasPlaceholder]) => hasVisibleSuggestion || hasPlaceholder))
|
|
1232
|
+
]).pipe(map(([hasVisibleSuggestion, hasPlaceholder]) => hasVisibleSuggestion || hasPlaceholder), distinctUntilChanged(), tap(hasContent => {
|
|
1233
|
+
if (hasContent) {
|
|
1234
|
+
this.directive$$.pipe(first()).subscribe(directive => {
|
|
1235
|
+
window.requestAnimationFrame(() => {
|
|
1236
|
+
directive.overlayRef.updatePosition();
|
|
1237
|
+
});
|
|
1238
|
+
});
|
|
1239
|
+
}
|
|
1240
|
+
}));
|
|
1233
1241
|
}
|
|
1234
1242
|
}
|
|
1235
1243
|
AutocompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AutocompleteComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|