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