ngx-typed-js-aot
Version:
An Angular integration for [Typed.js](https://github.com/mattboldt/typed.js/).
217 lines • 19.3 kB
JavaScript
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"]}