UNPKG

ngx-typed-js-aot

Version:

An Angular integration for [Typed.js](https://github.com/mattboldt/typed.js/).

217 lines 19.3 kB
import { __decorate, __metadata } from "tslib"; import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core'; import Typed from 'typed.js'; let NgxTypedJsComponent = class NgxTypedJsComponent { constructor() { this.completed = new EventEmitter(); this.preStringTyped = new EventEmitter(); this.stringTyped = new EventEmitter(); this.lastStringBackspaced = new EventEmitter(); this.typingPaused = new EventEmitter(); this.typingResumed = new EventEmitter(); this.reset = new EventEmitter(); this.stopped = new EventEmitter(); this.started = new EventEmitter(); this.destroyed = new EventEmitter(); } ngAfterViewInit() { this.typed = new Typed(this.content.nativeElement.querySelector('.typing'), this.options); if (this.showCursor !== false) { this.updateCursorStyle(); } } toggle() { this.typed.toggle(); } stop() { this.typed.stop(); } start() { this.typed.start(); } destroy() { this.typed.destroy(); } doReset(restart) { this.typed.reset(restart); } get options() { const emit = (emitter) => () => emitter.emit(); const emitIndex = (emitter) => (index) => emitter.emit(index); const opts = { strings: this.strings, stringsElement: this.stringsElement, typeSpeed: this.typeSpeed, startDelay: this.startDelay, backSpeed: this.backSpeed, smartBackspace: this.smartBackspace, shuffle: this.shuffle, backDelay: this.backDelay, fadeOut: this.fadeOut, fadeOutClass: this.fadeOutClass, fadeOutDelay: this.fadeOutDelay, loop: this.loop, loopCount: this.loopCount, showCursor: this.showCursor, autoInsertCss: this.autoInsertCss, attr: this.attr, bindInputFocusEvents: this.bindInputFocusEvents, contentType: this.contentType, onComplete: emit(this.completed), preStringTyped: emitIndex(this.preStringTyped), onStringTyped: emitIndex(this.stringTyped), onLastStringBackspaced: emit(this.lastStringBackspaced), onTypingPaused: emitIndex(this.typingPaused), onTypingResumed: emitIndex(this.typingResumed), onReset: emit(this.reset), onStop: emitIndex(this.stopped), onStart: emitIndex(this.started), onDestroy: emit(this.destroyed), }; Object.keys(opts).forEach(key => { if (opts[key] === undefined) { delete opts[key]; } }); return opts; } updateCursorStyle() { const textElementStyle = getComputedStyle(this.content.nativeElement.querySelector('.typing')); const cursorElementStyle = this.content.nativeElement.querySelector('.typed-cursor').style; cursorElementStyle.fontSize = textElementStyle.fontSize; cursorElementStyle.color = this.cursorColor || textElementStyle.color; } }; __decorate([ Input(), __metadata("design:type", String) ], NgxTypedJsComponent.prototype, "cursorColor", void 0); __decorate([ Input(), __metadata("design:type", Array) ], NgxTypedJsComponent.prototype, "strings", void 0); __decorate([ Input(), __metadata("design:type", String) ], NgxTypedJsComponent.prototype, "stringsElement", void 0); __decorate([ Input(), __metadata("design:type", Number) ], NgxTypedJsComponent.prototype, "typeSpeed", void 0); __decorate([ Input(), __metadata("design:type", Number) ], NgxTypedJsComponent.prototype, "startDelay", void 0); __decorate([ Input(), __metadata("design:type", Number) ], NgxTypedJsComponent.prototype, "backSpeed", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], NgxTypedJsComponent.prototype, "smartBackspace", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], NgxTypedJsComponent.prototype, "shuffle", void 0); __decorate([ Input(), __metadata("design:type", Number) ], NgxTypedJsComponent.prototype, "backDelay", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], NgxTypedJsComponent.prototype, "fadeOut", void 0); __decorate([ Input(), __metadata("design:type", String) ], NgxTypedJsComponent.prototype, "fadeOutClass", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], NgxTypedJsComponent.prototype, "fadeOutDelay", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], NgxTypedJsComponent.prototype, "loop", void 0); __decorate([ Input(), __metadata("design:type", Number) ], NgxTypedJsComponent.prototype, "loopCount", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], NgxTypedJsComponent.prototype, "showCursor", void 0); __decorate([ Input(), __metadata("design:type", String) ], NgxTypedJsComponent.prototype, "cursorChar", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], NgxTypedJsComponent.prototype, "autoInsertCss", void 0); __decorate([ Input(), __metadata("design:type", String) ], NgxTypedJsComponent.prototype, "attr", void 0); __decorate([ Input(), __metadata("design:type", Boolean) ], NgxTypedJsComponent.prototype, "bindInputFocusEvents", void 0); __decorate([ Input(), __metadata("design:type", String) ], NgxTypedJsComponent.prototype, "contentType", void 0); __decorate([ Output(), __metadata("design:type", EventEmitter) ], NgxTypedJsComponent.prototype, "completed", void 0); __decorate([ Output(), __metadata("design:type", EventEmitter) ], NgxTypedJsComponent.prototype, "preStringTyped", void 0); __decorate([ Output(), __metadata("design:type", EventEmitter) ], NgxTypedJsComponent.prototype, "stringTyped", void 0); __decorate([ Output(), __metadata("design:type", EventEmitter) ], NgxTypedJsComponent.prototype, "lastStringBackspaced", void 0); __decorate([ Output(), __metadata("design:type", EventEmitter) ], NgxTypedJsComponent.prototype, "typingPaused", void 0); __decorate([ Output(), __metadata("design:type", EventEmitter) ], NgxTypedJsComponent.prototype, "typingResumed", void 0); __decorate([ Output(), __metadata("design:type", EventEmitter) ], NgxTypedJsComponent.prototype, "reset", void 0); __decorate([ Output(), __metadata("design:type", EventEmitter) ], NgxTypedJsComponent.prototype, "stopped", void 0); __decorate([ Output(), __metadata("design:type", EventEmitter) ], NgxTypedJsComponent.prototype, "started", void 0); __decorate([ Output(), __metadata("design:type", EventEmitter) ], NgxTypedJsComponent.prototype, "destroyed", void 0); __decorate([ ViewChild('wrapper', { static: true }), __metadata("design:type", Object) ], NgxTypedJsComponent.prototype, "content", void 0); NgxTypedJsComponent = __decorate([ Component({ selector: 'ngx-typed-js', template: "<div #wrapper>\n <ng-content></ng-content>\n</div>\n", styles: [":host>>>.typing{display:inline}"] }) ], NgxTypedJsComponent); export { NgxTypedJsComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-typed-js.component.js","sourceRoot":"ng://ngx-typed-js-aot/","sources":["lib/ngx-typed-js.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, EventEmitter, Input, Output, ViewChild} from '@angular/core';\nimport Typed, {TypedOptions} from 'typed.js';\n\n@Component({\n  selector: 'ngx-typed-js',\n  templateUrl: 'ngx-typed-js.component.html',\n  styleUrls: ['ngx-typed-js.component.css']\n})\nexport class NgxTypedJsComponent implements AfterViewInit {\n  @Input() public cursorColor?: string;\n\n  @Input() public strings?: string[];\n  @Input() public stringsElement?: string;\n  @Input() public typeSpeed?: number;\n  @Input() public startDelay?: number;\n  @Input() public backSpeed?: number;\n  @Input() public smartBackspace?: boolean;\n  @Input() public shuffle?: boolean;\n  @Input() public backDelay?: number;\n  @Input() public fadeOut?: boolean;\n  @Input() public fadeOutClass?: string;\n  @Input() public fadeOutDelay?: boolean;\n  @Input() public loop?: boolean;\n  @Input() public loopCount?: number;\n  @Input() public showCursor?: boolean;\n  @Input() public cursorChar?: string;\n  @Input() public autoInsertCss?: boolean;\n  @Input() public attr?: string;\n  @Input() public bindInputFocusEvents?: boolean;\n  @Input() public contentType?: string;\n\n  @Output() public completed: EventEmitter<void> = new EventEmitter<void>();\n  @Output() public preStringTyped: EventEmitter<number> = new EventEmitter<number>();\n  @Output() public stringTyped: EventEmitter<number> = new EventEmitter<number>();\n  @Output() public lastStringBackspaced: EventEmitter<void> = new EventEmitter<void>();\n  @Output() public typingPaused: EventEmitter<number> = new EventEmitter<number>();\n  @Output() public typingResumed: EventEmitter<number> = new EventEmitter<number>();\n  @Output() public reset: EventEmitter<void> = new EventEmitter<void>();\n  @Output() public stopped: EventEmitter<number> = new EventEmitter<number>();\n  @Output() public started: EventEmitter<number> = new EventEmitter<number>();\n  @Output() public destroyed: EventEmitter<void> = new EventEmitter<void>();\n\n  private typed: Typed;\n  @ViewChild('wrapper', { static: true }) private content;\n\n  ngAfterViewInit(): void {\n    this.typed = new Typed(\n      this.content.nativeElement.querySelector('.typing'),\n      this.options,\n    );\n\n    if (this.showCursor !== false) {\n      this.updateCursorStyle();\n    }\n  }\n\n  public toggle(): void {\n    this.typed.toggle();\n  }\n\n  public stop(): void {\n    this.typed.stop();\n  }\n\n  public start(): void {\n    this.typed.start();\n  }\n\n  public destroy(): void {\n    this.typed.destroy();\n  }\n\n  public doReset(restart?: boolean): void {\n    this.typed.reset(restart);\n  }\n\n  private get options(): TypedOptions {\n    const emit: (emitter: EventEmitter<void>) => (self: Typed) => void\n      = (emitter: EventEmitter<void>) => () => emitter.emit();\n\n    const emitIndex: (emitter: EventEmitter<number>) => (index: number, self: Typed) => void\n      = (emitter: EventEmitter<number>) => (index: number) => emitter.emit(index);\n\n    const opts = {\n      strings: this.strings,\n      stringsElement: this.stringsElement,\n      typeSpeed: this.typeSpeed,\n      startDelay: this.startDelay,\n      backSpeed: this.backSpeed,\n      smartBackspace: this.smartBackspace,\n      shuffle: this.shuffle,\n      backDelay: this.backDelay,\n      fadeOut: this.fadeOut,\n      fadeOutClass: this.fadeOutClass,\n      fadeOutDelay: this.fadeOutDelay,\n      loop: this.loop,\n      loopCount: this.loopCount,\n      showCursor: this.showCursor,\n      autoInsertCss: this.autoInsertCss,\n      attr: this.attr,\n      bindInputFocusEvents: this.bindInputFocusEvents,\n      contentType: this.contentType,\n      onComplete: emit(this.completed),\n      preStringTyped: emitIndex(this.preStringTyped),\n      onStringTyped: emitIndex(this.stringTyped),\n      onLastStringBackspaced: emit(this.lastStringBackspaced),\n      onTypingPaused: emitIndex(this.typingPaused),\n      onTypingResumed: emitIndex(this.typingResumed),\n      onReset: emit(this.reset),\n      onStop: emitIndex(this.stopped),\n      onStart: emitIndex(this.started),\n      onDestroy: emit(this.destroyed),\n    } as TypedOptions;\n\n    Object.keys(opts).forEach(key => {\n      if (opts[key] === undefined) {\n        delete opts[key];\n      }\n    });\n\n    return opts;\n  }\n\n  private updateCursorStyle(): void {\n    const textElementStyle = getComputedStyle(this.content.nativeElement.querySelector('.typing'));\n    const cursorElementStyle = this.content.nativeElement.querySelector('.typed-cursor').style;\n\n    cursorElementStyle.fontSize = textElementStyle.fontSize;\n    cursorElementStyle.color = this.cursorColor || textElementStyle.color;\n  }\n}\n"]}