@fivethree/core
Version:
Fivethree Core Components
331 lines • 28.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/fab/fab.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { FivLoadingProgressBar } from './../loading-progress-bar/loading-progress-bar.component';
import { Component, Input, ViewChild, Output, EventEmitter, Renderer2, ContentChild, TemplateRef, Optional } from '@angular/core';
import { animate, style, transition, trigger } from '@angular/animations';
import { FivSpinner } from '../spinner/spinner.component';
import { IonContent, IonLabel, Platform } from '@ionic/angular';
import { Subject } from 'rxjs';
import { takeUntil, tap, filter, repeat, map, pairwise, distinctUntilChanged } from 'rxjs/operators';
export class FivFab {
/**
* @param {?} renderer
* @param {?} platform
* @param {?} content
*/
constructor(renderer, platform, content) {
this.renderer = renderer;
this.platform = platform;
this.content = content;
this.vertical = 'none';
this.horizontal = 'none';
this.mode = 'normal';
this.spinColor = 'primary';
this.disabled = false;
this.visible = true;
this.pulse = false;
this.animationDisabled = false;
this._scroll = false;
this.fivComplete = new EventEmitter();
this.fivRefresh = new EventEmitter();
this.fivHidden = new EventEmitter();
this.fivShow = new EventEmitter();
this.fivTransition = new EventEmitter();
this.loading = false;
this.extended = false;
this.iconState = 'normal';
this.currentDeltaY = 0;
this.$onDestroy = new Subject();
}
/**
* @param {?} scroll
* @return {?}
*/
set scroll(scroll) {
this._scroll = scroll;
this.$onDestroy.next();
this.ngOnInit();
}
/**
* @return {?}
*/
get scroll() {
return this._scroll;
}
/**
* @return {?}
*/
ngOnInit() {
if (!this.content) {
return;
}
if (!this.scroll) {
return;
}
this.content.scrollEvents = true;
/** @type {?} */
const directionChange = this.content.ionScroll.pipe(map((/**
* @param {?} ev
* @return {?}
*/
ev => ev.detail.deltaY)), pairwise(), map((/**
* @param {?} __0
* @return {?}
*/
([y1, y2]) => (y2 < y1 ? 'Up' : 'Down'))), distinctUntilChanged(), takeUntil(this.content.ionScrollEnd), repeat());
/** @type {?} */
const up = directionChange.pipe(filter((/**
* @param {?} direction
* @return {?}
*/
direction => direction === 'Up')));
/** @type {?} */
const down = directionChange.pipe(filter((/**
* @param {?} direction
* @return {?}
*/
direction => direction === 'Down')));
up.pipe(tap((/**
* @return {?}
*/
() => this.labelComp ? (this.extended = true) : (this.visible = true))), takeUntil(this.$onDestroy)).subscribe();
down
.pipe(tap((/**
* @return {?}
*/
() => this.labelComp ? (this.extended = false) : (this.visible = false))), takeUntil(this.$onDestroy))
.subscribe();
}
/**
* @return {?}
*/
ngOnDestroy() {
this.$onDestroy.next();
}
/**
* @return {?}
*/
ngAfterContentInit() {
this.extended = !!this.labelComp;
}
/**
* @return {?}
*/
load() {
this.loading = true;
this.fivRefresh.emit(this);
}
/**
* @return {?}
*/
unload() {
if (this.bar) {
this.bar.unload();
}
this.loading = false;
}
/**
* @return {?}
*/
complete() {
if (this.loading) {
if (this.spinner) {
this.spinner.completeIn(1000);
}
else if (this.bar) {
this.bar.complete();
}
}
}
/**
* @return {?}
*/
fillAnimationDone() {
this.fivComplete.emit(this);
this.unload();
}
/**
* @param {?} progress
* @return {?}
*/
rotate(progress) {
this.renderer.setStyle(this.spinner._elementRef.nativeElement, 'transform', `rotateZ(${(progress / 200) * 360}deg)`);
}
/**
* @param {?} event
* @return {?}
*/
fabAnimDone(event) {
if (event.fromState === 'void') {
this.fivShow.emit(this);
}
if (event.toState === 'void') {
this.fivHidden.emit(this);
}
}
}
FivFab.decorators = [
{ type: Component, args: [{
selector: 'fiv-fab',
template: "<ion-fab *ngIf=\"visible\" [@.disabled]=\"animationDisabled\" (@fabAnim.done)=\"fabAnimDone($event)\" [@fabAnim]=\"horizontal\"\n [ngClass]=\"[mode,horizontal,vertical]\" [slot]=\"slot\">\n <fiv-spinner *ngIf=\"!extended && loading\" (fivProgress)=\"rotate($event)\" #spinner (fivComplete)=\"fillAnimationDone()\"\n class=\"spinner\" [circleRadius]=\"30\" [diameter]=\"68\" [strokeWidth]=\"4\" [mode]=\"'indeterminate'\">\n </fiv-spinner>\n\n <ion-button [ngClass]=\"{'pulse': pulse, 'small':!labelComp || !extended}\" [color]=\"color\" [disabled]=\"disabled\">\n <fiv-loading-progress-bar *ngIf=\"extended\" [loading]=\"loading\" (fivComplete)=\"fillAnimationDone()\" #bar>\n </fiv-loading-progress-bar>\n <ng-content select=\"fiv-icon\"></ng-content>\n <ng-content select=\"ion-icon\"></ng-content>\n <div [@labelAnim] *ngIf=\"labelComp && extended\">\n <ng-content select=\"ion-label\"></ng-content>\n </div>\n </ion-button>\n</ion-fab>",
animations: [
trigger('fabAnim', [
transition('void => center', [
style({
transform: 'translateX(-50%) scale(0) '
}),
animate('250ms ease', style({ transform: 'translateX(-50%) scale(1)' }))
]),
transition('center => void', [
style({
transform: 'translateX(-50%) scale(1) '
}),
animate('250ms ease', style({ transform: ' translateX(-50%) scale(0)' }))
]),
transition('void => *', [
style({
transform: 'scale(0)'
}),
animate('250ms ease', style({
transform: 'scale(1)'
}))
]),
transition('* => void', [
style({
transform: 'scale(1)'
}),
animate('250ms ease', style({
transform: 'scale(0)'
}))
])
]),
trigger('labelAnim', [
transition('void => *', [
style({ width: '0', opacity: 0 }),
animate('140ms', style({ width: '*', opacity: 1 }))
]),
transition('* => void', [
style({ width: '*', opacity: 1 }),
animate('120ms', style({ width: 0, opacity: 0 }))
])
])
],
styles: [":host{--fiv-fab-size:56px;--fiv-spinner-size:calc(var(--fiv-fab-size) + 12px);--fiv-fab-bottom:calc(10px + env(safe-area-inset-bottom));--fiv-fab-top:calc(10px + env(safe-area-inset-top));--background-fab-progress-bar:var(--ion-color-primary);--background-fab-progress:var(--ion-color-primary-shade);position:inherit}fiv-loading-progress-bar{--background-progress-bar:var(--background-fab-progress-bar);--background-progress:var(--background-fab-progress)}:host(.button-disabled){pointer-events:none}::ng-deep ng-deep fiv-icon.ios{--fiv-icon-height:24px;--fiv-icon-width:24px}::ng-deep fiv-icon:not(.ios){--fiv-icon-height:25px;--fiv-icon-width:25px}ion-button{--border-radius:calc(var(--fiv-fab-size) / 2);height:var(--fiv-fab-size);min-width:var(--fiv-fab-size);-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:0;margin-inline-end:0;margin:0}ion-fab.top{top:var(--fiv-fab-top)}ion-fab.top.edge{top:calc(var(--fiv-fab-top) - 38px)}ion-fab.middle{top:calc(50% - var(--fiv-spinner-size))}ion-fab.bottom.edge{bottom:calc(var(--fiv-fab-bottom) - 38px)}ion-fab.bottom{bottom:var(--fiv-fab-bottom)}ion-fab.center{left:50%;transform:translateX(-50%)}ion-fab.start{left:10px}ion-fab.end{right:calc(10px + var(--ion-safe-area-right,0px))}.pulse{-webkit-animation:1.2s infinite shadow-pulse;animation:1.2s infinite shadow-pulse}fiv-spinner{position:absolute;left:calc((var(--fiv-spinner-size) - var(--fiv-fab-size))/ -2);top:calc((var(--fiv-spinner-size) - var(--fiv-fab-size))/ -2)}@-webkit-keyframes shadow-pulse{0%{border-radius:calc(var(--fiv-spinner-size)/ 2);box-shadow:0 0 0 0 rgba(0,0,0,.2)}100%{border-radius:calc(var(--fiv-spinner-size)/ 2);box-shadow:0 0 0 28px transparent}}@keyframes shadow-pulse{0%{border-radius:calc(var(--fiv-spinner-size)/ 2);box-shadow:0 0 0 0 rgba(0,0,0,.2)}100%{border-radius:calc(var(--fiv-spinner-size)/ 2);box-shadow:0 0 0 28px transparent}}"]
}] }
];
/** @nocollapse */
FivFab.ctorParameters = () => [
{ type: Renderer2 },
{ type: Platform },
{ type: IonContent, decorators: [{ type: Optional }] }
];
FivFab.propDecorators = {
vertical: [{ type: Input }],
horizontal: [{ type: Input }],
mode: [{ type: Input }],
slot: [{ type: Input }],
spinColor: [{ type: Input }],
color: [{ type: Input }],
disabled: [{ type: Input }],
visible: [{ type: Input }],
pulse: [{ type: Input }],
animationDisabled: [{ type: Input }],
scroll: [{ type: Input }],
feature: [{ type: Input }],
fivComplete: [{ type: Output }],
fivRefresh: [{ type: Output }],
fivHidden: [{ type: Output }],
fivShow: [{ type: Output }],
fivTransition: [{ type: Output }],
spinner: [{ type: ViewChild, args: ['spinner', { static: false },] }],
bar: [{ type: ViewChild, args: ['bar', { static: false },] }],
labelComp: [{ type: ContentChild, args: [IonLabel, { static: false },] }]
};
if (false) {
/** @type {?} */
FivFab.prototype.vertical;
/** @type {?} */
FivFab.prototype.horizontal;
/** @type {?} */
FivFab.prototype.mode;
/** @type {?} */
FivFab.prototype.slot;
/** @type {?} */
FivFab.prototype.spinColor;
/** @type {?} */
FivFab.prototype.color;
/** @type {?} */
FivFab.prototype.disabled;
/** @type {?} */
FivFab.prototype.visible;
/** @type {?} */
FivFab.prototype.pulse;
/** @type {?} */
FivFab.prototype.animationDisabled;
/** @type {?} */
FivFab.prototype._scroll;
/** @type {?} */
FivFab.prototype.feature;
/** @type {?} */
FivFab.prototype.fivComplete;
/** @type {?} */
FivFab.prototype.fivRefresh;
/** @type {?} */
FivFab.prototype.fivHidden;
/** @type {?} */
FivFab.prototype.fivShow;
/** @type {?} */
FivFab.prototype.fivTransition;
/** @type {?} */
FivFab.prototype.spinner;
/** @type {?} */
FivFab.prototype.bar;
/** @type {?} */
FivFab.prototype.labelComp;
/** @type {?} */
FivFab.prototype.loading;
/** @type {?} */
FivFab.prototype.extended;
/** @type {?} */
FivFab.prototype.iconState;
/** @type {?} */
FivFab.prototype.currentDeltaY;
/** @type {?} */
FivFab.prototype.$onDestroy;
/**
* @type {?}
* @private
*/
FivFab.prototype.renderer;
/** @type {?} */
FivFab.prototype.platform;
/**
* @type {?}
* @private
*/
FivFab.prototype.content;
}
/**
* @record
*/
export function FabTransitionEvent() { }
if (false) {
/** @type {?} */
FabTransitionEvent.prototype.from;
/** @type {?} */
FabTransitionEvent.prototype.to;
}
/** @enum {number} */
const FabState = {
HIDDEN: 0,
NORMAL: 1,
EXTENDED: 2,
};
export { FabState };
FabState[FabState.HIDDEN] = 'HIDDEN';
FabState[FabState.NORMAL] = 'NORMAL';
FabState[FabState.EXTENDED] = 'EXTENDED';
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fab.component.js","sourceRoot":"ng://@fivethree/core/","sources":["lib/fab/fab.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { FivLoadingProgressBar } from './../loading-progress-bar/loading-progress-bar.component';\nimport {\n  Component,\n  OnInit,\n  Input,\n  ViewChild,\n  Output,\n  EventEmitter,\n  Renderer2,\n  OnDestroy,\n  ContentChild,\n  AfterContentInit,\n  TemplateRef,\n  Optional\n} from '@angular/core';\nimport {\n  animate,\n  style,\n  transition,\n  trigger,\n  state\n} from '@angular/animations';\nimport { FivSpinner } from '../spinner/spinner.component';\nimport { IonContent, IonLabel, Platform } from '@ionic/angular';\nimport { Subject } from 'rxjs';\nimport {\n  takeUntil,\n  tap,\n  filter,\n  repeat,\n  map,\n  pairwise,\n  distinctUntilChanged\n} from 'rxjs/operators';\n\n@Component({\n  selector: 'fiv-fab',\n  templateUrl: './fab.component.html',\n  styleUrls: ['./fab.component.scss'],\n  animations: [\n    trigger('fabAnim', [\n      transition('void => center', [\n        style({\n          transform: 'translateX(-50%) scale(0) '\n        }),\n        animate('250ms ease', style({ transform: 'translateX(-50%) scale(1)' }))\n      ]),\n      transition('center => void', [\n        style({\n          transform: 'translateX(-50%) scale(1) '\n        }),\n        animate(\n          '250ms ease',\n          style({ transform: ' translateX(-50%) scale(0)' })\n        )\n      ]),\n      transition('void => *', [\n        style({\n          transform: 'scale(0)'\n        }),\n        animate(\n          '250ms ease',\n          style({\n            transform: 'scale(1)'\n          })\n        )\n      ]),\n      transition('* => void', [\n        style({\n          transform: 'scale(1)'\n        }),\n        animate(\n          '250ms ease',\n          style({\n            transform: 'scale(0)'\n          })\n        )\n      ])\n    ]),\n    trigger('labelAnim', [\n      transition('void => *', [\n        style({ width: '0', opacity: 0 }),\n        animate('140ms', style({ width: '*', opacity: 1 }))\n      ]),\n      transition('* => void', [\n        style({ width: '*', opacity: 1 }),\n        animate('120ms', style({ width: 0, opacity: 0 }))\n      ])\n    ])\n  ]\n})\nexport class FivFab implements OnInit, OnDestroy, AfterContentInit {\n  @Input() vertical?: 'top' | 'middle' | 'bottom' | 'none' = 'none';\n  @Input() horizontal?: 'center' | 'start' | 'end' | 'none' = 'none';\n  @Input() mode?: 'normal' | 'edge' = 'normal';\n  @Input() slot: string;\n  @Input() spinColor = 'primary';\n  @Input() color: string;\n  @Input() disabled = false;\n  @Input() visible = true;\n  @Input() pulse = false;\n  @Input() animationDisabled = false;\n  @Input() set scroll(scroll: boolean) {\n    this._scroll = scroll;\n    this.$onDestroy.next();\n    this.ngOnInit();\n  }\n  get scroll() {\n    return this._scroll;\n  }\n  _scroll = false;\n  @Input() feature: TemplateRef<any>;\n\n  @Output() fivComplete: EventEmitter<FivFab> = new EventEmitter<FivFab>();\n  @Output() fivRefresh: EventEmitter<FivFab> = new EventEmitter<FivFab>();\n  @Output() fivHidden: EventEmitter<FivFab> = new EventEmitter<FivFab>();\n  @Output() fivShow: EventEmitter<FivFab> = new EventEmitter<FivFab>();\n  @Output() fivTransition: EventEmitter<FivFab> = new EventEmitter<FivFab>();\n\n  @ViewChild('spinner', { static: false }) spinner: FivSpinner;\n  @ViewChild('bar', { static: false }) bar: FivLoadingProgressBar;\n  @ContentChild(IonLabel, { static: false }) labelComp: IonLabel;\n\n  loading = false;\n  extended = false;\n  iconState = 'normal';\n  currentDeltaY = 0;\n  $onDestroy = new Subject();\n\n  constructor(\n    private renderer: Renderer2,\n    public platform: Platform,\n    @Optional() private content: IonContent\n  ) {}\n\n  ngOnInit() {\n    if (!this.content) {\n      return;\n    }\n\n    if (!this.scroll) {\n      return;\n    }\n    this.content.scrollEvents = true;\n\n    const directionChange = this.content.ionScroll.pipe(\n      map(ev => ev.detail.deltaY),\n      pairwise(),\n      map(([y1, y2]) => (y2 < y1 ? 'Up' : 'Down')),\n      distinctUntilChanged(),\n      takeUntil(this.content.ionScrollEnd),\n      repeat()\n    );\n\n    const up = directionChange.pipe(filter(direction => direction === 'Up'));\n\n    const down = directionChange.pipe(\n      filter(direction => direction === 'Down')\n    );\n\n    up.pipe(\n      tap(() =>\n        this.labelComp ? (this.extended = true) : (this.visible = true)\n      ),\n      takeUntil(this.$onDestroy)\n    ).subscribe();\n\n    down\n      .pipe(\n        tap(() =>\n          this.labelComp ? (this.extended = false) : (this.visible = false)\n        ),\n        takeUntil(this.$onDestroy)\n      )\n      .subscribe();\n  }\n\n  ngOnDestroy(): void {\n    this.$onDestroy.next();\n  }\n\n  ngAfterContentInit(): void {\n    this.extended = !!this.labelComp;\n  }\n\n  load() {\n    this.loading = true;\n    this.fivRefresh.emit(this);\n  }\n\n  unload() {\n    if (this.bar) {\n      this.bar.unload();\n    }\n    this.loading = false;\n  }\n\n  complete() {\n    if (this.loading) {\n      if (this.spinner) {\n        this.spinner.completeIn(1000);\n      } else if (this.bar) {\n        this.bar.complete();\n      }\n    }\n  }\n\n  fillAnimationDone() {\n    this.fivComplete.emit(this);\n    this.unload();\n  }\n\n  rotate(progress: number) {\n    this.renderer.setStyle(\n      this.spinner._elementRef.nativeElement,\n      'transform',\n      `rotateZ(${(progress / 200) * 360}deg)`\n    );\n  }\n\n  fabAnimDone(event) {\n    if (event.fromState === 'void') {\n      this.fivShow.emit(this);\n    }\n\n    if (event.toState === 'void') {\n      this.fivHidden.emit(this);\n    }\n  }\n}\n\nexport interface FabTransitionEvent {\n  from: FabState;\n  to: FabState;\n}\n\nexport enum FabState {\n  HIDDEN,\n  NORMAL,\n  EXTENDED\n}\n"]}