UNPKG

ng-zorro-antd

Version:

An enterprise-class UI components based on Ant Design and Angular

218 lines 16.5 kB
/** * @fileoverview added by tsickle * Generated from: scroll/nz-scroll.service.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @license * Copyright Alibaba.com All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE */ import { DOCUMENT } from '@angular/common'; import { Inject, Injectable, Optional, SkipSelf } from '@angular/core'; import { reqAnimFrame } from '../polyfill/request-animation'; /** * @param {?} t * @param {?} b * @param {?} c * @param {?} d * @return {?} */ function easeInOutCubic(t, b, c, d) { /** @type {?} */ var cc = c - b; /** @type {?} */ var tt = t / (d / 2); if (tt < 1) { return (cc / 2) * tt * tt * tt + b; } else { return (cc / 2) * ((tt -= 2) * tt * tt + 2) + b; } } var NzScrollService = /** @class */ (function () { /* tslint:disable-next-line:no-any */ function NzScrollService(doc) { this.doc = doc; } /** Set the position of the scroll bar of `el`. */ /** * Set the position of the scroll bar of `el`. * @param {?} el * @param {?=} topValue * @return {?} */ NzScrollService.prototype.setScrollTop = /** * Set the position of the scroll bar of `el`. * @param {?} el * @param {?=} topValue * @return {?} */ function (el, topValue) { if (topValue === void 0) { topValue = 0; } if (el === window) { this.doc.body.scrollTop = topValue; (/** @type {?} */ (this.doc.documentElement)).scrollTop = topValue; } else { ((/** @type {?} */ (el))).scrollTop = topValue; } }; /** Get position of `el` against window. */ /** * Get position of `el` against window. * @param {?} el * @return {?} */ NzScrollService.prototype.getOffset = /** * Get position of `el` against window. * @param {?} el * @return {?} */ function (el) { /** @type {?} */ var ret = { top: 0, left: 0 }; if (!el || !el.getClientRects().length) { return ret; } /** @type {?} */ var rect = el.getBoundingClientRect(); if (rect.width || rect.height) { /** @type {?} */ var doc = (/** @type {?} */ (el.ownerDocument)).documentElement; ret.top = rect.top - (/** @type {?} */ (doc)).clientTop; ret.left = rect.left - (/** @type {?} */ (doc)).clientLeft; } else { ret.top = rect.top; ret.left = rect.left; } return ret; }; /** Get the position of the scoll bar of `el`. */ // TODO: remove '| Window' as the fallback already happens here /** * Get the position of the scoll bar of `el`. * @param {?=} el * @param {?=} top * @return {?} */ // TODO: remove '| Window' as the fallback already happens here NzScrollService.prototype.getScroll = /** * Get the position of the scoll bar of `el`. * @param {?=} el * @param {?=} top * @return {?} */ // TODO: remove '| Window' as the fallback already happens here function (el, top) { if (top === void 0) { top = true; } /** @type {?} */ var target = el ? el : window; /** @type {?} */ var prop = top ? 'pageYOffset' : 'pageXOffset'; /** @type {?} */ var method = top ? 'scrollTop' : 'scrollLeft'; /** @type {?} */ var isWindow = target === window; // @ts-ignore /** @type {?} */ var ret = isWindow ? target[prop] : target[method]; if (isWindow && typeof ret !== 'number') { ret = (/** @type {?} */ (this.doc.documentElement))[method]; } return ret; }; /** * Scroll `el` to some position with animation. * * @param containerEl container, `window` by default * @param targetTopValue Scroll to `top`, 0 by default * @param easing Transition curve, `easeInOutCubic` by default * @param callback callback invoked when transition is done */ /** * Scroll `el` to some position with animation. * * @param {?} containerEl container, `window` by default * @param {?=} targetTopValue Scroll to `top`, 0 by default * @param {?=} easing Transition curve, `easeInOutCubic` by default * @param {?=} callback callback invoked when transition is done * @return {?} */ NzScrollService.prototype.scrollTo = /** * Scroll `el` to some position with animation. * * @param {?} containerEl container, `window` by default * @param {?=} targetTopValue Scroll to `top`, 0 by default * @param {?=} easing Transition curve, `easeInOutCubic` by default * @param {?=} callback callback invoked when transition is done * @return {?} */ function (containerEl, targetTopValue, easing, callback) { var _this = this; if (targetTopValue === void 0) { targetTopValue = 0; } /** @type {?} */ var target = containerEl ? containerEl : window; /** @type {?} */ var scrollTop = this.getScroll(target); /** @type {?} */ var startTime = Date.now(); /** @type {?} */ var frameFunc = (/** * @return {?} */ function () { /** @type {?} */ var timestamp = Date.now(); /** @type {?} */ var time = timestamp - startTime; _this.setScrollTop(target, (easing || easeInOutCubic)(time, scrollTop, targetTopValue, 450)); if (time < 450) { reqAnimFrame(frameFunc); } else { if (callback) { callback(); } } }); reqAnimFrame(frameFunc); }; NzScrollService.decorators = [ { type: Injectable } ]; /** @nocollapse */ NzScrollService.ctorParameters = function () { return [ { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] } ]; }; return NzScrollService; }()); export { NzScrollService }; if (false) { /** * @type {?} * @private */ NzScrollService.prototype.doc; } /** * @param {?} doc * @param {?} scrollService * @return {?} */ export function SCROLL_SERVICE_PROVIDER_FACTORY(doc, scrollService) { return scrollService || new NzScrollService(doc); } /** @type {?} */ export var SCROLL_SERVICE_PROVIDER = { provide: NzScrollService, useFactory: SCROLL_SERVICE_PROVIDER_FACTORY, deps: [DOCUMENT, [new Optional(), new SkipSelf(), NzScrollService]] }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-scroll.service.js","sourceRoot":"ng://ng-zorro-antd/core/","sources":["scroll/nz-scroll.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { DOCUMENT } from '@angular/common';\nimport { Inject, Injectable, Optional, Provider, SkipSelf } from '@angular/core';\n\nimport { reqAnimFrame } from '../polyfill/request-animation';\n\nexport type EasyingFn = (t: number, b: number, c: number, d: number) => number;\n\nfunction easeInOutCubic(t: number, b: number, c: number, d: number): number {\n  const cc = c - b;\n  let tt = t / (d / 2);\n  if (tt < 1) {\n    return (cc / 2) * tt * tt * tt + b;\n  } else {\n    return (cc / 2) * ((tt -= 2) * tt * tt + 2) + b;\n  }\n}\n\n@Injectable()\nexport class NzScrollService {\n  private doc: Document;\n\n  /* tslint:disable-next-line:no-any */\n  constructor(@Inject(DOCUMENT) doc: any) {\n    this.doc = doc;\n  }\n\n  /** Set the position of the scroll bar of `el`. */\n  setScrollTop(el: Element | Window, topValue: number = 0): void {\n    if (el === window) {\n      this.doc.body.scrollTop = topValue;\n      this.doc.documentElement!.scrollTop = topValue;\n    } else {\n      (el as Element).scrollTop = topValue;\n    }\n  }\n\n  /** Get position of `el` against window. */\n  getOffset(el: Element): { top: number; left: number } {\n    const ret = {\n      top: 0,\n      left: 0\n    };\n    if (!el || !el.getClientRects().length) {\n      return ret;\n    }\n\n    const rect = el.getBoundingClientRect();\n    if (rect.width || rect.height) {\n      const doc = el.ownerDocument!.documentElement;\n      ret.top = rect.top - doc!.clientTop;\n      ret.left = rect.left - doc!.clientLeft;\n    } else {\n      ret.top = rect.top;\n      ret.left = rect.left;\n    }\n\n    return ret;\n  }\n\n  /** Get the position of the scoll bar of `el`. */\n  // TODO: remove '| Window' as the fallback already happens here\n  getScroll(el?: Element | Window, top: boolean = true): number {\n    const target = el ? el : window;\n    const prop = top ? 'pageYOffset' : 'pageXOffset';\n    const method = top ? 'scrollTop' : 'scrollLeft';\n    const isWindow = target === window;\n    // @ts-ignore\n    let ret = isWindow ? target[prop] : target[method];\n    if (isWindow && typeof ret !== 'number') {\n      ret = this.doc.documentElement![method];\n    }\n    return ret;\n  }\n\n  /**\n   * Scroll `el` to some position with animation.\n   *\n   * @param containerEl container, `window` by default\n   * @param targetTopValue Scroll to `top`, 0 by default\n   * @param easing Transition curve, `easeInOutCubic` by default\n   * @param callback callback invoked when transition is done\n   */\n  scrollTo(containerEl: Element | Window, targetTopValue: number = 0, easing?: EasyingFn, callback?: () => void): void {\n    const target = containerEl ? containerEl : window;\n    const scrollTop = this.getScroll(target);\n    const startTime = Date.now();\n    const frameFunc = () => {\n      const timestamp = Date.now();\n      const time = timestamp - startTime;\n      this.setScrollTop(target, (easing || easeInOutCubic)(time, scrollTop, targetTopValue, 450));\n      if (time < 450) {\n        reqAnimFrame(frameFunc);\n      } else {\n        if (callback) {\n          callback();\n        }\n      }\n    };\n    reqAnimFrame(frameFunc);\n  }\n}\n\nexport function SCROLL_SERVICE_PROVIDER_FACTORY(doc: Document, scrollService: NzScrollService): NzScrollService {\n  return scrollService || new NzScrollService(doc);\n}\n\nexport const SCROLL_SERVICE_PROVIDER: Provider = {\n  provide: NzScrollService,\n  useFactory: SCROLL_SERVICE_PROVIDER_FACTORY,\n  deps: [DOCUMENT, [new Optional(), new SkipSelf(), NzScrollService]]\n};\n"]}