@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.
- package/autocomplete/autocomplete.component.d.ts +1 -0
- package/esm2020/autocomplete/autocomplete.component.mjs +13 -3
- package/fesm2015/alauda-ui.mjs +13 -2
- package/fesm2015/alauda-ui.mjs.map +1 -1
- package/fesm2020/alauda-ui.mjs +12 -2
- package/fesm2020/alauda-ui.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -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.
|
|
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)
|
|
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,
|
|
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"]}
|
package/fesm2015/alauda-ui.mjs
CHANGED
|
@@ -1218,9 +1218,10 @@ class AutocompleteComponent {
|
|
|
1218
1218
|
this.directive$$ = new ReplaySubject(1);
|
|
1219
1219
|
}
|
|
1220
1220
|
ngAfterContentInit() {
|
|
1221
|
-
this.
|
|
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)
|
|
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 });
|