@fivethree/core
Version:
Fivethree Core Components
260 lines • 19 kB
JavaScript
/**
* @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"]}