@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._scrollTarget.scrollTo({ top: 0, behavior: 'smooth' });
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFjay10b3AuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2JhY2stdG9wL2JhY2stdG9wLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uL3NyYy9iYWNrLXRvcC9iYWNrLXRvcC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUNMLFFBQVEsRUFDUixNQUFNLEVBQ04saUJBQWlCLEdBQ2xCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFDTCxlQUFlLEVBQ2YsYUFBYSxFQUNiLFNBQVMsRUFDVCxvQkFBb0IsRUFDcEIsR0FBRyxFQUNILFNBQVMsRUFDVCxZQUFZLEdBQ2IsTUFBTSxNQUFNLENBQUM7Ozs7O0FBWWQsTUFBTSxPQUFPLGdCQUFnQjtJQWlDYztJQWhDekMsSUFDSSxnQkFBZ0IsQ0FBQyxHQUFXO1FBQzlCLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxHQUFHLENBQUM7UUFDN0IsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRUQsSUFBSSxnQkFBZ0I7UUFDbEIsT0FBTyxJQUFJLENBQUMsaUJBQWlCLENBQUM7SUFDaEMsQ0FBQztJQUVELElBQ0ksTUFBTSxDQUFDLEdBQWU7UUFDeEIsSUFBSSxDQUFDLE9BQU8sR0FBRyxHQUFHLENBQUM7UUFDbkIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQUVELElBQUksTUFBTTtRQUNSLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0lBR0QsS0FBSyxHQUFHLElBQUksWUFBWSxFQUFTLENBQUM7SUFFMUIsaUJBQWlCLEdBQUcsR0FBRyxDQUFDO0lBQ2YsUUFBUSxHQUFHLElBQUksZUFBZSxDQUFhLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN4RCxrQkFBa0IsR0FBRyxJQUFJLGVBQWUsQ0FDdkQsSUFBSSxDQUFDLGdCQUFnQixDQUN0QixDQUFDO0lBRU0sT0FBTyxDQUFhO0lBQ3BCLGFBQWEsQ0FBbUI7SUFFeEMsWUFBeUMsYUFBNEI7UUFBNUIsa0JBQWEsR0FBYixhQUFhLENBQWU7SUFBRyxDQUFDO0lBRXpFLFlBQVksR0FBRyxhQUFhLENBQUM7UUFDM0IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxZQUFZLEVBQUUsQ0FBQyxJQUFJLENBQy9CLEdBQUcsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUMsRUFDckMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQ2pCLFNBQVMsQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUMsSUFBSSxDQUU5QixZQUFZLENBQUMsRUFBRSxFQUFFLFNBQVMsRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDLEVBQzlELEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FDM0MsQ0FDRixDQUNGO1FBQ0QsSUFBSSxDQUFDLGtCQUFrQjtLQUN4QixDQUFDLENBQUMsSUFBSSxDQUNMLEdBQUcsQ0FBQyxDQUFDLENBQUMsU0FBUyxFQUFFLGdCQUFnQixDQUFDLEVBQUUsRUFBRSxDQUFDLFNBQVMsSUFBSSxnQkFBZ0IsQ0FBQyxFQUNyRSxvQkFBb0IsRUFBRSxDQUN2QixDQUFDO0lBRUYsa0JBQWtCLENBQUMsTUFBd0I7UUFDekMsSUFBSSxNQUFNLEtBQUssTUFBTSxFQUFFO1lBQ3JCLE9BQU8sUUFBUSxDQUFDLGVBQWUsQ0FBQyxTQUFTLENBQUM7U0FDM0M7UUFDRCxPQUFRLE1BQXNCLENBQUMsU0FBUyxDQUFDO0lBQzNDLENBQUM7SUFFRCxXQUFXLENBQUMsS0FBWTtRQUN0QixJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxDQUFDLENBQUM7UUFDNUQsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDekIsQ0FBQztJQUVELFNBQVMsQ0FBQyxNQUFrQjtRQUMxQixNQUFNLFlBQVksR0FDaEIsQ0FBQyxPQUFPLE1BQU0sS0FBSyxRQUFRLElBQUksUUFBUSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUM5RCxJQUFJLENBQUMsYUFBYSxFQUFFLGFBQWEsRUFBRSxDQUFDLGFBQWE7WUFDakQsTUFBTSxDQUFDO1FBQ1QsSUFBSSxDQUFDLGFBQWEsR0FBRyxZQUFZLENBQUM7UUFDbEMsT0FBTyxZQUFZLENBQUM7SUFDdEIsQ0FBQzt1R0F2RVUsZ0JBQWdCOzJGQUFoQixnQkFBZ0IscUpDOUI3Qix1TkFVQTs7MkZEb0JhLGdCQUFnQjtrQkFSNUIsU0FBUzsrQkFDRSxjQUFjLGlCQUdULGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0sdUJBQzFCLEtBQUs7OzBCQW1DYixRQUFROzRDQS9CakIsZ0JBQWdCO3NCQURuQixLQUFLO2dCQVdGLE1BQU07c0JBRFQsS0FBSztnQkFXTixLQUFLO3NCQURKLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDZGtTY3JvbGxhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT3B0aW9uYWwsXG4gIE91dHB1dCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgQmVoYXZpb3JTdWJqZWN0LFxuICBjb21iaW5lTGF0ZXN0LFxuICBmcm9tRXZlbnQsXG4gIGRpc3RpbmN0VW50aWxDaGFuZ2VkLFxuICBtYXAsXG4gIHN3aXRjaE1hcCxcbiAgdGhyb3R0bGVUaW1lLFxufSBmcm9tICdyeGpzJztcblxudHlwZSBUYXJnZXRUeXBlID0gRWxlbWVudCB8IFdpbmRvdyB8IHN0cmluZztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXVpLWJhY2stdG9wJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2JhY2stdG9wLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYmFjay10b3AuY29tcG9uZW50LnNjc3MnXSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHByZXNlcnZlV2hpdGVzcGFjZXM6IGZhbHNlLFxufSlcbmV4cG9ydCBjbGFzcyBCYWNrVG9wQ29tcG9uZW50IHtcbiAgQElucHV0KClcbiAgc2V0IHZpc2liaWxpdHlIZWlnaHQodmFsOiBudW1iZXIpIHtcbiAgICB0aGlzLl92aXNpYmlsaXR5SGVpZ2h0ID0gdmFsO1xuICAgIHRoaXMudmlzaWJpbGl0eUhlaWdodCQkLm5leHQodmFsKTtcbiAgfVxuXG4gIGdldCB2aXNpYmlsaXR5SGVpZ2h0KCkge1xuICAgIHJldHVybiB0aGlzLl92aXNpYmlsaXR5SGVpZ2h0O1xuICB9XG5cbiAgQElucHV0KClcbiAgc2V0IHRhcmdldCh2YWw6IFRhcmdldFR5cGUpIHtcbiAgICB0aGlzLl90YXJnZXQgPSB2YWw7XG4gICAgdGhpcy50YXJnZXQkJC5uZXh0KHZhbCk7XG4gIH1cblxuICBnZXQgdGFyZ2V0KCkge1xuICAgIHJldHVybiB0aGlzLl90YXJnZXQ7XG4gIH1cblxuICBAT3V0cHV0KClcbiAgY2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyPEV2ZW50PigpO1xuXG4gIHByaXZhdGUgX3Zpc2liaWxpdHlIZWlnaHQgPSA0MDA7XG4gIHByaXZhdGUgcmVhZG9ubHkgdGFyZ2V0JCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PFRhcmdldFR5cGU+KHRoaXMudGFyZ2V0KTtcbiAgcHJpdmF0ZSByZWFkb25seSB2aXNpYmlsaXR5SGVpZ2h0JCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PG51bWJlcj4oXG4gICAgdGhpcy52aXNpYmlsaXR5SGVpZ2h0LFxuICApO1xuXG4gIHByaXZhdGUgX3RhcmdldDogVGFyZ2V0VHlwZTtcbiAgcHJpdmF0ZSBfc2Nyb2xsVGFyZ2V0OiBFbGVtZW50IHwgV2luZG93O1xuXG4gIGNvbnN0cnVjdG9yKEBPcHRpb25hbCgpIHByaXZhdGUgcmVhZG9ubHkgY2RrU2Nyb2xsYWJsZTogQ2RrU2Nyb2xsYWJsZSkge31cblxuICBpc0Rpc3BsYXllZCQgPSBjb21iaW5lTGF0ZXN0KFtcbiAgICB0aGlzLnRhcmdldCQkLmFzT2JzZXJ2YWJsZSgpLnBpcGUoXG4gICAgICBtYXAodGFyZ2V0ID0+IHRoaXMuZ2V0VGFyZ2V0KHRhcmdldCkpLFxuICAgICAgc3dpdGNoTWFwKHRhcmdldCA9PlxuICAgICAgICBmcm9tRXZlbnQodGFyZ2V0LCAnc2Nyb2xsJykucGlwZShcbiAgICAgICAgICAvLyB1c2UgZGVmYXVsdCBzY2hlZHVsZXJcbiAgICAgICAgICB0aHJvdHRsZVRpbWUoNTAsIHVuZGVmaW5lZCwgeyBsZWFkaW5nOiB0cnVlLCB0cmFpbGluZzogdHJ1ZSB9KSxcbiAgICAgICAgICBtYXAoKCkgPT4gdGhpcy5nZXRUYXJnZXRTY3JvbGxUb3AodGFyZ2V0KSksXG4gICAgICAgICksXG4gICAgICApLFxuICAgICksXG4gICAgdGhpcy52aXNpYmlsaXR5SGVpZ2h0JCQsXG4gIF0pLnBpcGUoXG4gICAgbWFwKChbc2Nyb2xsVG9wLCB2aXNpYmlsaXR5SGVpZ2h0XSkgPT4gc2Nyb2xsVG9wID49IHZpc2liaWxpdHlIZWlnaHQpLFxuICAgIGRpc3RpbmN0VW50aWxDaGFuZ2VkKCksXG4gICk7XG5cbiAgZ2V0VGFyZ2V0U2Nyb2xsVG9wKHRhcmdldDogRWxlbWVudCB8IFdpbmRvdykge1xuICAgIGlmICh0YXJnZXQgPT09IHdpbmRvdykge1xuICAgICAgcmV0dXJuIGRvY3VtZW50LmRvY3VtZW50RWxlbWVudC5zY3JvbGxUb3A7XG4gICAgfVxuICAgIHJldHVybiAodGFyZ2V0IGFzIEhUTUxFbGVtZW50KS5zY3JvbGxUb3A7XG4gIH1cblxuICBoYW5kbGVDbGljayhldmVudDogRXZlbnQpIHtcbiAgICB0aGlzLl9zY3JvbGxUYXJnZXQuc2Nyb2xsVG8oeyB0b3A6IDAsIGJlaGF2aW9yOiAnc21vb3RoJyB9KTtcbiAgICB0aGlzLmNsaWNrLmVtaXQoZXZlbnQpO1xuICB9XG5cbiAgZ2V0VGFyZ2V0KHRhcmdldDogVGFyZ2V0VHlwZSk6IEVsZW1lbnQgfCBXaW5kb3cge1xuICAgIGNvbnN0IHNjcm9sbFRhcmdldCA9XG4gICAgICAodHlwZW9mIHRhcmdldCA9PT0gJ3N0cmluZycgJiYgZG9jdW1lbnQucXVlcnlTZWxlY3Rvcih0YXJnZXQpKSB8fFxuICAgICAgdGhpcy5jZGtTY3JvbGxhYmxlPy5nZXRFbGVtZW50UmVmKCkubmF0aXZlRWxlbWVudCB8fFxuICAgICAgd2luZG93O1xuICAgIHRoaXMuX3Njcm9sbFRhcmdldCA9IHNjcm9sbFRhcmdldDtcbiAgICByZXR1cm4gc2Nyb2xsVGFyZ2V0O1xuICB9XG59XG4iLCI8ZGl2XG4gIGNsYXNzPVwiYXVpLWJhY2stdG9wXCJcbiAgKGNsaWNrKT1cImhhbmRsZUNsaWNrKCRldmVudClcIlxuICBbY2xhc3Muc2hvd109XCJpc0Rpc3BsYXllZCQgfCBhc3luY1wiXG4+XG4gIDxhdWktaWNvblxuICAgIGljb249XCJhcnJvd191cF90b19saW5lXCJcbiAgICBjbGFzcz1cImF1aS1iYWNrLXRvcF9faWNvblwiXG4gID48L2F1aS1pY29uPlxuPC9kaXY+XG4iXX0=
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":"AACA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,QAAQ,EACR,MAAM,EACN,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,eAAe,EACf,aAAa,EACb,SAAS,EACT,oBAAoB,EACpB,GAAG,EACH,SAAS,EACT,YAAY,GACb,MAAM,MAAM,CAAC;;;;;AAYd,MAAM,OAAO,gBAAgB;IAiCc;IAhCzC,IACI,gBAAgB,CAAC,GAAW;QAC9B,IAAI,CAAC,iBAAiB,GAAG,GAAG,CAAC;QAC7B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACpC,CAAC;IAED,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IAED,IACI,MAAM,CAAC,GAAe;QACxB,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC;QACnB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAGD,KAAK,GAAG,IAAI,YAAY,EAAS,CAAC;IAE1B,iBAAiB,GAAG,GAAG,CAAC;IACf,QAAQ,GAAG,IAAI,eAAe,CAAa,IAAI,CAAC,MAAM,CAAC,CAAC;IACxD,kBAAkB,GAAG,IAAI,eAAe,CACvD,IAAI,CAAC,gBAAgB,CACtB,CAAC;IAEM,OAAO,CAAa;IACpB,aAAa,CAAmB;IAExC,YAAyC,aAA4B;QAA5B,kBAAa,GAAb,aAAa,CAAe;IAAG,CAAC;IAEzE,YAAY,GAAG,aAAa,CAAC;QAC3B,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,CAAC,IAAI,CAC/B,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,EACrC,SAAS,CAAC,MAAM,CAAC,EAAE,CACjB,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,IAAI,CAE9B,YAAY,CAAC,EAAE,EAAE,SAAS,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,EAC9D,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAC3C,CACF,CACF;QACD,IAAI,CAAC,kBAAkB;KACxB,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,gBAAgB,CAAC,EAAE,EAAE,CAAC,SAAS,IAAI,gBAAgB,CAAC,EACrE,oBAAoB,EAAE,CACvB,CAAC;IAEF,kBAAkB,CAAC,MAAwB;QACzC,IAAI,MAAM,KAAK,MAAM,EAAE;YACrB,OAAO,QAAQ,CAAC,eAAe,CAAC,SAAS,CAAC;SAC3C;QACD,OAAQ,MAAsB,CAAC,SAAS,CAAC;IAC3C,CAAC;IAED,WAAW,CAAC,KAAY;QACtB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QACtB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IAED,WAAW,CAAC,QAAgB;QAC1B,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAChE,IAAI,SAAiB,CAAC;QAEtB,MAAM,UAAU,GAAG,CAAC,SAAiB,EAAE,EAAE;YACvC,IAAI,CAAC,SAAS,EAAE;gBACd,SAAS,GAAG,SAAS,CAAC;aACvB;YACD,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAC3B,WAAW,GAAG,CAAC,CAAC,SAAS,GAAG,SAAS,CAAC,GAAG,QAAQ,CAAC,GAAG,WAAW,EAChE,CAAC,CACF,CAAC;YAEF,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC;YAC7C,IAAI,YAAY,EAAE;gBAChB,qBAAqB,CAAC,UAAU,CAAC,CAAC;aACnC;QACH,CAAC,CAAC;QACF,qBAAqB,CAAC,UAAU,CAAC,CAAC;IACpC,CAAC;IAED,SAAS,CAAC,MAAkB;QAC1B,MAAM,YAAY,GAChB,CAAC,OAAO,MAAM,KAAK,QAAQ,IAAI,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YAC9D,IAAI,CAAC,aAAa,EAAE,aAAa,EAAE,CAAC,aAAa;YACjD,MAAM,CAAC;QACT,IAAI,CAAC,aAAa,GAAG,YAAY,CAAC;QAClC,OAAO,YAAY,CAAC;IACtB,CAAC;uGA5FU,gBAAgB;2FAAhB,gBAAgB,qJC9B7B,uNAUA;;2FDoBa,gBAAgB;kBAR5B,SAAS;+BACE,cAAc,iBAGT,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,uBAC1B,KAAK;;0BAmCb,QAAQ;4CA/BjB,gBAAgB;sBADnB,KAAK;gBAWF,MAAM;sBADT,KAAK;gBAWN,KAAK;sBADJ,MAAM","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"]}
@@ -2384,9 +2384,24 @@ class BackTopComponent {
2384
2384
  return target.scrollTop;
2385
2385
  }
2386
2386
  handleClick(event) {
2387
- this._scrollTarget.scrollTo({ top: 0, behavior: 'smooth' });
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 ||