UNPKG

ng-zorro-antd-mobile

Version:

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

109 lines 17.3 kB
import { Component, Input, Output, EventEmitter } from '@angular/core'; import { IconHandler } from 'ng-zorro-antd-mobile/core'; import { deleteKeyFrame, getTextWidth, getWidthHeight, insertKeyFrame } from './util'; import * as i0 from "@angular/core"; import * as i1 from "ng-zorro-antd-mobile/core"; import * as i2 from "ng-zorro-antd-mobile/icon"; import * as i3 from "@angular/common"; export class NoticeBarComponent { get option() { return this._option; } set option(value) { Object.assign(this._option, value); this.dataProcess(); if (this._option.scrolling) { this.marqueeScroll = 'scrolling'; } else { this.marqueeScroll = 'scrolling-stop'; } } 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(); } click() { this.onClick.emit(this._option.mode); if (this._option.mode === 'closable') { this.visiable = false; } } dataProcess() { this.visiable = true; this.style = { width: '200%' }; this._width = getTextWidth(this._option.content, this._option.fontSize); if (getWidthHeight().width < this._width) { const count = this._option.marqueeProps.loop ? 'infinite' : 1; 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) / getWidthHeight().width) * 1000}s`, 'animation-iteration-count': `${count}` }; this.marqueeScroll = 'scrolling'; this.insetKeyframe(animationName); } else { this.marqueeScroll = 'scrolling-stop'; } } insetKeyframe(animationName) { insertKeyFrame(`@keyframes ${animationName} { 0% { left: 0px; } 100% { left: -${this._width}px } }`, 'notice_bar_animation_cls'); insertKeyFrame(`@-webkit-keyframes ${animationName} { 0% { left: 0px; } 100% { left: -${this._width}px } }`, 'notice_bar_animation_cls'); insertKeyFrame(`@-moz-keyframes ${animationName} { 0% { left: 0px; } 100% { left: -${this._width}px } }`, 'notice_bar_animation_cls'); insertKeyFrame(`@-o-keyframes ${animationName} { 0% { left: 0px; } 100% { left: -${this._width}px } }`, 'notice_bar_animation_cls'); } ngOnInit() { document.addEventListener('touchstart', () => { this.marqueeScroll = 'scrolling-stop'; }); document.addEventListener('touchend', () => { this.marqueeScroll = 'scrolling'; }); } ngOnDestroy() { deleteKeyFrame('notice_bar_animation_cls'); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: NoticeBarComponent, deps: [{ token: i1.IconHandler }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: NoticeBarComponent, selector: "NoticeBar, nzm-notice-bar", inputs: { option: "option" }, outputs: { onClick: "onClick" }, providers: [IconHandler], ngImport: i0, 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", dependencies: [{ kind: "component", type: i2.IconComponent, selector: "Icon, nzm-icon", inputs: ["color", "type", "src", "size"] }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: NoticeBarComponent, decorators: [{ type: Component, args: [{ selector: 'NoticeBar, nzm-notice-bar', providers: [IconHandler], 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" }] }], ctorParameters: () => [{ type: i1.IconHandler }], propDecorators: { option: [{ type: Input }], onClick: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notice-bar.component.js","sourceRoot":"","sources":["../../../components/notice-bar/notice-bar.component.ts","../../../components/notice-bar/notice-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, OnDestroy } from '@angular/core';\nimport { IconHandler } from 'ng-zorro-antd-mobile/core';\nimport { deleteKeyFrame, getTextWidth, getWidthHeight, insertKeyFrame } from './util';\n\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 = getTextWidth(this._option.content, this._option.fontSize);\n    if (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) / 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    insertKeyFrame(\n      `@keyframes ${animationName} {\n      0% { left: 0px; }\n      100% { left: -${this._width}px }\n    }`,\n      'notice_bar_animation_cls'\n    );\n    insertKeyFrame(\n      `@-webkit-keyframes ${animationName} {\n      0% { left: 0px; }\n      100% { left: -${this._width}px }\n    }`,\n      'notice_bar_animation_cls'\n    );\n    insertKeyFrame(\n      `@-moz-keyframes ${animationName} {\n      0% { left: 0px; }\n      100% { left: -${this._width}px }\n    }`,\n      'notice_bar_animation_cls'\n    );\n    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    deleteKeyFrame('notice_bar_animation_cls');\n  }\n}\n","<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"]}