UNPKG

@fivethree/core

Version:
260 lines 19 kB
/** * @fileoverview added by tsickle * Generated from: lib/feature-discovery/feature.directive.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { FivIcon } from '../icon/icon.component'; import { Directive, Host, ElementRef, Input, Optional, TemplateRef, Output, EventEmitter, ViewContainerRef } from '@angular/core'; import { FivOverlayService } from '../overlay/overlay.service'; import { FivFeatureDiscovery } from './feature-discovery.component'; import { first, filter } from 'rxjs/operators'; import { Platform, IonIcon } from '@ionic/angular'; var FivFeature = /** @class */ (function () { function FivFeature(host, viewContainer, fivIcon, ionIcon, overlay, platform) { this.host = host; this.viewContainer = viewContainer; this.fivIcon = fivIcon; this.ionIcon = ionIcon; this.overlay = overlay; this.platform = platform; this.maxDiameter = 1080; this.diameter = Math.min(this.platform.width() * 2, this.maxDiameter); this.contentOffset = 20; this.featurePadding = 20; this.clickEnabled = true; this.classes = []; this.fivFeatureClick = new EventEmitter(); this.fivOpen = new EventEmitter(); this.fivWillOpen = new EventEmitter(); this.fivClose = new EventEmitter(); this.fivWillClose = new EventEmitter(); this.isOpen = false; } /** * @private * @param {?} nativeElement * @return {?} */ FivFeature.prototype.getBounds = /** * @private * @param {?} nativeElement * @return {?} */ function (nativeElement) { /** @type {?} */ var bounds = nativeElement.getBoundingClientRect(); return { top: bounds.top, left: bounds.left, height: nativeElement.clientHeight, width: nativeElement.clientWidth }; }; /** * @return {?} */ FivFeature.prototype.show = /** * @return {?} */ function () { var _this = this; /** @type {?} */ var icon = this.ionIcon || this.fivIcon; /** @type {?} */ var bounds = icon ? this.getBounds(this.host.nativeElement.parentElement) : this.getBounds(this.host.nativeElement); this.overlayRef = this.overlay.createOverlay(this.viewContainer, FivFeatureDiscovery, this.fivFeature); /** @type {?} */ var featureOverlay = this.overlayRef.instance; featureOverlay.height = this.diameter; featureOverlay.width = this.diameter; featureOverlay.featurePadding = this.featurePadding; featureOverlay.contentOffset = this.contentOffset; featureOverlay.classes = this.classes; featureOverlay.setIcon(icon); featureOverlay.setBounds(bounds); featureOverlay.show(); this.fivWillOpen.emit(); featureOverlay.fivAnimation .pipe(filter((/** * @param {?} event * @return {?} */ function (event) { return event.toState === 'visible'; })), first()) .subscribe((/** * @return {?} */ function () { _this.didOpen(); })); featureOverlay.fivClick.pipe(first()).subscribe((/** * @param {?} ev * @return {?} */ function (ev) { _this.featureClick(ev); })); featureOverlay.fivBackdropClick.pipe(first()).subscribe((/** * @return {?} */ function () { _this.hide(); })); }; /** * @return {?} */ FivFeature.prototype.hide = /** * @return {?} */ function () { var _this = this; this.fivWillClose.emit(); if (this.overlayRef) { this.overlayRef.instance.hide(); this.overlayRef.instance.fivClose.pipe(first()).subscribe((/** * @return {?} */ function () { _this.fivClose.emit(); _this.isOpen = false; _this.overlayRef.destroy(); _this.overlayRef = null; })); } }; /** * @private * @return {?} */ FivFeature.prototype.didOpen = /** * @private * @return {?} */ function () { this.fivOpen.emit(); this.isOpen = true; }; /** * @private * @param {?} ev * @return {?} */ FivFeature.prototype.featureClick = /** * @private * @param {?} ev * @return {?} */ function (ev) { var _this = this; if (this.overlayRef) { this.fivFeatureClick.emit(ev); this.fivWillClose.emit(); this.overlayRef.instance.featureClick(); this.overlayRef.instance.fivClose.pipe(first()).subscribe((/** * @return {?} */ function () { _this.fivClose.emit(); _this.overlayRef.destroy(); _this.overlayRef = null; if (_this.clickEnabled) { _this.host.nativeElement.click(); } })); } }; FivFeature.decorators = [ { type: Directive, args: [{ selector: '[fivFeature]', exportAs: 'fivFeature' },] } ]; /** @nocollapse */ FivFeature.ctorParameters = function () { return [ { type: ElementRef, decorators: [{ type: Host }] }, { type: ViewContainerRef }, { type: FivIcon, decorators: [{ type: Host }, { type: Optional }] }, { type: IonIcon, decorators: [{ type: Host }, { type: Optional }] }, { type: FivOverlayService }, { type: Platform } ]; }; FivFeature.propDecorators = { maxDiameter: [{ type: Input }], diameter: [{ type: Input }], contentOffset: [{ type: Input }], featurePadding: [{ type: Input }], clickEnabled: [{ type: Input }], classes: [{ type: Input }], fivFeature: [{ type: Input }], fivFeatureClick: [{ type: Output }], fivOpen: [{ type: Output }], fivWillOpen: [{ type: Output }], fivClose: [{ type: Output }], fivWillClose: [{ type: Output }] }; return FivFeature; }()); export { FivFeature }; if (false) { /** @type {?} */ FivFeature.prototype.maxDiameter; /** @type {?} */ FivFeature.prototype.diameter; /** @type {?} */ FivFeature.prototype.contentOffset; /** @type {?} */ FivFeature.prototype.featurePadding; /** @type {?} */ FivFeature.prototype.clickEnabled; /** @type {?} */ FivFeature.prototype.classes; /** @type {?} */ FivFeature.prototype.fivFeature; /** @type {?} */ FivFeature.prototype.overlayRef; /** @type {?} */ FivFeature.prototype.fivFeatureClick; /** @type {?} */ FivFeature.prototype.fivOpen; /** @type {?} */ FivFeature.prototype.fivWillOpen; /** @type {?} */ FivFeature.prototype.fivClose; /** @type {?} */ FivFeature.prototype.fivWillClose; /** @type {?} */ FivFeature.prototype.isOpen; /** * @type {?} * @private */ FivFeature.prototype.host; /** * @type {?} * @private */ FivFeature.prototype.viewContainer; /** * @type {?} * @private */ FivFeature.prototype.fivIcon; /** * @type {?} * @private */ FivFeature.prototype.ionIcon; /** * @type {?} * @private */ FivFeature.prototype.overlay; /** * @type {?} * @private */ FivFeature.prototype.platform; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"feature.directive.js","sourceRoot":"ng://@fivethree/core/","sources":["lib/feature-discovery/feature.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { FivIcon } from '../icon/icon.component';\nimport { FeaturePosition } from '../interfaces';\nimport {\n  Directive,\n  Host,\n  ElementRef,\n  Input,\n  Optional,\n  ComponentRef,\n  TemplateRef,\n  Output,\n  EventEmitter,\n  ViewContainerRef\n} from '@angular/core';\nimport { FivOverlayService } from '../overlay/overlay.service';\nimport { FivFeatureDiscovery } from './feature-discovery.component';\nimport { first, filter } from 'rxjs/operators';\nimport { Platform, IonIcon } from '@ionic/angular';\n\n@Directive({\n  selector: '[fivFeature]',\n  exportAs: 'fivFeature'\n})\nexport class FivFeature {\n  @Input() maxDiameter = 1080;\n  @Input() diameter = Math.min(this.platform.width() * 2, this.maxDiameter);\n  @Input() contentOffset = 20;\n  @Input() featurePadding = 20;\n  @Input() clickEnabled = true;\n  @Input() classes: string[] = [];\n  @Input() fivFeature: TemplateRef<any>;\n  overlayRef: ComponentRef<FivFeatureDiscovery>;\n\n  @Output() fivFeatureClick = new EventEmitter<any>();\n  @Output() fivOpen = new EventEmitter<any>();\n  @Output() fivWillOpen = new EventEmitter<any>();\n  @Output() fivClose = new EventEmitter<any>();\n  @Output() fivWillClose = new EventEmitter<any>();\n\n  isOpen = false;\n\n  constructor(\n    @Host() private host: ElementRef,\n    private viewContainer: ViewContainerRef,\n    @Host() @Optional() private fivIcon: FivIcon,\n    @Host() @Optional() private ionIcon: IonIcon,\n    private overlay: FivOverlayService,\n    private platform: Platform\n  ) {}\n\n  private getBounds(nativeElement: any): FeaturePosition {\n    const bounds = nativeElement.getBoundingClientRect();\n    return {\n      top: bounds.top,\n      left: bounds.left,\n      height: nativeElement.clientHeight,\n      width: nativeElement.clientWidth\n    };\n  }\n\n  show() {\n    const icon = this.ionIcon || this.fivIcon;\n    const bounds = icon\n      ? this.getBounds(this.host.nativeElement.parentElement)\n      : this.getBounds(this.host.nativeElement);\n\n    this.overlayRef = this.overlay.createOverlay(\n      this.viewContainer,\n      FivFeatureDiscovery,\n      this.fivFeature\n    );\n    const featureOverlay = this.overlayRef.instance;\n    featureOverlay.height = this.diameter;\n    featureOverlay.width = this.diameter;\n    featureOverlay.featurePadding = this.featurePadding;\n    featureOverlay.contentOffset = this.contentOffset;\n    featureOverlay.classes = this.classes;\n    featureOverlay.setIcon(icon);\n    featureOverlay.setBounds(bounds);\n    featureOverlay.show();\n    this.fivWillOpen.emit();\n    featureOverlay.fivAnimation\n      .pipe(\n        filter(event => event.toState === 'visible'),\n        first()\n      )\n      .subscribe(() => {\n        this.didOpen();\n      });\n    featureOverlay.fivClick.pipe(first()).subscribe(ev => {\n      this.featureClick(ev);\n    });\n    featureOverlay.fivBackdropClick.pipe(first()).subscribe(() => {\n      this.hide();\n    });\n  }\n\n  hide() {\n    this.fivWillClose.emit();\n    if (this.overlayRef) {\n      this.overlayRef.instance.hide();\n      this.overlayRef.instance.fivClose.pipe(first()).subscribe(() => {\n        this.fivClose.emit();\n        this.isOpen = false;\n        this.overlayRef.destroy();\n        this.overlayRef = null;\n      });\n    }\n  }\n\n  private didOpen() {\n    this.fivOpen.emit();\n    this.isOpen = true;\n  }\n\n  private featureClick(ev) {\n    if (this.overlayRef) {\n      this.fivFeatureClick.emit(ev);\n      this.fivWillClose.emit();\n      this.overlayRef.instance.featureClick();\n      this.overlayRef.instance.fivClose.pipe(first()).subscribe(() => {\n        this.fivClose.emit();\n        this.overlayRef.destroy();\n        this.overlayRef = null;\n        if (this.clickEnabled) {\n          this.host.nativeElement.click();\n        }\n      });\n    }\n  }\n}\n"]}