UNPKG

@fivethree/core

Version:
276 lines 27.5 kB
/** * @fileoverview added by tsickle * Generated from: lib/feature-discovery/feature-discovery.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Platform } from '@ionic/angular'; import { Component, ViewChild, ElementRef, Renderer2, Output, EventEmitter, HostBinding } from '@angular/core'; import { trigger, transition, animate, style } from '@angular/animations'; export class FivFeatureDiscovery { /** * @param {?} renderer * @param {?} platform */ constructor(renderer, platform) { this.renderer = renderer; this.platform = platform; this.top = 0; this.left = 0; this.width = 420; this.height = 420; this.innerDiameter = 0; this.featurePadding = 0; this.contentTop = 0; this.contentLeft = 0; this.contentWidth = 0; this.contentHeight = 0; this.contentOffset = 0; this.animationState = 'hidden'; this.pulse = 'small'; this.fivClick = new EventEmitter(); this.fivBackdropClick = new EventEmitter(); this.fivClose = new EventEmitter(); this.fivOpen = new EventEmitter(); this.fivAnimation = new EventEmitter(); } /** * @return {?} */ get _classes() { return this.classes.join(' '); } /** * @return {?} */ ngOnInit() { } /** * @return {?} */ ngAfterContentInit() { } /** * @param {?} bounds * @return {?} */ setBounds(bounds) { this.bounds = bounds; this.innerDiameter = bounds.height > bounds.width ? bounds.height : bounds.width; this.top = bounds.top + bounds.height / 2 - this.height / 2; this.left = bounds.left + bounds.width / 2 - this.width / 2; this.calculateContentBounds(); if (!this.icon) { /** @type {?} */ const gradient = `-webkit-radial-gradient(transparent ${this .innerDiameter / 2 + 5}px, var(--fiv-color-feature) ${this.innerDiameter / 2 + 5}px)`; /** @type {?} */ const pulseGradient = `-webkit-radial-gradient(transparent ${this .innerDiameter / 2 + 5}px, var(--fiv-color-pulse) ${this.innerDiameter / 2 + 5}px)`; this.renderer.setStyle(this.circle.nativeElement, 'background', gradient); this.renderer.setStyle(this.innerPulse.nativeElement, 'background', pulseGradient); this.renderer.setStyle(this.outerPulse.nativeElement, 'background', pulseGradient); } } /** * @return {?} */ calculateContentBounds() { /** @type {?} */ const absoluteCenter = { x: this.platform.width() / 2, y: this.platform.height() / 2 }; /** @type {?} */ const center = { x: this.left + this.width / 2, y: this.top + this.width / 2 }; /** @type {?} */ const rectWidth = Math.sqrt(Math.pow(this.width, 2) / 2); /** @type {?} */ const isTop = center.y < absoluteCenter.y; /** @type {?} */ const isLeft = center.x < absoluteCenter.x; /** @type {?} */ const innerRadius = this.innerDiameter / 2; /** @type {?} */ const padding = this.featurePadding / 2; /** @type {?} */ let contentRight = 0; /** @type {?} */ let contentBottom = 0; if (isLeft) { this.contentLeft = center.x - innerRadius; contentRight = Math.min(center.x + rectWidth / 2 + this.contentOffset, this.platform.width()); } else { this.contentLeft = Math.max(center.x - rectWidth / 2 - this.contentOffset, 0); contentRight = center.x + innerRadius; } if (isTop) { this.contentTop = center.y + innerRadius + padding; contentBottom = center.y + rectWidth / 2 + -1 * this.contentOffset; } else { this.contentTop = center.y - rectWidth / 2 + this.contentOffset; contentBottom = center.y - innerRadius - padding; } this.contentWidth = Math.abs(this.contentLeft - contentRight); this.contentHeight = Math.abs(this.contentTop - contentBottom); } /** * @param {?} event * @return {?} */ handleCircleAnimation(event) { this.fivAnimation.emit(event); if (event.toState === 'visible') { this.fivOpen.emit(); } if (event.fromState === 'visible' && event.toState === 'hidden') { this.fivClose.emit(); } if (event.fromState === 'visible' && event.toState === 'execute') { this.fivClose.emit(); } } /** * @return {?} */ show() { this.animationState = 'visible'; } /** * @return {?} */ hide() { this.animationState = 'hidden'; } /** * @return {?} */ featureClick() { this.animationState = 'execute'; } /** * @param {?} icon * @return {?} */ setIcon(icon) { if (icon) { this.icon = icon.name; } } } FivFeatureDiscovery.decorators = [ { type: Component, args: [{ selector: 'fiv-feature-discovery', template: "<div class=\"backdrop\" (click)=\"fivBackdropClick.emit()\"></div>\n<div [@scale]=\"animationState\" (@scale.done)=\"handleCircleAnimation($event)\" #circle class=\"circle\"\n [style.height]=\"height + 'px'\" [style.width]=\"width + 'px'\" [style.top]=\"top + 'px'\" [style.left]=\"left + 'px'\">\n <div #pOuter class=\"feature center pulse\" [style.height]=\"(innerDiameter + featurePadding) + 'px'\"\n [style.width]=\"(innerDiameter + featurePadding) + 'px'\">\n </div>\n <div #pInner class=\"feature center inner ion-activatable\" (click)=\"fivClick.emit($event)\"\n [style.height]=\"(innerDiameter + (icon ? featurePadding : 0)) + 'px'\"\n [style.width]=\"(innerDiameter + (icon ? featurePadding : 0)) + 'px'\">\n <fiv-icon class=\"center\" *ngIf=\"icon\" [name]=\"icon\"></fiv-icon>\n <ion-ripple-effect type=\"unbounded\"></ion-ripple-effect>\n </div>\n</div>\n<div class=\"content\" *ngIf=\"animationState === 'visible'\" [@contentAnim] [style.width]=\"contentWidth + 'px'\"\n [style.height]=\"contentHeight + 'px'\" [style.top]=\"contentTop + 'px'\" [style.left]=\"contentLeft + 'px'\">\n <ng-content></ng-content>\n</div>", animations: [ trigger('scale', [ transition('* => visible', [ style({ transform: 'scale(0)', opacity: '0' }), animate('240ms ease-out', style({ transform: 'scale(1)', opacity: '1' })) ]), transition('visible => hidden', [ style({ transform: 'scale(1)', opacity: '1' }), animate('215ms ease-in', style({ transform: 'scale(0)', opacity: '0' })) ]), transition('visible => execute', [ style({ transform: 'scale(1)', opacity: '1' }), animate('215ms 0.15s ease-in', style({ transform: 'scale(1.4)', opacity: '0' })) ]) ]), trigger('contentAnim', [ transition('void => *', [ style({ opacity: '0' }), animate('100ms 240ms ease-out', style({ opacity: '1' })) ]) ]) ], styles: [":host{display:block;height:100vh;width:100vw;position:absolute;--fiv-color-feature:rgba(56, 128, 255, 0.97);--fiv-color-pulse:var(--ion-color-light);--fiv-icon-color:var(--fiv-color-feature, var(--ion-color-primary))}.backdrop{display:block;height:100vh;width:100vw;position:absolute}.circle{position:absolute;border-radius:100%;background:var(--fiv-color-feature);box-shadow:0 3px 1px -2px rgba(0,0,0,.2),0 2px 2px 0 rgba(0,0,0,.14),0 1px 5px 0 rgba(0,0,0,.12)}.feature{border-radius:100%;background:var(--fiv-color-pulse)}.feature.center.pulse{-webkit-animation:1.4s infinite feature-pulse;animation:1.4s infinite feature-pulse}@-webkit-keyframes feature-pulse{0%{transform:scale(1) translate(-50%,-50%);border-radius:100%;box-shadow:0 0 0 0 rgba(0,0,0,.24)}50%{transform:scale(1.1) translate(-45%,-45%)}100%{transform:scale(1) translate(-50%,-50%);border-radius:100%;box-shadow:0 0 0 28px transparent}}@keyframes feature-pulse{0%{transform:scale(1) translate(-50%,-50%);border-radius:100%;box-shadow:0 0 0 0 rgba(0,0,0,.24)}50%{transform:scale(1.1) translate(-45%,-45%)}100%{transform:scale(1) translate(-50%,-50%);border-radius:100%;box-shadow:0 0 0 28px transparent}}.content{position:absolute}.center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}"] }] } ]; /** @nocollapse */ FivFeatureDiscovery.ctorParameters = () => [ { type: Renderer2 }, { type: Platform } ]; FivFeatureDiscovery.propDecorators = { circle: [{ type: ViewChild, args: ['circle', { static: true },] }], rect: [{ type: ViewChild, args: ['rect', { static: true },] }], innerPulse: [{ type: ViewChild, args: ['pInner', { static: true, read: ElementRef },] }], outerPulse: [{ type: ViewChild, args: ['pOuter', { static: true },] }], fivClick: [{ type: Output }], fivBackdropClick: [{ type: Output }], fivClose: [{ type: Output }], fivOpen: [{ type: Output }], fivAnimation: [{ type: Output }], _classes: [{ type: HostBinding, args: ['class',] }] }; if (false) { /** @type {?} */ FivFeatureDiscovery.prototype.top; /** @type {?} */ FivFeatureDiscovery.prototype.left; /** @type {?} */ FivFeatureDiscovery.prototype.width; /** @type {?} */ FivFeatureDiscovery.prototype.height; /** @type {?} */ FivFeatureDiscovery.prototype.innerDiameter; /** @type {?} */ FivFeatureDiscovery.prototype.featurePadding; /** @type {?} */ FivFeatureDiscovery.prototype.contentTop; /** @type {?} */ FivFeatureDiscovery.prototype.contentLeft; /** @type {?} */ FivFeatureDiscovery.prototype.contentWidth; /** @type {?} */ FivFeatureDiscovery.prototype.contentHeight; /** @type {?} */ FivFeatureDiscovery.prototype.contentOffset; /** @type {?} */ FivFeatureDiscovery.prototype.bounds; /** @type {?} */ FivFeatureDiscovery.prototype.icon; /** @type {?} */ FivFeatureDiscovery.prototype.classes; /** @type {?} */ FivFeatureDiscovery.prototype.circle; /** @type {?} */ FivFeatureDiscovery.prototype.rect; /** @type {?} */ FivFeatureDiscovery.prototype.innerPulse; /** @type {?} */ FivFeatureDiscovery.prototype.outerPulse; /** @type {?} */ FivFeatureDiscovery.prototype.animationState; /** @type {?} */ FivFeatureDiscovery.prototype.pulse; /** @type {?} */ FivFeatureDiscovery.prototype.fivClick; /** @type {?} */ FivFeatureDiscovery.prototype.fivBackdropClick; /** @type {?} */ FivFeatureDiscovery.prototype.fivClose; /** @type {?} */ FivFeatureDiscovery.prototype.fivOpen; /** @type {?} */ FivFeatureDiscovery.prototype.fivAnimation; /** * @type {?} * @private */ FivFeatureDiscovery.prototype.renderer; /** * @type {?} * @private */ FivFeatureDiscovery.prototype.platform; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"feature-discovery.component.js","sourceRoot":"ng://@fivethree/core/","sources":["lib/feature-discovery/feature-discovery.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Platform, IonIcon } from '@ionic/angular';\nimport {\n  Component,\n  OnInit,\n  ViewChild,\n  AfterContentInit,\n  ElementRef,\n  Renderer2,\n  Output,\n  EventEmitter,\n  HostBinding\n} from '@angular/core';\nimport {\n  AnimationEvent,\n  trigger,\n  transition,\n  animate,\n  style\n} from '@angular/animations';\nimport { FeaturePosition } from '../interfaces';\nimport { FivIcon } from '../icon/icon.component';\n\n@Component({\n  selector: 'fiv-feature-discovery',\n  templateUrl: './feature-discovery.component.html',\n  styleUrls: ['./feature-discovery.component.scss'],\n  animations: [\n    trigger('scale', [\n      transition('* => visible', [\n        style({ transform: 'scale(0)', opacity: '0' }),\n        animate(\n          '240ms ease-out',\n          style({ transform: 'scale(1)', opacity: '1' })\n        )\n      ]),\n      transition('visible => hidden', [\n        style({ transform: 'scale(1)', opacity: '1' }),\n        animate('215ms ease-in', style({ transform: 'scale(0)', opacity: '0' }))\n      ]),\n      transition('visible => execute', [\n        style({ transform: 'scale(1)', opacity: '1' }),\n        animate(\n          '215ms 0.15s ease-in',\n          style({ transform: 'scale(1.4)', opacity: '0' })\n        )\n      ])\n    ]),\n    trigger('contentAnim', [\n      transition('void => *', [\n        style({ opacity: '0' }),\n        animate('100ms 240ms ease-out', style({ opacity: '1' }))\n      ])\n    ])\n  ]\n})\nexport class FivFeatureDiscovery implements OnInit, AfterContentInit {\n  top = 0;\n  left = 0;\n  width = 420;\n  height = 420;\n  innerDiameter = 0;\n  featurePadding = 0;\n  contentTop = 0;\n  contentLeft = 0;\n  contentWidth = 0;\n  contentHeight = 0;\n  contentOffset = 0;\n  bounds: FeaturePosition;\n  icon: string;\n  classes: string[];\n  @ViewChild('circle', { static: true }) circle: ElementRef;\n  @ViewChild('rect', { static: true }) rect: ElementRef;\n  @ViewChild('pInner', { static: true, read: ElementRef })\n  innerPulse: ElementRef;\n  @ViewChild('pOuter', { static: true }) outerPulse: ElementRef;\n\n  animationState = 'hidden';\n  pulse = 'small';\n\n  @Output() fivClick = new EventEmitter<any>();\n  @Output() fivBackdropClick = new EventEmitter<any>();\n  @Output() fivClose = new EventEmitter<any>();\n  @Output() fivOpen = new EventEmitter<any>();\n  @Output() fivAnimation = new EventEmitter<AnimationEvent>();\n\n  @HostBinding('class') get _classes() {\n    return this.classes.join(' ');\n  }\n\n  constructor(private renderer: Renderer2, private platform: Platform) {}\n\n  ngOnInit() {}\n\n  ngAfterContentInit(): void {}\n\n  setBounds(bounds: FeaturePosition) {\n    this.bounds = bounds;\n    this.innerDiameter =\n      bounds.height > bounds.width ? bounds.height : bounds.width;\n    this.top = bounds.top + bounds.height / 2 - this.height / 2;\n    this.left = bounds.left + bounds.width / 2 - this.width / 2;\n    this.calculateContentBounds();\n    if (!this.icon) {\n      const gradient = `-webkit-radial-gradient(transparent ${this\n        .innerDiameter /\n        2 +\n        5}px, var(--fiv-color-feature) ${this.innerDiameter / 2 + 5}px)`;\n      const pulseGradient = `-webkit-radial-gradient(transparent ${this\n        .innerDiameter /\n        2 +\n        5}px, var(--fiv-color-pulse) ${this.innerDiameter / 2 + 5}px)`;\n      this.renderer.setStyle(this.circle.nativeElement, 'background', gradient);\n      this.renderer.setStyle(\n        this.innerPulse.nativeElement,\n        'background',\n        pulseGradient\n      );\n      this.renderer.setStyle(\n        this.outerPulse.nativeElement,\n        'background',\n        pulseGradient\n      );\n    }\n  }\n  calculateContentBounds() {\n    const absoluteCenter: { x: number; y: number } = {\n      x: this.platform.width() / 2,\n      y: this.platform.height() / 2\n    };\n    const center: { x: number; y: number } = {\n      x: this.left + this.width / 2,\n      y: this.top + this.width / 2\n    };\n    const rectWidth = Math.sqrt(Math.pow(this.width, 2) / 2);\n    const isTop = center.y < absoluteCenter.y;\n    const isLeft = center.x < absoluteCenter.x;\n    const innerRadius = this.innerDiameter / 2;\n    const padding = this.featurePadding / 2;\n    let contentRight = 0;\n    let contentBottom = 0;\n    if (isLeft) {\n      this.contentLeft = center.x - innerRadius;\n      contentRight = Math.min(\n        center.x + rectWidth / 2 + this.contentOffset,\n        this.platform.width()\n      );\n    } else {\n      this.contentLeft = Math.max(\n        center.x - rectWidth / 2 - this.contentOffset,\n        0\n      );\n      contentRight = center.x + innerRadius;\n    }\n    if (isTop) {\n      this.contentTop = center.y + innerRadius + padding;\n      contentBottom = center.y + rectWidth / 2 + -1 * this.contentOffset;\n    } else {\n      this.contentTop = center.y - rectWidth / 2 + this.contentOffset;\n      contentBottom = center.y - innerRadius - padding;\n    }\n\n    this.contentWidth = Math.abs(this.contentLeft - contentRight);\n    this.contentHeight = Math.abs(this.contentTop - contentBottom);\n  }\n  handleCircleAnimation(event: AnimationEvent) {\n    this.fivAnimation.emit(event);\n    if (event.toState === 'visible') {\n      this.fivOpen.emit();\n    }\n    if (event.fromState === 'visible' && event.toState === 'hidden') {\n      this.fivClose.emit();\n    }\n    if (event.fromState === 'visible' && event.toState === 'execute') {\n      this.fivClose.emit();\n    }\n  }\n\n  show() {\n    this.animationState = 'visible';\n  }\n\n  hide() {\n    this.animationState = 'hidden';\n  }\n\n  featureClick() {\n    this.animationState = 'execute';\n  }\n\n  setIcon(icon: FivIcon | IonIcon) {\n    if (icon) {\n      this.icon = icon.name;\n    }\n  }\n}\n"]}