UNPKG

@ohayojp.com/components

Version:

Common business components of ohayojp.

300 lines 21.5 kB
/** * @fileoverview added by tsickle * Generated from: onboarding.service.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { DOCUMENT } from '@angular/common'; import { ApplicationRef, ComponentFactoryResolver, Inject, Injectable, Injector, } from '@angular/core'; import { Router } from '@angular/router'; import { OhayoLocaleService } from '@ohayojp.com/theme'; import { of, pipe } from 'rxjs'; import { delay, switchMap } from 'rxjs/operators'; import { OnboardingComponent } from './onboarding.component'; import * as i0 from "@angular/core"; import * as i1 from "@ohayojp.com/theme"; import * as i2 from "@angular/router"; import * as i3 from "@angular/common"; export class OnboardingService { /** * @param {?} i18n * @param {?} appRef * @param {?} resolver * @param {?} router * @param {?} injector * @param {?} doc */ constructor(i18n, appRef, resolver, router, injector, doc) { this.i18n = i18n; this.appRef = appRef; this.resolver = resolver; this.router = router; this.injector = injector; this.doc = doc; this.active = 0; this.running$ = null; this._running = false; this.type = null; } /** * @private * @return {?} */ _getDoc() { return this.doc; } /** * @return {?} */ get running() { return this._running; } /** * @private * @return {?} */ attach() { /** @type {?} */ const compRef = (this.compRef = this.resolver.resolveComponentFactory(OnboardingComponent).create(this.injector)); this.appRef.attachView(compRef.hostView); /** @type {?} */ const compNode = ((/** @type {?} */ (compRef.hostView))).rootNodes[0]; /** @type {?} */ const doc = this._getDoc(); /** @type {?} */ const cdk = (/** @type {?} */ (doc.querySelector('.cdk-overlay-container'))); if (cdk) { doc.body.insertBefore(compNode, cdk); } else { doc.body.appendChild(compNode); } this.op$ = this.compRef.instance.op.subscribe((/** * @param {?} type * @return {?} */ (type) => { switch (type) { case 'next': this.next(); break; case 'prev': this.prev(); break; default: this.done(); break; } })); } /** * @private * @template THIS * @this {THIS} * @return {THIS} */ cancelRunning() { if ((/** @type {?} */ (this)).running$) { (/** @type {?} */ (this)).running$.unsubscribe(); (/** @type {?} */ (this)).running$ = null; } return (/** @type {?} */ (this)); } /** * @private * @template THIS * @this {THIS} * @param {?} status * @return {THIS} */ updateRunning(status) { (/** @type {?} */ (this))._running = status; (/** @type {?} */ ((/** @type {?} */ (this)).compRef)).instance.updateRunning(status); return (/** @type {?} */ (this)); } /** * @private * @return {?} */ destroy() { this.cancelRunning(); if (this.compRef) { this.appRef.detachView(this.compRef.hostView); this.compRef.destroy(); this.op$.unsubscribe(); } } /** * @private * @param {?=} isStart * @return {?} */ showItem(isStart = false) { /** @type {?} */ const items = (/** @type {?} */ (this.config.items)); /** @type {?} */ const item = (/** @type {?} */ (Object.assign(Object.assign({ position: 'bottomLeft', before: of(true), after: of(true) }, this.i18n.getData('onboarding')), items[this.active]))); Object.assign(this.compRef.instance, { item, config: this.config, active: this.active, max: items.length }); /** @type {?} */ const pipes = [ switchMap((/** * @return {?} */ () => (item.url ? this.router.navigateByUrl(item.url) : of(true)))), switchMap((/** * @return {?} */ () => { /** @type {?} */ const obs = this.type === 'prev' ? (/** @type {?} */ (item.after)) : (/** @type {?} */ (item.before)); return typeof obs === 'number' ? of(true).pipe(delay(obs)) : obs; })), ]; if (!isStart) { pipes.push(delay(1)); } this.updateRunning(true); this.running$ = of(true) .pipe(pipe.apply(this, pipes)) .subscribe((/** * @template THIS * @this {THIS} * @return {THIS} */ () => this.cancelRunning().updateRunning(false)), (/** * @return {?} */ () => this.done())); } /** * @param {?} config * @return {?} */ start(config) { if (this.running) { return; } this.destroy(); this.config = Object.assign({ items: [], mask: true, maskClosable: true, showTotal: false }, config); this.active = 0; this.type = null; this.attach(); this.showItem(true); } /** * @return {?} */ next() { if (this._running || this.active + 1 >= (/** @type {?} */ (this.config.items)).length) { this.done(); return; } this.type = 'next'; ++this.active; this.showItem(); } /** * @return {?} */ prev() { if (this._running || this.active - 1 < 0) { return; } this.type = 'prev'; --this.active; this.showItem(); } /** * @return {?} */ done() { this.type = 'done'; this.destroy(); } /** * @return {?} */ ngOnDestroy() { this.destroy(); } } OnboardingService.decorators = [ { type: Injectable, args: [{ providedIn: 'root' },] } ]; /** @nocollapse */ OnboardingService.ctorParameters = () => [ { type: OhayoLocaleService }, { type: ApplicationRef }, { type: ComponentFactoryResolver }, { type: Router }, { type: Injector }, { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] } ]; /** @nocollapse */ OnboardingService.ɵprov = i0.ɵɵdefineInjectable({ factory: function OnboardingService_Factory() { return new OnboardingService(i0.ɵɵinject(i1.OhayoLocaleService), i0.ɵɵinject(i0.ApplicationRef), i0.ɵɵinject(i0.ComponentFactoryResolver), i0.ɵɵinject(i2.Router), i0.ɵɵinject(i0.INJECTOR), i0.ɵɵinject(i3.DOCUMENT)); }, token: OnboardingService, providedIn: "root" }); if (false) { /** * @type {?} * @private */ OnboardingService.prototype.compRef; /** * @type {?} * @private */ OnboardingService.prototype.op$; /** * @type {?} * @private */ OnboardingService.prototype.config; /** * @type {?} * @private */ OnboardingService.prototype.active; /** * @type {?} * @private */ OnboardingService.prototype.running$; /** * @type {?} * @private */ OnboardingService.prototype._running; /** * @type {?} * @private */ OnboardingService.prototype.type; /** * @type {?} * @private */ OnboardingService.prototype.i18n; /** * @type {?} * @private */ OnboardingService.prototype.appRef; /** * @type {?} * @private */ OnboardingService.prototype.resolver; /** * @type {?} * @private */ OnboardingService.prototype.router; /** * @type {?} * @private */ OnboardingService.prototype.injector; /** * @type {?} * @private */ OnboardingService.prototype.doc; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onboarding.service.js","sourceRoot":"C:/android/@ohayojp/packages/components/onboarding/","sources":["onboarding.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n  ApplicationRef,\n  ComponentFactoryResolver,\n  ComponentRef,\n  EmbeddedViewRef,\n  Inject,\n  Injectable,\n  Injector,\n  OnDestroy,\n} from '@angular/core';\nimport { Router } from '@angular/router';\nimport { OhayoLocaleService } from '@ohayo/theme';\nimport { of, pipe, Subscription } from 'rxjs';\nimport { delay, switchMap } from 'rxjs/operators';\nimport { OnboardingComponent } from './onboarding.component';\nimport { OnboardingConfig, OnboardingItem, OnboardingOpType } from './onboarding.types';\n\n@Injectable({ providedIn: 'root' })\nexport class OnboardingService implements OnDestroy {\n  private compRef: ComponentRef<OnboardingComponent>;\n  private op$: Subscription;\n  private config: OnboardingConfig;\n  private active = 0;\n  private running$: Subscription | null = null;\n  private _running = false;\n  private type: OnboardingOpType | null = null;\n\n  private _getDoc(): Document {\n    return this.doc;\n  }\n\n  get running(): boolean {\n    return this._running;\n  }\n\n  constructor(\n    private i18n: OhayoLocaleService,\n    private appRef: ApplicationRef,\n    private resolver: ComponentFactoryResolver,\n    private router: Router,\n    private injector: Injector,\n    @Inject(DOCUMENT) private doc: any,\n  ) { }\n\n  private attach(): void {\n    const compRef = (this.compRef = this.resolver.resolveComponentFactory(OnboardingComponent).create(this.injector));\n    this.appRef.attachView(compRef.hostView);\n    const compNode = (compRef.hostView as EmbeddedViewRef<any>).rootNodes[0];\n    const doc = this._getDoc();\n    const cdk = doc.querySelector('.cdk-overlay-container') as HTMLElement;\n    if (cdk) {\n      doc.body.insertBefore(compNode, cdk);\n    } else {\n      doc.body.appendChild(compNode);\n    }\n    this.op$ = this.compRef.instance.op.subscribe((type: OnboardingOpType) => {\n      switch (type) {\n        case 'next':\n          this.next();\n          break;\n        case 'prev':\n          this.prev();\n          break;\n        default:\n          this.done();\n          break;\n      }\n    });\n  }\n\n  private cancelRunning(): this {\n    if (this.running$) {\n      this.running$.unsubscribe();\n      this.running$ = null;\n    }\n    return this;\n  }\n\n  private updateRunning(status: boolean): this {\n    this._running = status;\n    this.compRef!.instance.updateRunning(status);\n    return this;\n  }\n\n  private destroy(): void {\n    this.cancelRunning();\n    if (this.compRef) {\n      this.appRef.detachView(this.compRef.hostView);\n      this.compRef.destroy();\n      this.op$.unsubscribe();\n    }\n  }\n\n  private showItem(isStart: boolean = false): void {\n    const items = this.config.items!;\n    const item = {\n      position: 'bottomLeft',\n      before: of(true),\n      after: of(true),\n      ...this.i18n.getData('onboarding'),\n      ...items[this.active],\n    } as OnboardingItem;\n    Object.assign(this.compRef.instance, { item, config: this.config, active: this.active, max: items.length });\n    const pipes = [\n      switchMap(() => (item.url ? this.router.navigateByUrl(item.url) : of(true))),\n      switchMap(() => {\n        const obs = this.type === 'prev' ? item.after! : item.before!;\n        return typeof obs === 'number' ? of(true).pipe(delay(obs)) : obs;\n      }),\n    ];\n    if (!isStart) {\n      pipes.push(delay(1));\n    }\n\n    this.updateRunning(true);\n\n    this.running$ = of(true)\n      .pipe(pipe.apply(this, pipes))\n      .subscribe(\n        () => this.cancelRunning().updateRunning(false),\n        () => this.done(),\n      );\n  }\n\n  start(config: OnboardingConfig): void {\n    if (this.running) {\n      return;\n    }\n    this.destroy();\n    this.config = {\n      items: [],\n      mask: true,\n      maskClosable: true,\n      showTotal: false,\n      ...config,\n    };\n    this.active = 0;\n    this.type = null;\n    this.attach();\n    this.showItem(true);\n  }\n\n  next(): void {\n    if (this._running || this.active + 1 >= this.config.items!.length) {\n      this.done();\n      return;\n    }\n    this.type = 'next';\n    ++this.active;\n    this.showItem();\n  }\n\n  prev(): void {\n    if (this._running || this.active - 1 < 0) {\n      return;\n    }\n    this.type = 'prev';\n    --this.active;\n    this.showItem();\n  }\n\n  done(): void {\n    this.type = 'done';\n    this.destroy();\n  }\n\n  ngOnDestroy(): void {\n    this.destroy();\n  }\n}\n"]}