UNPKG

@ohayojp.com/components

Version:

Common business components of ohayojp.

257 lines 20.2 kB
/** * @fileoverview added by tsickle * Generated from: onboarding.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Platform } from '@angular/cdk/platform'; import { DOCUMENT } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Inject, Optional, ViewEncapsulation, } from '@angular/core'; /** * @record */ function OnboardingLightData() { } if (false) { /** @type {?} */ OnboardingLightData.prototype.el; /** @type {?} */ OnboardingLightData.prototype.top; /** @type {?} */ OnboardingLightData.prototype.left; /** @type {?} */ OnboardingLightData.prototype.width; /** @type {?} */ OnboardingLightData.prototype.height; /** @type {?} */ OnboardingLightData.prototype.clientHeight; /** @type {?} */ OnboardingLightData.prototype.clientWidth; } export class OnboardingComponent { /** * @param {?} el * @param {?} doc * @param {?} platform * @param {?} cdr */ constructor(el, doc, platform, cdr) { this.el = el; this.doc = doc; this.platform = platform; this.cdr = cdr; this.active = 0; this.max = 0; this.op = new EventEmitter(); this.running = false; } /** * @return {?} */ get first() { return this.active === 0; } /** * @return {?} */ get last() { return this.active === this.max - 1; } /** * @private * @return {?} */ _getDoc() { return this.doc; } /** * @private * @return {?} */ _getWin() { return this._getDoc().defaultView || window; } /** * @private * @return {?} */ getLightData() { /** @type {?} */ const doc = this._getDoc(); /** @type {?} */ const win = this._getWin(); /** @type {?} */ const el = (/** @type {?} */ (doc.querySelector(this.item.selectors))); if (!el) { return null; } /** @type {?} */ const scrollTop = win.pageYOffset || doc.documentElement.scrollTop || doc.body.scrollTop; /** @type {?} */ const scrollLeft = win.pageXOffset || doc.documentElement.scrollLeft || doc.body.scrollLeft; /** @type {?} */ const rect = el.getBoundingClientRect(); /** @type {?} */ const top = rect.top + scrollTop; /** @type {?} */ const left = rect.left + scrollLeft; /** @type {?} */ const padding = 8; /** @type {?} */ const needPadding = top > padding && left > padding; /** @type {?} */ const offsetPos = needPadding ? padding : 0; /** @type {?} */ const offsetWH = needPadding ? padding * 2 : 0; return { top: top - offsetPos, left: left - offsetPos, width: rect.width + offsetWH, height: rect.height + offsetWH, el, clientWidth: doc.body.clientWidth, clientHeight: doc.body.clientHeight, }; } /** * @private * @param {?} pos * @return {?} */ scroll(pos) { this.prevSelectorEl = pos.el; /** @type {?} */ const scrollY = pos.top - (pos.clientHeight - pos.height) / 2; this._getWin().scrollTo({ top: scrollY }); this.updatePrevElStatus(true); } /** * @param {?} status * @return {?} */ updateRunning(status) { this.running = status; this.cdr.detectChanges(); if (!status) { this.updatePosition(); } } /** * @private * @return {?} */ updatePosition() { if (!this.platform.isBrowser) { return; } /** @type {?} */ const pos = this.getLightData(); if (pos == null) { console.warn(`Did not matches selectors [${this.item.selectors}]`); return; } /** @type {?} */ const lightStyle = ((/** @type {?} */ (this.el.nativeElement.querySelector('.onboarding__light')))).style; lightStyle.top = `${pos.top}px`; lightStyle.left = `${pos.left}px`; lightStyle.width = `${pos.width}px`; lightStyle.height = `${pos.height}px`; this.updatePrevElStatus(false); this.scroll(pos); } /** * @private * @param {?} status * @return {?} */ updatePrevElStatus(status) { if (this.prevSelectorEl) { this.prevSelectorEl.classList[status ? 'add' : 'remove']('onboarding__light-el'); } } /** * @param {?} type * @return {?} */ to(type) { this.op.emit(type); } /** * @return {?} */ handleMask() { if (this.config.maskClosable === true) { this.to('done'); } } /** * @return {?} */ ngOnDestroy() { clearTimeout(this.time); this.updatePrevElStatus(false); } } OnboardingComponent.decorators = [ { type: Component, args: [{ selector: 'onboarding', template: "<div *ngIf=\"!running && config.mask\" class=\"onboarding__mask\" (click)=\"handleMask()\"></div>\n<div\n *ngIf=\"item\"\n class=\"onboarding__light\"\n [class.onboarding__light-hide]=\"running\"\n [attr.style]=\"item.lightStyle\"\n nz-popover\n [nzPopoverTitle]=\"item.title\"\n [nzPopoverContent]=\"content\"\n [nzPopoverVisible]=\"!running\"\n [nzPopoverTrigger]=\"null\"\n [nzPopoverPlacement]=\"item.position\"\n [nzPopoverOverlayClassName]=\"item.className\"\n [nzPopoverOverlayStyle]=\"{ 'max-width.px': item.width }\"\n [nzNoAnimation]=\"true\"\n></div>\n<ng-template #content>\n <ng-container *nzStringTemplateOutlet=\"item.content\">\n <div [innerHTML]=\"item.content\"></div>\n </ng-container>\n <div class=\"flex-center-between onboarding__footer\">\n <span class=\"onboarding__total\">\n <ng-container *ngIf=\"config.showTotal\">{{ active + 1 }}/{{ max }}</ng-container>\n </span>\n <div class=\"onboarding__btns\">\n <a *ngIf=\"!last && item.skip !== null\" nz-button nzType=\"link\" (click)=\"to('skip')\" nzSize=\"small\" data-btnType=\"skip\">\n <ng-container *nzStringTemplateOutlet=\"item.skip\">{{ item.skip }}</ng-container>\n </a>\n <a *ngIf=\"!first && item.prev !== null\" nz-button (click)=\"to('prev')\" nzSize=\"small\" data-btnType=\"prev\">\n <ng-container *nzStringTemplateOutlet=\"item.prev\">{{ item.prev }}</ng-container>\n </a>\n <a *ngIf=\"!last && item.next !== null\" nz-button (click)=\"to('next')\" nzType=\"primary\" nzSize=\"small\" data-btnType=\"next\">\n <ng-container *nzStringTemplateOutlet=\"item.next\">{{ item.next }}</ng-container>\n </a>\n <a *ngIf=\"last && item.done !== null\" nz-button (click)=\"to('done')\" nzType=\"primary\" nzSize=\"small\" data-btnType=\"done\">\n <ng-container *nzStringTemplateOutlet=\"item.done\">{{ item.done }}</ng-container>\n </a>\n </div>\n </div>\n</ng-template>\n", host: { '[class.onboarding]': `true`, '[attr.data-onboarding-active]': `active`, }, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None }] } ]; /** @nocollapse */ OnboardingComponent.ctorParameters = () => [ { type: ElementRef }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DOCUMENT,] }] }, { type: Platform }, { type: ChangeDetectorRef } ]; if (false) { /** * @type {?} * @private */ OnboardingComponent.prototype.time; /** * @type {?} * @private */ OnboardingComponent.prototype.prevSelectorEl; /** @type {?} */ OnboardingComponent.prototype.config; /** @type {?} */ OnboardingComponent.prototype.item; /** @type {?} */ OnboardingComponent.prototype.active; /** @type {?} */ OnboardingComponent.prototype.max; /** @type {?} */ OnboardingComponent.prototype.op; /** @type {?} */ OnboardingComponent.prototype.running; /** * @type {?} * @private */ OnboardingComponent.prototype.el; /** * @type {?} * @private */ OnboardingComponent.prototype.doc; /** * @type {?} * @private */ OnboardingComponent.prototype.platform; /** * @type {?} * @private */ OnboardingComponent.prototype.cdr; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onboarding.component.js","sourceRoot":"C:/android/@ohayojp/packages/components/onboarding/","sources":["onboarding.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Platform } from '@angular/cdk/platform';\nimport { DOCUMENT } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  OnDestroy,\n  Optional,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { OnboardingConfig, OnboardingItem, OnboardingOpType } from './onboarding.types';\n\ninterface OnboardingLightData {\n  el: HTMLElement;\n  top: number;\n  left: number;\n  width: number;\n  height: number;\n  clientHeight: number;\n  clientWidth: number;\n}\n\n@Component({\n  selector: 'onboarding',\n  templateUrl: './onboarding.component.html',\n  host: {\n    '[class.onboarding]': `true`,\n    '[attr.data-onboarding-active]': `active`,\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class OnboardingComponent implements OnDestroy {\n  private time: any;\n  private prevSelectorEl: HTMLElement;\n  config: OnboardingConfig;\n  item: OnboardingItem;\n  active = 0;\n  max = 0;\n  readonly op = new EventEmitter<OnboardingOpType>();\n  running = false;\n\n  get first(): boolean {\n    return this.active === 0;\n  }\n\n  get last(): boolean {\n    return this.active === this.max - 1;\n  }\n\n  private _getDoc(): Document {\n    return this.doc;\n  }\n\n  private _getWin(): Window {\n    return this._getDoc().defaultView || window;\n  }\n\n  constructor(\n    private el: ElementRef<HTMLElement>,\n    @Optional() @Inject(DOCUMENT) private doc: any,\n    private platform: Platform,\n    private cdr: ChangeDetectorRef,\n  ) {}\n\n  private getLightData(): OnboardingLightData | null {\n    const doc = this._getDoc();\n    const win = this._getWin();\n    const el = doc.querySelector(this.item.selectors) as HTMLElement;\n    if (!el) {\n      return null;\n    }\n\n    const scrollTop = win.pageYOffset || doc.documentElement.scrollTop || doc.body.scrollTop;\n    const scrollLeft = win.pageXOffset || doc.documentElement.scrollLeft || doc.body.scrollLeft;\n    const rect = el.getBoundingClientRect();\n    const top = rect.top + scrollTop;\n    const left = rect.left + scrollLeft;\n    const padding = 8;\n    const needPadding = top > padding && left > padding;\n    const offsetPos = needPadding ? padding : 0;\n    const offsetWH = needPadding ? padding * 2 : 0;\n    return {\n      top: top - offsetPos,\n      left: left - offsetPos,\n      width: rect.width + offsetWH,\n      height: rect.height + offsetWH,\n      el,\n      clientWidth: doc.body.clientWidth,\n      clientHeight: doc.body.clientHeight,\n    };\n  }\n\n  private scroll(pos: OnboardingLightData): void {\n    this.prevSelectorEl = pos.el;\n    const scrollY = pos.top - (pos.clientHeight - pos.height) / 2;\n    this._getWin().scrollTo({ top: scrollY });\n    this.updatePrevElStatus(true);\n  }\n\n  updateRunning(status: boolean): void {\n    this.running = status;\n    this.cdr.detectChanges();\n    if (!status) {\n      this.updatePosition();\n    }\n  }\n\n  private updatePosition(): void {\n    if (!this.platform.isBrowser) {\n      return;\n    }\n\n    const pos = this.getLightData();\n    if (pos == null) {\n      console.warn(`Did not matches selectors [${this.item.selectors}]`);\n      return;\n    }\n\n    const lightStyle = (this.el.nativeElement.querySelector('.onboarding__light') as HTMLElement).style;\n    lightStyle.top = `${pos.top}px`;\n    lightStyle.left = `${pos.left}px`;\n    lightStyle.width = `${pos.width}px`;\n    lightStyle.height = `${pos.height}px`;\n\n    this.updatePrevElStatus(false);\n    this.scroll(pos);\n  }\n\n  private updatePrevElStatus(status: boolean): void {\n    if (this.prevSelectorEl) {\n      this.prevSelectorEl.classList[status ? 'add' : 'remove']('onboarding__light-el');\n    }\n  }\n\n  to(type: OnboardingOpType): void {\n    this.op.emit(type);\n  }\n\n  handleMask(): void {\n    if (this.config.maskClosable === true) {\n      this.to('done');\n    }\n  }\n\n  ngOnDestroy(): void {\n    clearTimeout(this.time);\n    this.updatePrevElStatus(false);\n  }\n}\n"]}