UNPKG

ng-zorro-antd-mobile

Version:

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

459 lines 40.1 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ViewEncapsulation, Input, HostBinding, Output, EventEmitter, ElementRef } from '@angular/core'; export class DrawerComponent { /** * @param {?} _el */ constructor(_el) { this._el = _el; this.prefixCls = 'am-drawer'; this.sidebarStyleFinal = {}; this.contentStyleFinal = {}; this.overlayStyleFinal = {}; this.sidebarWidth = 0; this.sidebarHeight = 0; this.sidebarTop = 0; this.dragHandleTop = 0; this.touchIdentifier = null; this.touchStartX = null; this.touchStartY = null; this.touchCurrentX = null; this.touchCurrentY = null; this.touchSupported = typeof window === 'object' && 'ontouchstart' in window; this._docked = false; this._open = false; this._position = 'left'; this.sidebarStyle = {}; this.contentStyle = {}; this.overlayStyle = {}; this.dragHandleStyle = {}; this.transitions = true; this.touch = true; this.enableDragHandle = false; this.dragToggleDistance = 30; this.onOpenChange = new EventEmitter(); this.am = true; this.left = this._position === 'left'; this.right = this._position === 'right'; this.top = this._position == 'top'; this.bottom = this._position == 'bottom'; this.dockedCls = this._docked; this.openCls = this._open; } /** * @return {?} */ get docked() { return this._docked; } /** * @param {?} v * @return {?} */ set docked(v) { this._docked = v; this.dockedCls = v; } /** * @return {?} */ get open() { return this._open; } /** * @param {?} v * @return {?} */ set open(v) { this._open = v; this.openCls = v; } /** * @param {?} v * @return {?} */ set position(v) { this._position = v; this.right = false; this.left = false; this.top = false; this.bottom = false; switch (v) { case 'right': this.right = true; break; case 'left': this.left = true; break; case 'top': this.top = true; break; case 'bottom': this.bottom = true; break; } } /** * @return {?} */ onOverlayClicked() { if (this._open) { this.onOpenChange.emit(true); } } /** * @return {?} */ isTouching() { return this.touchIdentifier !== null; } /** * @param {?} event * @return {?} */ onTouchStart(event) { /** @type {?} */ const touch = event.changedTouches[0]; this.touchIdentifier = touch.identifier; this.touchStartX = touch.clientX; this.touchStartY = touch.clientY; this.touchCurrentX = touch.clientX; this.touchCurrentY = touch.clientY; } /** * @param {?} ev * @return {?} */ onTouchMove(ev) { for (let ind = 0; ind < ev.changedTouches.length; ind++) { if (ev.changedTouches[ind].identifier === this.touchIdentifier) { this.touchCurrentX = ev.changedTouches[ind].clientX; this.touchCurrentY = ev.changedTouches[ind].clientY; break; } } this.update(); } /** * @return {?} */ onTouchEnd() { /** @type {?} */ const touchWidth = this.touchSidebarWidth(); if (!this._open && touchWidth > this.dragToggleDistance) { this.onOpenChange.emit(!this._open); } /** @type {?} */ const touchHeight = this.touchSidebarHeight(); if (!this._open && touchHeight > this.dragToggleDistance) { this.onOpenChange.emit(!this._open); } this.touchIdentifier = null; this.touchStartX = null; this.touchStartY = null; this.touchCurrentX = null; this.touchCurrentY = null; this.update(); } /** * @return {?} */ saveSidebarSize() { /** @type {?} */ const sidebar = this._el.nativeElement.querySelector('#sidebar'); /** @type {?} */ const dragHandle = this._el.nativeElement.querySelector('#dragHandle'); /** @type {?} */ const width = sidebar.offsetWidth; /** @type {?} */ const height = sidebar.offsetHeight; /** @type {?} */ const sidebarTop = this.getOffset(sidebar).top; /** @type {?} */ const dragHandleTop = this.getOffset(dragHandle).top; if (width !== this.sidebarWidth) { this.sidebarWidth = width; } if (height !== this.sidebarHeight) { this.sidebarHeight = height; } if (sidebarTop !== this.sidebarTop) { this.sidebarTop = sidebarTop; } if (dragHandleTop !== this.dragHandleTop) { this.dragHandleTop = dragHandleTop; } } /** * @return {?} */ touchSidebarWidth() { if (this._position === 'right') { return Math.min(window.innerWidth - this.touchCurrentX, this.sidebarWidth); } if (this._position === 'left') { return Math.min(this.touchCurrentX, this.sidebarWidth); } } /** * @return {?} */ touchSidebarHeight() { if (this._position === 'bottom') { return Math.min(this._el.nativeElement.offsetHeight - this.touchCurrentY + this._el.nativeElement.offsetTop, this.sidebarHeight); } if (this._position === 'top') { return Math.min(this.touchCurrentY - this.dragHandleTop, this.sidebarHeight); } } /** * @param {?} __0 * @return {?} */ renderStyle({ sidebarStyle, isTouching, overlayStyle, contentStyle }) { if (this._position === 'right' || this._position === 'left') { sidebarStyle.transform = `translateX(0%)`; sidebarStyle.WebkitTransform = `translateX(0%)`; if (isTouching) { /** @type {?} */ const percentage = this.touchSidebarWidth() / this.sidebarWidth; // slide open to what we dragged if (this._position === 'right') { sidebarStyle.transform = `translateX(${(1 - percentage) * 100}%)`; sidebarStyle.WebkitTransform = `translateX(${(1 - percentage) * 100}%)`; } if (this._position === 'left') { sidebarStyle.transform = `translateX(-${(1 - percentage) * 100}%)`; sidebarStyle.WebkitTransform = `translateX(-${(1 - percentage) * 100}%)`; } overlayStyle.opacity = percentage; overlayStyle.visibility = 'visible'; } if (contentStyle) { contentStyle[this._position] = `${this.sidebarWidth}px`; } } if (this._position === 'top' || this._position === 'bottom') { sidebarStyle.transform = `translateY(0%)`; sidebarStyle.WebkitTransform = `translateY(0%)`; if (isTouching) { /** @type {?} */ const percentage = this.touchSidebarHeight() / this.sidebarHeight; if (this._position === 'bottom') { sidebarStyle.transform = `translateY(${(1 - percentage) * 100}%)`; sidebarStyle.WebkitTransform = `translateY(${(1 - percentage) * 100}%)`; } if (this._position === 'top') { sidebarStyle.transform = `translateY(-${(1 - percentage) * 100}%)`; sidebarStyle.WebkitTransform = `translateY(-${(1 - percentage) * 100}%)`; } overlayStyle.opacity = percentage; overlayStyle.visibility = 'visible'; } if (contentStyle) { contentStyle[this._position] = `${this.sidebarHeight}px`; } } } /** * @return {?} */ update() { /** @type {?} */ const sidebarStyle = Object.assign({}, this.sidebarStyle); /** @type {?} */ const contentStyle = Object.assign({}, this.contentStyle); /** @type {?} */ const overlayStyle = Object.assign({}, this.overlayStyle); if (this.isTouching()) { this.renderStyle({ sidebarStyle: sidebarStyle, isTouching: true, contentStyle: undefined, overlayStyle: overlayStyle }); } else if (this._docked) { this.dockedCls = true; this.renderStyle({ sidebarStyle: sidebarStyle, isTouching: undefined, contentStyle: contentStyle, overlayStyle: undefined }); } else if (this._open) { this.openCls = true; this.renderStyle({ sidebarStyle: sidebarStyle, isTouching: undefined, contentStyle: undefined, overlayStyle: undefined }); overlayStyle.opacity = 1; overlayStyle.visibility = 'visible'; } if (this.isTouching() || !this.transitions) { sidebarStyle.transition = 'none'; sidebarStyle.WebkitTransition = 'none'; contentStyle.transition = 'none'; overlayStyle.transition = 'none'; } this.sidebarStyleFinal = sidebarStyle; this.contentStyleFinal = contentStyle; this.overlayStyleFinal = overlayStyle; } /** * @param {?} ele * @return {?} */ getOffset(ele) { /** @type {?} */ let el = ele; /** @type {?} */ let _x = 0; /** @type {?} */ let _y = 0; while (el && !isNaN(el.offsetLeft) && !isNaN(el.offsetTop)) { _x += el.offsetLeft - el.scrollLeft; _y += el.offsetTop - el.scrollTop; el = el.offsetParent; } return { top: _y, left: _x }; } /** * @return {?} */ ngAfterViewChecked() { if (!this.isTouching()) { this.saveSidebarSize(); } } /** * @return {?} */ ngOnChanges() { this.update(); } } DrawerComponent.decorators = [ { type: Component, args: [{ selector: 'Drawer, nzm-drawer', template: "<div class=\"{{ prefixCls }}-sidebar\" [ngStyle]=\"sidebarStyleFinal\" id=\"sidebar\">\n <ng-template [ngTemplateOutlet]=\"sidebar\"></ng-template>\n</div>\n<div\n class=\"{{ prefixCls }}-overlay\"\n [ngStyle]=\"overlayStyleFinal\"\n role=\"presentation\"\n ref=\"overlay\"\n (click)=\"onOverlayClicked()\"\n></div>\n<div class=\"{{ prefixCls }}-content\" [ngStyle]=\"contentStyleFinal\" ref=\"content\">\n <div\n *ngIf=\"touch && touchSupported && !open && !docked && enableDragHandle\"\n id=\"dragHandle\"\n class=\"{{ prefixCls }}-draghandle\"\n [ngStyle]=\"dragHandleStyle\"\n (touchstart)=\"onTouchStart($event)\"\n (touchmove)=\"onTouchMove($event)\"\n (touchend)=\"onTouchEnd()\"\n (touchcancle)=\"onTouchEnd()\"\n ></div>\n <ng-content></ng-content>\n</div>\n", encapsulation: ViewEncapsulation.None }] } ]; /** @nocollapse */ DrawerComponent.ctorParameters = () => [ { type: ElementRef } ]; DrawerComponent.propDecorators = { sidebar: [{ type: Input }], sidebarStyle: [{ type: Input }], contentStyle: [{ type: Input }], overlayStyle: [{ type: Input }], dragHandleStyle: [{ type: Input }], transitions: [{ type: Input }], touch: [{ type: Input }], enableDragHandle: [{ type: Input }], dragToggleDistance: [{ type: Input }], docked: [{ type: Input }], open: [{ type: Input }], position: [{ type: Input }], onOpenChange: [{ type: Output }], am: [{ type: HostBinding, args: ['class.am-drawer',] }], left: [{ type: HostBinding, args: ['class.am-drawer-left',] }], right: [{ type: HostBinding, args: ['class.am-drawer-right',] }], top: [{ type: HostBinding, args: ['class.am-drawer-top',] }], bottom: [{ type: HostBinding, args: ['class.am-drawer-bottom',] }], dockedCls: [{ type: HostBinding, args: ['class.am-drawer-docked',] }], openCls: [{ type: HostBinding, args: ['class.am-drawer-open',] }] }; if (false) { /** @type {?} */ DrawerComponent.prototype.prefixCls; /** @type {?} */ DrawerComponent.prototype.sidebarStyleFinal; /** @type {?} */ DrawerComponent.prototype.contentStyleFinal; /** @type {?} */ DrawerComponent.prototype.overlayStyleFinal; /** @type {?} */ DrawerComponent.prototype.sidebarWidth; /** @type {?} */ DrawerComponent.prototype.sidebarHeight; /** @type {?} */ DrawerComponent.prototype.sidebarTop; /** @type {?} */ DrawerComponent.prototype.dragHandleTop; /** @type {?} */ DrawerComponent.prototype.touchIdentifier; /** @type {?} */ DrawerComponent.prototype.touchStartX; /** @type {?} */ DrawerComponent.prototype.touchStartY; /** @type {?} */ DrawerComponent.prototype.touchCurrentX; /** @type {?} */ DrawerComponent.prototype.touchCurrentY; /** @type {?} */ DrawerComponent.prototype.touchSupported; /** * @type {?} * @private */ DrawerComponent.prototype._docked; /** * @type {?} * @private */ DrawerComponent.prototype._open; /** * @type {?} * @private */ DrawerComponent.prototype._position; /** @type {?} */ DrawerComponent.prototype.sidebar; /** @type {?} */ DrawerComponent.prototype.sidebarStyle; /** @type {?} */ DrawerComponent.prototype.contentStyle; /** @type {?} */ DrawerComponent.prototype.overlayStyle; /** @type {?} */ DrawerComponent.prototype.dragHandleStyle; /** @type {?} */ DrawerComponent.prototype.transitions; /** @type {?} */ DrawerComponent.prototype.touch; /** @type {?} */ DrawerComponent.prototype.enableDragHandle; /** @type {?} */ DrawerComponent.prototype.dragToggleDistance; /** @type {?} */ DrawerComponent.prototype.onOpenChange; /** @type {?} */ DrawerComponent.prototype.am; /** @type {?} */ DrawerComponent.prototype.left; /** @type {?} */ DrawerComponent.prototype.right; /** @type {?} */ DrawerComponent.prototype.top; /** @type {?} */ DrawerComponent.prototype.bottom; /** @type {?} */ DrawerComponent.prototype.dockedCls; /** @type {?} */ DrawerComponent.prototype.openCls; /** * @type {?} * @private */ DrawerComponent.prototype._el; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["drawer/drawer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ViewEncapsulation,\n  Input,\n  HostBinding,\n  Output,\n  EventEmitter,\n  ElementRef,\n  OnChanges,\n  AfterViewChecked\n} from '@angular/core';\n\n@Component({\n  selector: 'Drawer, nzm-drawer',\n  templateUrl: './drawer.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class DrawerComponent implements AfterViewChecked, OnChanges {\n  prefixCls: string = 'am-drawer';\n  sidebarStyleFinal: { [k: string]: any } = {};\n  contentStyleFinal: { [k: string]: any } = {};\n  overlayStyleFinal: { [k: string]: any } = {};\n  sidebarWidth: number = 0;\n  sidebarHeight: number = 0;\n  sidebarTop: number = 0;\n  dragHandleTop: number = 0;\n  touchIdentifier: number = null;\n  touchStartX: number = null;\n  touchStartY: number = null;\n  touchCurrentX: number = null;\n  touchCurrentY: number = null;\n  touchSupported: boolean = typeof window === 'object' && 'ontouchstart' in window;\n\n  private _docked: boolean = false;\n  private _open: boolean = false;\n  private _position: string = 'left';\n\n  @Input()\n  sidebar: any;\n  @Input()\n  sidebarStyle: { [k: string]: any } = {};\n  @Input()\n  contentStyle: { [k: string]: any } = {};\n  @Input()\n  overlayStyle: { [k: string]: any } = {};\n  @Input()\n  dragHandleStyle: { [k: string]: any } = {};\n  @Input()\n  transitions: boolean = true;\n  @Input()\n  touch: boolean = true;\n  @Input()\n  enableDragHandle: boolean = false;\n  @Input()\n  dragToggleDistance: number = 30;\n  @Input()\n  get docked() {\n    return this._docked;\n  }\n  set docked(v) {\n    this._docked = v;\n    this.dockedCls = v;\n  }\n  @Input()\n  get open() {\n    return this._open;\n  }\n  set open(v) {\n    this._open = v;\n    this.openCls = v;\n  }\n  @Input()\n  set position(v) {\n    this._position = v;\n    this.right = false;\n    this.left = false;\n    this.top = false;\n    this.bottom = false;\n    switch (v) {\n      case 'right':\n        this.right = true;\n        break;\n      case 'left':\n        this.left = true;\n        break;\n      case 'top':\n        this.top = true;\n        break;\n      case 'bottom':\n        this.bottom = true;\n        break;\n    }\n  }\n  @Output()\n  onOpenChange: EventEmitter<any> = new EventEmitter<any>();\n\n  @HostBinding('class.am-drawer')\n  am: boolean = true;\n  @HostBinding('class.am-drawer-left')\n  left: boolean = this._position === 'left';\n  @HostBinding('class.am-drawer-right')\n  right: boolean = this._position === 'right';\n  @HostBinding('class.am-drawer-top')\n  top: boolean = this._position == 'top';\n  @HostBinding('class.am-drawer-bottom')\n  bottom: boolean = this._position == 'bottom';\n  @HostBinding('class.am-drawer-docked')\n  dockedCls: boolean = this._docked;\n  @HostBinding('class.am-drawer-open')\n  openCls: boolean = this._open;\n\n  constructor(private _el: ElementRef) {}\n\n  onOverlayClicked() {\n    if (this._open) {\n      this.onOpenChange.emit(true);\n    }\n  }\n\n  isTouching() {\n    return this.touchIdentifier !== null;\n  }\n\n  onTouchStart(event) {\n    const touch = event.changedTouches[0];\n    this.touchIdentifier = touch.identifier;\n    this.touchStartX = touch.clientX;\n    this.touchStartY = touch.clientY;\n    this.touchCurrentX = touch.clientX;\n    this.touchCurrentY = touch.clientY;\n  }\n\n  onTouchMove(ev) {\n    for (let ind = 0; ind < ev.changedTouches.length; ind++) {\n      if (ev.changedTouches[ind].identifier === this.touchIdentifier) {\n        this.touchCurrentX = ev.changedTouches[ind].clientX;\n        this.touchCurrentY = ev.changedTouches[ind].clientY;\n        break;\n      }\n    }\n    this.update();\n  }\n\n  onTouchEnd() {\n    const touchWidth = this.touchSidebarWidth();\n    if (!this._open && touchWidth > this.dragToggleDistance) {\n      this.onOpenChange.emit(!this._open);\n    }\n\n    const touchHeight = this.touchSidebarHeight();\n    if (!this._open && touchHeight > this.dragToggleDistance) {\n      this.onOpenChange.emit(!this._open);\n    }\n    this.touchIdentifier = null;\n    this.touchStartX = null;\n    this.touchStartY = null;\n    this.touchCurrentX = null;\n    this.touchCurrentY = null;\n    this.update();\n  }\n\n  saveSidebarSize() {\n    const sidebar = this._el.nativeElement.querySelector('#sidebar');\n    const dragHandle = this._el.nativeElement.querySelector('#dragHandle');\n\n    const width = sidebar.offsetWidth;\n    const height = sidebar.offsetHeight;\n    const sidebarTop = this.getOffset(sidebar).top;\n    const dragHandleTop = this.getOffset(dragHandle).top;\n\n    if (width !== this.sidebarWidth) {\n      this.sidebarWidth = width;\n    }\n    if (height !== this.sidebarHeight) {\n      this.sidebarHeight = height;\n    }\n    if (sidebarTop !== this.sidebarTop) {\n      this.sidebarTop = sidebarTop;\n    }\n    if (dragHandleTop !== this.dragHandleTop) {\n      this.dragHandleTop = dragHandleTop;\n    }\n  }\n\n  touchSidebarWidth() {\n    if (this._position === 'right') {\n      return Math.min(window.innerWidth - this.touchCurrentX, this.sidebarWidth);\n    }\n\n    if (this._position === 'left') {\n      return Math.min(this.touchCurrentX, this.sidebarWidth);\n    }\n  }\n\n  touchSidebarHeight() {\n    if (this._position === 'bottom') {\n      return Math.min(\n        this._el.nativeElement.offsetHeight - this.touchCurrentY + this._el.nativeElement.offsetTop,\n        this.sidebarHeight\n      );\n    }\n\n    if (this._position === 'top') {\n      return Math.min(this.touchCurrentY - this.dragHandleTop, this.sidebarHeight);\n    }\n  }\n\n  renderStyle({ sidebarStyle, isTouching, overlayStyle, contentStyle }) {\n    if (this._position === 'right' || this._position === 'left') {\n      sidebarStyle.transform = `translateX(0%)`;\n      sidebarStyle.WebkitTransform = `translateX(0%)`;\n      if (isTouching) {\n        const percentage = this.touchSidebarWidth() / this.sidebarWidth;\n        // slide open to what we dragged\n        if (this._position === 'right') {\n          sidebarStyle.transform = `translateX(${(1 - percentage) * 100}%)`;\n          sidebarStyle.WebkitTransform = `translateX(${(1 - percentage) * 100}%)`;\n        }\n        if (this._position === 'left') {\n          sidebarStyle.transform = `translateX(-${(1 - percentage) * 100}%)`;\n          sidebarStyle.WebkitTransform = `translateX(-${(1 - percentage) * 100}%)`;\n        }\n        overlayStyle.opacity = percentage;\n        overlayStyle.visibility = 'visible';\n      }\n      if (contentStyle) {\n        contentStyle[this._position] = `${this.sidebarWidth}px`;\n      }\n    }\n    if (this._position === 'top' || this._position === 'bottom') {\n      sidebarStyle.transform = `translateY(0%)`;\n      sidebarStyle.WebkitTransform = `translateY(0%)`;\n      if (isTouching) {\n        const percentage = this.touchSidebarHeight() / this.sidebarHeight;\n        if (this._position === 'bottom') {\n          sidebarStyle.transform = `translateY(${(1 - percentage) * 100}%)`;\n          sidebarStyle.WebkitTransform = `translateY(${(1 - percentage) * 100}%)`;\n        }\n        if (this._position === 'top') {\n          sidebarStyle.transform = `translateY(-${(1 - percentage) * 100}%)`;\n          sidebarStyle.WebkitTransform = `translateY(-${(1 - percentage) * 100}%)`;\n        }\n        overlayStyle.opacity = percentage;\n        overlayStyle.visibility = 'visible';\n      }\n      if (contentStyle) {\n        contentStyle[this._position] = `${this.sidebarHeight}px`;\n      }\n    }\n  }\n\n  update() {\n    const sidebarStyle = { ...this.sidebarStyle };\n    const contentStyle = { ...this.contentStyle };\n    const overlayStyle = { ...this.overlayStyle };\n\n    if (this.isTouching()) {\n      this.renderStyle({\n        sidebarStyle: sidebarStyle,\n        isTouching: true,\n        contentStyle: undefined,\n        overlayStyle: overlayStyle\n      });\n    } else if (this._docked) {\n      this.dockedCls = true;\n      this.renderStyle({\n        sidebarStyle: sidebarStyle,\n        isTouching: undefined,\n        contentStyle: contentStyle,\n        overlayStyle: undefined\n      });\n    } else if (this._open) {\n      this.openCls = true;\n      this.renderStyle({\n        sidebarStyle: sidebarStyle,\n        isTouching: undefined,\n        contentStyle: undefined,\n        overlayStyle: undefined\n      });\n      overlayStyle.opacity = 1;\n      overlayStyle.visibility = 'visible';\n    }\n\n    if (this.isTouching() || !this.transitions) {\n      sidebarStyle.transition = 'none';\n      sidebarStyle.WebkitTransition = 'none';\n      contentStyle.transition = 'none';\n      overlayStyle.transition = 'none';\n    }\n    this.sidebarStyleFinal = sidebarStyle;\n    this.contentStyleFinal = contentStyle;\n    this.overlayStyleFinal = overlayStyle;\n  }\n\n  getOffset(ele) {\n    let el = ele;\n    let _x = 0;\n    let _y = 0;\n    while (el && !isNaN(el.offsetLeft) && !isNaN(el.offsetTop)) {\n      _x += el.offsetLeft - el.scrollLeft;\n      _y += el.offsetTop - el.scrollTop;\n      el = el.offsetParent;\n    }\n    return { top: _y, left: _x };\n  }\n\n  ngAfterViewChecked() {\n    if (!this.isTouching()) {\n      this.saveSidebarSize();\n    }\n  }\n\n  ngOnChanges() {\n    this.update();\n  }\n}\n"]}