UNPKG

ng-zorro-antd-mobile

Version:

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

173 lines 14.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, Output, EventEmitter } from '@angular/core'; import { IconHandler } from '../core/util/icon'; import * as util from './util'; export class NoticeBarComponent { /** * @param {?} _iconHandler */ constructor(_iconHandler) { this._iconHandler = _iconHandler; this.visiable = false; this.marqueeScroll = 'scrolling'; this.style = {}; this._option = { mode: '', icon: '', action: '', content: '', fontSize: '14px', scrolling: true, marqueeProps: { loop: true, leading: 500, trailing: 8000, fps: 200, style: {} } }; this.onClick = new EventEmitter(); this._iconHandler.load(); } /** * @return {?} */ get option() { return this._option; } /** * @param {?} value * @return {?} */ set option(value) { Object.assign(this._option, value); this.dataProcess(); if (this._option.scrolling) { this.marqueeScroll = 'scrolling'; } else { this.marqueeScroll = 'scrolling-stop'; } } /** * @return {?} */ click() { this.onClick.emit(this._option.mode); if (this._option.mode === 'closable') { this.visiable = false; } } /** * @return {?} */ dataProcess() { this.visiable = true; this.style = { width: '200%' }; this._width = util.getTextWidth(this._option.content, this._option.fontSize); if (util.getWidthHeight().width < this._width) { /** @type {?} */ const count = this._option.marqueeProps.loop ? 'infinite' : 1; /** @type {?} */ let animationName = `noticebarmarquee_${this._width}`; this.style = { width: this._width * 2 + 'px', 'animation-name': animationName, 'animation-delay': `${this._option.marqueeProps.leading}ms`, 'animation-duration': `${(((1 / this._option.marqueeProps.fps) * this._width) / util.getWidthHeight().width) * 1000}s`, 'animation-iteration-count': `${count}` }; this.marqueeScroll = 'scrolling'; this.insetKeyframe(animationName); } else { this.marqueeScroll = 'scrolling-stop'; } } /** * @param {?} animationName * @return {?} */ insetKeyframe(animationName) { util.insertKeyFrame(`@keyframes ${animationName} { 0% { left: 0px; } 100% { left: -${this._width}px } }`, 'notice_bar_animation_cls'); util.insertKeyFrame(`@-webkit-keyframes ${animationName} { 0% { left: 0px; } 100% { left: -${this._width}px } }`, 'notice_bar_animation_cls'); util.insertKeyFrame(`@-moz-keyframes ${animationName} { 0% { left: 0px; } 100% { left: -${this._width}px } }`, 'notice_bar_animation_cls'); util.insertKeyFrame(`@-o-keyframes ${animationName} { 0% { left: 0px; } 100% { left: -${this._width}px } }`, 'notice_bar_animation_cls'); } /** * @return {?} */ ngOnInit() { document.addEventListener('touchstart', (/** * @return {?} */ () => { this.marqueeScroll = 'scrolling-stop'; })); document.addEventListener('touchend', (/** * @return {?} */ () => { this.marqueeScroll = 'scrolling'; })); } /** * @return {?} */ ngOnDestroy() { util.deleteKeyFrame('notice_bar_animation_cls'); } } NoticeBarComponent.decorators = [ { type: Component, args: [{ selector: 'NoticeBar, nzm-notice-bar', template: "<div role=\"alert\" *ngIf=\"visiable\" class=\"am-notice-bar\" (click)=\"click()\">\n <div *ngIf=\"option.icon !== null\" class=\"am-notice-bar-icon\">\n <ng-template [ngTemplateOutlet]=\"option.icon || voice\"></ng-template>\n </div>\n <div class=\"am-notice-bar-content\">\n <div class=\"marquee\">\n <div [ngClass]=\"marqueeScroll\" [ngStyle]=\"style\">\n <span>{{ option.content }}</span>\n <span>{{ option.content }}</span>\n </div>\n </div>\n </div>\n <div role=\"button\" *ngIf=\"option.mode && option.action !== null\" class=\"am-notice-bar-operation\">\n <ng-template *ngIf=\"option.mode === 'closable'\" [ngTemplateOutlet]=\"option.action || cross\"></ng-template>\n <ng-template *ngIf=\"option.mode === 'link'\" [ngTemplateOutlet]=\"option.action || right\"></ng-template>\n </div>\n</div>\n\n<ng-template #voice>\n <Icon [type]=\"'voice'\" [size]=\"'xxs'\"></Icon>\n</ng-template>\n<ng-template #cross>\n <Icon [type]=\"'cross'\" [size]=\"'md'\"></Icon>\n</ng-template>\n<ng-template #right>\n <Icon [type]=\"'right'\" [size]=\"'md'\"></Icon>\n</ng-template>\n", providers: [IconHandler] }] } ]; /** @nocollapse */ NoticeBarComponent.ctorParameters = () => [ { type: IconHandler } ]; NoticeBarComponent.propDecorators = { option: [{ type: Input }], onClick: [{ type: Output }] }; if (false) { /** @type {?} */ NoticeBarComponent.prototype.visiable; /** @type {?} */ NoticeBarComponent.prototype.marqueeScroll; /** @type {?} */ NoticeBarComponent.prototype.style; /** * @type {?} * @private */ NoticeBarComponent.prototype._width; /** * @type {?} * @private */ NoticeBarComponent.prototype._option; /** @type {?} */ NoticeBarComponent.prototype.onClick; /** * @type {?} * @private */ NoticeBarComponent.prototype._iconHandler; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notice-bar.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["notice-bar/notice-bar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, OnDestroy } from '@angular/core';\nimport { IconHandler } from '../core/util/icon';\nimport * as util from './util';\n@Component({\n  selector: 'NoticeBar, nzm-notice-bar',\n  templateUrl: './notice-bar.component.html',\n  providers: [IconHandler]\n})\nexport class NoticeBarComponent implements OnInit, OnDestroy {\n  visiable = false;\n  marqueeScroll = 'scrolling';\n  style = {};\n  private _width;\n  private _option = {\n    mode: '',\n    icon: '',\n    action: '',\n    content: '',\n    fontSize: '14px',\n    scrolling: true,\n    marqueeProps: { loop: true, leading: 500, trailing: 8000, fps: 200, style: {} }\n  };\n  @Input()\n  get option() {\n    return this._option;\n  }\n  set option(value) {\n    Object.assign(this._option, value);\n    this.dataProcess();\n    if (this._option.scrolling) {\n      this.marqueeScroll = 'scrolling';\n    } else {\n      this.marqueeScroll = 'scrolling-stop';\n    }\n  }\n  @Output()\n  onClick: EventEmitter<any> = new EventEmitter();\n\n  constructor(private _iconHandler: IconHandler) {\n    this._iconHandler.load();\n  }\n\n  click() {\n    this.onClick.emit(this._option.mode);\n    if (this._option.mode === 'closable') {\n      this.visiable = false;\n    }\n  }\n\n  dataProcess() {\n    this.visiable = true;\n    this.style = {\n      width: '200%'\n    };\n    this._width = util.getTextWidth(this._option.content, this._option.fontSize);\n    if (util.getWidthHeight().width < this._width) {\n      const count = this._option.marqueeProps.loop ? 'infinite' : 1;\n      let animationName = `noticebarmarquee_${this._width}`;\n      this.style = {\n        width: this._width * 2 + 'px',\n        'animation-name': animationName,\n        'animation-delay': `${this._option.marqueeProps.leading}ms`,\n        'animation-duration': `${(((1 / this._option.marqueeProps.fps) * this._width) / util.getWidthHeight().width) *\n          1000}s`,\n        'animation-iteration-count': `${count}`\n      };\n      this.marqueeScroll = 'scrolling';\n      this.insetKeyframe(animationName);\n    } else {\n      this.marqueeScroll = 'scrolling-stop';\n    }\n  }\n\n  insetKeyframe(animationName) {\n    util.insertKeyFrame(\n      `@keyframes ${animationName} {\n      0% { left: 0px; }\n      100% { left: -${this._width}px }\n    }`,\n      'notice_bar_animation_cls'\n    );\n    util.insertKeyFrame(\n      `@-webkit-keyframes ${animationName} {\n      0% { left: 0px; }\n      100% { left: -${this._width}px }\n    }`,\n      'notice_bar_animation_cls'\n    );\n    util.insertKeyFrame(\n      `@-moz-keyframes ${animationName} {\n      0% { left: 0px; }\n      100% { left: -${this._width}px }\n    }`,\n      'notice_bar_animation_cls'\n    );\n    util.insertKeyFrame(\n      `@-o-keyframes ${animationName} {\n      0% { left: 0px; }\n      100% { left: -${this._width}px }\n    }`,\n      'notice_bar_animation_cls'\n    );\n  }\n\n  ngOnInit() {\n    document.addEventListener('touchstart', () => {\n      this.marqueeScroll = 'scrolling-stop';\n    });\n\n    document.addEventListener('touchend', () => {\n      this.marqueeScroll = 'scrolling';\n    });\n  }\n\n  ngOnDestroy() {\n    util.deleteKeyFrame('notice_bar_animation_cls');\n  }\n}\n"]}