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