@alauda/ui 6.5.10-beta.15 → 6.5.10-beta.16
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.
|
@@ -18,6 +18,7 @@ export declare class BackTopComponent {
|
|
|
18
18
|
isDisplayed$: import("rxjs").Observable<boolean>;
|
|
19
19
|
getTargetScrollTop(target: Element | Window): number;
|
|
20
20
|
handleClick(event: Event): void;
|
|
21
|
+
scrollToTop(duration: number): void;
|
|
21
22
|
getTarget(target: TargetType): Element | Window;
|
|
22
23
|
static ɵfac: i0.ɵɵFactoryDeclaration<BackTopComponent, [{ optional: true; }]>;
|
|
23
24
|
static ɵcmp: i0.ɵɵComponentDeclaration<BackTopComponent, "aui-back-top", never, { "visibilityHeight": { "alias": "visibilityHeight"; "required": false; }; "target": { "alias": "target"; "required": false; }; }, { "click": "click"; }, never, never, false, never>;
|
|
@@ -40,9 +40,24 @@ export class BackTopComponent {
|
|
|
40
40
|
return target.scrollTop;
|
|
41
41
|
}
|
|
42
42
|
handleClick(event) {
|
|
43
|
-
this.
|
|
43
|
+
this.scrollToTop(300);
|
|
44
44
|
this.click.emit(event);
|
|
45
45
|
}
|
|
46
|
+
scrollToTop(duration) {
|
|
47
|
+
const startHeight = this.getTargetScrollTop(this._scrollTarget);
|
|
48
|
+
let startTime;
|
|
49
|
+
const scrollStep = (timestamp) => {
|
|
50
|
+
if (!startTime) {
|
|
51
|
+
startTime = timestamp;
|
|
52
|
+
}
|
|
53
|
+
const scrollHeight = Math.max(startHeight - ((timestamp - startTime) / duration) * startHeight, 0);
|
|
54
|
+
this._scrollTarget.scrollTo(0, scrollHeight);
|
|
55
|
+
if (scrollHeight) {
|
|
56
|
+
requestAnimationFrame(scrollStep);
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
requestAnimationFrame(scrollStep);
|
|
60
|
+
}
|
|
46
61
|
getTarget(target) {
|
|
47
62
|
const scrollTarget = (typeof target === 'string' && document.querySelector(target)) ||
|
|
48
63
|
this.cdkScrollable?.getElementRef().nativeElement ||
|
|
@@ -65,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImpor
|
|
|
65
80
|
}], click: [{
|
|
66
81
|
type: Output
|
|
67
82
|
}] } });
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"back-top.component.js","sourceRoot":"","sources":["../../../src/back-top/back-top.component.ts","../../../src/back-top/back-top.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkScrollable } from '@angular/cdk/overlay';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Optional,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  fromEvent,\n  distinctUntilChanged,\n  map,\n  switchMap,\n  throttleTime,\n} from 'rxjs';\n\ntype TargetType = Element | Window | string;\n\n@Component({\n  selector: 'aui-back-top',\n  templateUrl: './back-top.component.html',\n  styleUrls: ['./back-top.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n})\nexport class BackTopComponent {\n  @Input()\n  set visibilityHeight(val: number) {\n    this._visibilityHeight = val;\n    this.visibilityHeight$$.next(val);\n  }\n\n  get visibilityHeight() {\n    return this._visibilityHeight;\n  }\n\n  @Input()\n  set target(val: TargetType) {\n    this._target = val;\n    this.target$$.next(val);\n  }\n\n  get target() {\n    return this._target;\n  }\n\n  @Output()\n  click = new EventEmitter<Event>();\n\n  private _visibilityHeight = 400;\n  private readonly target$$ = new BehaviorSubject<TargetType>(this.target);\n  private readonly visibilityHeight$$ = new BehaviorSubject<number>(\n    this.visibilityHeight,\n  );\n\n  private _target: TargetType;\n  private _scrollTarget: Element | Window;\n\n  constructor(@Optional() private readonly cdkScrollable: CdkScrollable) {}\n\n  isDisplayed$ = combineLatest([\n    this.target$$.asObservable().pipe(\n      map(target => this.getTarget(target)),\n      switchMap(target =>\n        fromEvent(target, 'scroll').pipe(\n          // use default scheduler\n          throttleTime(50, undefined, { leading: true, trailing: true }),\n          map(() => this.getTargetScrollTop(target)),\n        ),\n      ),\n    ),\n    this.visibilityHeight$$,\n  ]).pipe(\n    map(([scrollTop, visibilityHeight]) => scrollTop >= visibilityHeight),\n    distinctUntilChanged(),\n  );\n\n  getTargetScrollTop(target: Element | Window) {\n    if (target === window) {\n      return document.documentElement.scrollTop;\n    }\n    return (target as HTMLElement).scrollTop;\n  }\n\n  handleClick(event: Event) {\n    this.scrollToTop(300);\n    this.click.emit(event);\n  }\n\n  scrollToTop(duration: number) {\n    const startHeight = this.getTargetScrollTop(this._scrollTarget);\n    let startTime: number;\n\n    const scrollStep = (timestamp: number) => {\n      if (!startTime) {\n        startTime = timestamp;\n      }\n      const scrollHeight = Math.max(\n        startHeight - ((timestamp - startTime) / duration) * startHeight,\n        0,\n      );\n\n      this._scrollTarget.scrollTo(0, scrollHeight);\n      if (scrollHeight) {\n        requestAnimationFrame(scrollStep);\n      }\n    };\n    requestAnimationFrame(scrollStep);\n  }\n\n  getTarget(target: TargetType): Element | Window {\n    const scrollTarget =\n      (typeof target === 'string' && document.querySelector(target)) ||\n      this.cdkScrollable?.getElementRef().nativeElement ||\n      window;\n    this._scrollTarget = scrollTarget;\n    return scrollTarget;\n  }\n}\n","<div\n  class=\"aui-back-top\"\n  (click)=\"handleClick($event)\"\n  [class.show]=\"isDisplayed$ | async\"\n>\n  <aui-icon\n    icon=\"arrow_up_to_line\"\n    class=\"aui-back-top__icon\"\n  ></aui-icon>\n</div>\n"]}
|
package/fesm2022/alauda-ui.mjs
CHANGED
|
@@ -2384,9 +2384,24 @@ class BackTopComponent {
|
|
|
2384
2384
|
return target.scrollTop;
|
|
2385
2385
|
}
|
|
2386
2386
|
handleClick(event) {
|
|
2387
|
-
this.
|
|
2387
|
+
this.scrollToTop(300);
|
|
2388
2388
|
this.click.emit(event);
|
|
2389
2389
|
}
|
|
2390
|
+
scrollToTop(duration) {
|
|
2391
|
+
const startHeight = this.getTargetScrollTop(this._scrollTarget);
|
|
2392
|
+
let startTime;
|
|
2393
|
+
const scrollStep = (timestamp) => {
|
|
2394
|
+
if (!startTime) {
|
|
2395
|
+
startTime = timestamp;
|
|
2396
|
+
}
|
|
2397
|
+
const scrollHeight = Math.max(startHeight - ((timestamp - startTime) / duration) * startHeight, 0);
|
|
2398
|
+
this._scrollTarget.scrollTo(0, scrollHeight);
|
|
2399
|
+
if (scrollHeight) {
|
|
2400
|
+
requestAnimationFrame(scrollStep);
|
|
2401
|
+
}
|
|
2402
|
+
};
|
|
2403
|
+
requestAnimationFrame(scrollStep);
|
|
2404
|
+
}
|
|
2390
2405
|
getTarget(target) {
|
|
2391
2406
|
const scrollTarget = (typeof target === 'string' && document.querySelector(target)) ||
|
|
2392
2407
|
this.cdkScrollable?.getElementRef().nativeElement ||
|