@ohayojp.com/components
Version:
Common business components of ohayojp.
300 lines • 21.5 kB
JavaScript
/**
* @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"]}