ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
173 lines • 14.7 kB
JavaScript
/**
* @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(` ${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"]}