@alauda/ui 6.5.8-beta.3 → 6.5.8-beta.5

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.
@@ -12,6 +12,7 @@ export declare class AutocompleteComponent implements AfterContentInit {
12
12
  suggestionListRef: ElementRef;
13
13
  hasVisibleSuggestion$: Observable<boolean>;
14
14
  hasContent$: Observable<boolean>;
15
+ visibles$: Observable<boolean[]>;
15
16
  directive$$: ReplaySubject<AutoCompleteDirective>;
16
17
  constructor(cdr: ChangeDetectorRef);
17
18
  ngAfterContentInit(): void;
@@ -11,9 +11,10 @@ export class AutocompleteComponent {
11
11
  this.directive$$ = new ReplaySubject(1);
12
12
  }
13
13
  ngAfterContentInit() {
14
- this.hasVisibleSuggestion$ = this.suggestions.changes.pipe(startWith(this.suggestions), switchMap((suggestions) => suggestions.length > 0
14
+ this.visibles$ = this.suggestions.changes.pipe(startWith(this.suggestions), switchMap((suggestions) => suggestions.length > 0
15
15
  ? combineLatest(suggestions.map(suggestion => suggestion.visible$))
16
- : of([])), debounceTime(0), map(visible => visible.some(Boolean)), withLatestFrom(this.directive$$), map(([hasVisibleSuggestion, directive]) => {
16
+ : of([])), debounceTime(0));
17
+ this.hasVisibleSuggestion$ = this.visibles$.pipe(map(visible => visible.some(Boolean)), withLatestFrom(this.directive$$), map(([hasVisibleSuggestion, directive]) => {
17
18
  if (hasVisibleSuggestion && directive.defaultFirstSuggestion) {
18
19
  directive.autoFocusFirstSuggestion();
19
20
  }
@@ -31,6 +32,15 @@ export class AutocompleteComponent {
31
32
  });
32
33
  }
33
34
  }));
35
+ this.visibles$
36
+ .pipe(distinctUntilChanged((prev, cur) => JSON.stringify(prev) === JSON.stringify(cur)))
37
+ .subscribe(() => {
38
+ this.directive$$.pipe(first()).subscribe(directive => {
39
+ window.requestAnimationFrame(() => {
40
+ directive.overlayRef?.updatePosition();
41
+ });
42
+ });
43
+ });
34
44
  }
35
45
  }
36
46
  AutocompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AutocompleteComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
@@ -51,4 +61,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
51
61
  type: ViewChild,
52
62
  args: ['suggestionListRef', { static: true }]
53
63
  }] } });
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"]}
64
+ //# 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  visibles$: Observable<boolean[]>;\n\n  directive$$ = new ReplaySubject<AutoCompleteDirective>(1);\n\n  constructor(private readonly cdr: ChangeDetectorRef) {}\n\n  ngAfterContentInit() {\n    this.visibles$ = 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    );\n    this.hasVisibleSuggestion$ = this.visibles$.pipe(\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    this.visibles$\n      .pipe(\n        distinctUntilChanged(\n          (prev, cur) => JSON.stringify(prev) === JSON.stringify(cur),\n        ),\n      )\n      .subscribe(() => {\n        this.directive$$.pipe(first()).subscribe(directive => {\n          window.requestAnimationFrame(() => {\n            directive.overlayRef?.updatePosition();\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"]}
@@ -1218,9 +1218,10 @@ class AutocompleteComponent {
1218
1218
  this.directive$$ = new ReplaySubject(1);
1219
1219
  }
1220
1220
  ngAfterContentInit() {
1221
- this.hasVisibleSuggestion$ = this.suggestions.changes.pipe(startWith(this.suggestions), switchMap((suggestions) => suggestions.length > 0
1221
+ this.visibles$ = this.suggestions.changes.pipe(startWith(this.suggestions), switchMap((suggestions) => suggestions.length > 0
1222
1222
  ? combineLatest(suggestions.map(suggestion => suggestion.visible$))
1223
- : of([])), debounceTime(0), map(visible => visible.some(Boolean)), withLatestFrom(this.directive$$), map(([hasVisibleSuggestion, directive]) => {
1223
+ : of([])), debounceTime(0));
1224
+ this.hasVisibleSuggestion$ = this.visibles$.pipe(map(visible => visible.some(Boolean)), withLatestFrom(this.directive$$), map(([hasVisibleSuggestion, directive]) => {
1224
1225
  if (hasVisibleSuggestion && directive.defaultFirstSuggestion) {
1225
1226
  directive.autoFocusFirstSuggestion();
1226
1227
  }
@@ -1238,6 +1239,16 @@ class AutocompleteComponent {
1238
1239
  });
1239
1240
  }
1240
1241
  }));
1242
+ this.visibles$
1243
+ .pipe(distinctUntilChanged((prev, cur) => JSON.stringify(prev) === JSON.stringify(cur)))
1244
+ .subscribe(() => {
1245
+ this.directive$$.pipe(first()).subscribe(directive => {
1246
+ window.requestAnimationFrame(() => {
1247
+ var _a;
1248
+ (_a = directive.overlayRef) === null || _a === void 0 ? void 0 : _a.updatePosition();
1249
+ });
1250
+ });
1251
+ });
1241
1252
  }
1242
1253
  }
1243
1254
  AutocompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AutocompleteComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });