@fivethree/core
Version:
Fivethree Core Components
313 lines • 31.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/dialog/dialog.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { FivLoadingProgressBar } from './../loading-progress-bar/loading-progress-bar.component';
import { EventEmitter, Output, Input, ElementRef, Renderer2 } from '@angular/core';
import { Component, ViewChild } from '@angular/core';
import { FivOverlay } from '../overlay/overlay.component';
import { trigger, transition, style, animate, state, AnimationBuilder } from '@angular/animations';
import { DomController } from '@ionic/angular';
export class FivDialog {
/**
* @param {?} renderer
* @param {?} domCtrl
* @param {?} animation
*/
constructor(renderer, domCtrl, animation) {
this.renderer = renderer;
this.domCtrl = domCtrl;
this.animation = animation;
this.verticalAlign = 'top';
this.horizontalAlign = 'middle';
this.shape = 'card';
this.priority = 20001;
this.backdrop = true;
this.backdropDismiss = true;
this.pullEnabled = true;
// animation data
this.inDuration = 160;
this.outDuration = 120;
this.outPosition = '-100%';
this.toPosition = '0px';
this.translate = '0px';
this.fivClose = new EventEmitter();
this.fivDurationOver = new EventEmitter();
this.fivOpen = new EventEmitter();
this.dialogState = 'out';
}
/**
* @return {?}
*/
ngOnInit() { }
/**
* @return {?}
*/
open() {
this.overlay.show(this.priority);
this.dialogState = this.verticalAlign;
if (this.duration) {
this.bar.shrinkIn(this.duration);
}
}
/**
* @return {?}
*/
doneShrinking() {
this.fivDurationOver.emit(this);
}
/**
* @return {?}
*/
close() {
this.dialogState = 'out';
this.bar.stopProgressAnimation();
}
/**
* @return {?}
*/
backdropClick() {
if (this.backdropDismiss) {
this.close();
}
}
/**
* @param {?} event
* @return {?}
*/
animationDone(event) {
if (event.fromState !== 'void' && event.toState === 'out') {
this.transformDialog(0);
this.overlay.hide();
this.fivClose.emit(this);
}
}
/**
* @param {?} event
* @return {?}
*/
backdropAnimDone(event) {
if (event.fromState === 'out' && event.toState !== 'void') {
this.fivOpen.emit(this);
}
}
/**
* @return {?}
*/
onRefresh() {
this.close();
}
/**
* @return {?}
*/
fivCancel() {
this.resetDialog(this.currentPullProgress);
}
/**
* @param {?} progress
* @return {?}
*/
transformDialog(progress) {
this.currentPullProgress = progress;
this.domCtrl.write((/**
* @return {?}
*/
() => {
if (this.verticalAlign === 'bottom') {
this.renderer.setStyle(this.dialogRef.nativeElement, 'margin-bottom', `-${progress * 120}px`);
}
else if (this.verticalAlign === 'top') {
this.renderer.setStyle(this.dialogRef.nativeElement, 'margin-top', `-${progress * 120}px`);
}
else if (this.verticalAlign === 'center') {
this.renderer.setStyle(this.dialogRef.nativeElement, 'margin-top', `${progress * 120}px`);
}
}));
}
/**
* @param {?} progress
* @return {?}
*/
resetDialog(progress) {
/** @type {?} */
let reset;
if (this.verticalAlign === 'bottom') {
reset = this.animation.build([
style({ 'margin-bottom': `-${progress * 120}px` }),
animate('150ms', style({ 'margin-bottom': `0px` }))
]);
}
else if (this.verticalAlign === 'top') {
reset = this.animation.build([
style({ 'margin-top': `-${progress * 120}px` }),
animate('150ms', style({ 'margin-top': `0px` }))
]);
}
else if (this.verticalAlign === 'center') {
reset = this.animation.build([
style({ 'margin-top': `${progress * 120}px` }),
animate('150ms', style({ 'margin-top': `0px` }))
]);
}
/** @type {?} */
const animation = reset.create(this.dialogRef.nativeElement);
animation.play();
animation.onDone((/**
* @return {?}
*/
() => {
animation.destroy();
this.transformDialog(0);
}));
}
}
FivDialog.decorators = [
{ type: Component, args: [{
selector: 'fiv-dialog',
template: "<fiv-overlay #overlay>\n <ion-content no-bounce [direction]=\"verticalAlign === 'top' ? 'up' : 'down'\" fivPull [enabled]=\"pullEnabled\" [maxPullHeight]=\"168\" [minPullHeight]=\"120\" (fivPull)=\"transformDialog($event)\"\n (fivRefresh)=\"onRefresh()\" (fivCancel)=\"fivCancel()\" *ngIf=\"backdrop\" (@fade.done)=\"backdropAnimDone($event)\"\n [@fade]=\"{value: dialogState, params: { opacity: 0, inDuration: '120ms' }}\" (click)=\"backdropClick()\" class=\"backdrop\">\n</ion-content>\n <div #dialog [@fade]=\"{value: dialogState, params: { opacity: 0, inDuration: '120ms' }}\"\n [@slide]=\"{value: dialogState, params: {top: outPosition, inDuration: inDuration + 'ms',outDuration: outDuration + 'ms', toPosition: toPosition, translate: translate,translateX: horizontalAlign === 'middle' ? 'translateX(-50%)' : '' }}\"\n (@slide.done)=\"animationDone($event)\" class=\"dialog\" [ngClass]=\"[verticalAlign, horizontalAlign, shape]\">\n <ng-container>\n <ng-container *ngTemplateOutlet=\"card\"></ng-container>\n </ng-container>\n </div>\n\n</fiv-overlay>\n\n<ng-template #card>\n <ion-card>\n <fiv-loading-progress-bar [verticalAlign]=\"verticalAlign === 'top' ? 'bottom' : 'top'\"\n (fivDoneShrinking)=\"doneShrinking()\" #bar></fiv-loading-progress-bar>\n <ng-content></ng-content>\n </ion-card>\n</ng-template>",
animations: [
trigger('slide', [
transition('out => top', [
style({ top: '0', transform: 'translateY(-100%) {{translateX}}' }),
animate('220ms ease-out')
]),
transition('out => center', [
style({
top: '50%',
transform: 'translateY(-50%) {{translateX}} scale(0)',
opacity: 0
}),
animate('220ms ease-out', style({
top: '50%',
transform: 'translateY(-50%) {{translateX}} scale(1)',
opacity: 1
}))
]),
transition('out => bottom', [
style({ bottom: '0', transform: 'translateY(100%) {{translateX}}' }),
animate('220ms ease-out')
]),
transition('top => out', [
style({ top: '0', transform: '*' }),
animate('140ms ease-in', style({ top: '0', transform: 'translateY(-100%) {{translateX}}' }))
]),
transition('center => out', [
style({
top: '50%',
transform: '*',
opacity: 1
}),
animate('140ms ease-in', style({
top: '50%',
transform: 'translateY(-50%) {{translateX}} scale(0)',
opacity: 0
}))
]),
transition('bottom => out', [
style({ bottom: '0', transform: '*' }),
animate('140ms ease-in', style({ bottom: '0', transform: 'translateY(100%) {{translateX}}' }))
])
// state('bottom', style({ bottom: '0', transform: '*' })),
// state('top', style({ top: '0', transform: '*' })),
// state('center', style({ top: '50%', transform: 'translateY(-50%) {{translateX}}' }))
]),
trigger('fade', [
transition('out => *', [
style({ opacity: '{{opacity}}' }),
animate('{{inDuration}} ease-out', style({ opacity: '1' }))
], { params: { opacity: 0, inDuration: '250ms' } }),
transition('* => out', [
style({ opacity: '1' }),
animate('{{outDuration}} ease-in', style({ opacity: '0' }))
], { params: { opacity: 0, outDuration: '200ms' } }),
state('out', style({ opacity: '0' }))
])
],
styles: ["ion-grid{--ion-grid-padding:0;--ion-grid-column-padding:0}.dialog{--min-width:340px;position:absolute;min-width:var(--min-width)}@media (max-width:600px){.dialog{--min-width:100%}}.dialog.fill{background:var(--ion-item-background);box-shadow:0 4px 16px rgba(0,0,0,.12)}.dialog.fill .sc-ion-card-ios-h,.dialog.fill .sc-ion-card-md-h{margin-left:unset;margin-right:unset;-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:0;margin-inline-end:0;box-shadow:none;margin-top:0;margin-bottom:0}.dialog.fill.bottom .sc-ion-card-ios-h,.dialog.fill.bottom .sc-ion-card-md-h,.dialog.fill.top .sc-ion-card-ios-h,.dialog.fill.top .sc-ion-card-md-h{border-radius:0}.dialog.top.left{padding-top:env(safe-area-inset-top);top:0;left:0}.dialog.top.right{padding-top:env(safe-area-inset-top);top:0;right:0}.dialog.top.middle{padding-top:env(safe-area-inset-top);top:0;left:50%;transform:translateX(-50%)}.dialog.center.middle{padding-top:env(safe-area-inset-top);top:50%;left:50%;transform:translate(-50%,-50%)}.dialog.center.left{top:50%;padding-top:env(safe-area-inset-top);left:0;transform:translateY(-50%)}.dialog.center.right{right:0;top:50%;padding-top:env(safe-area-inset-top);transform:translateY(-50%)}.dialog.bottom.left{bottom:0;left:0;padding-bottom:env(safe-area-inset-bottom)}.dialog.bottom.right{bottom:0;right:0;padding-bottom:env(safe-area-inset-bottom)}.dialog.bottom.middle{bottom:0;left:50%;transform:translateX(-50%);padding-bottom:env(safe-area-inset-bottom)}.backdrop{width:100%;height:100%;--background:rgba(0, 0, 0, 0.2);position:absolute}"]
}] }
];
/** @nocollapse */
FivDialog.ctorParameters = () => [
{ type: Renderer2 },
{ type: DomController },
{ type: AnimationBuilder }
];
FivDialog.propDecorators = {
verticalAlign: [{ type: Input }],
horizontalAlign: [{ type: Input }],
shape: [{ type: Input }],
priority: [{ type: Input }],
backdrop: [{ type: Input }],
backdropDismiss: [{ type: Input }],
pullEnabled: [{ type: Input }],
duration: [{ type: Input }],
inDuration: [{ type: Input }],
outDuration: [{ type: Input }],
fivClose: [{ type: Output }],
fivDurationOver: [{ type: Output }],
fivOpen: [{ type: Output }],
overlay: [{ type: ViewChild, args: [FivOverlay, { static: false },] }],
bar: [{ type: ViewChild, args: [FivLoadingProgressBar, { static: false },] }],
dialogRef: [{ type: ViewChild, args: ['dialog', { static: false },] }]
};
if (false) {
/** @type {?} */
FivDialog.prototype.verticalAlign;
/** @type {?} */
FivDialog.prototype.horizontalAlign;
/** @type {?} */
FivDialog.prototype.shape;
/** @type {?} */
FivDialog.prototype.priority;
/** @type {?} */
FivDialog.prototype.backdrop;
/** @type {?} */
FivDialog.prototype.backdropDismiss;
/** @type {?} */
FivDialog.prototype.pullEnabled;
/** @type {?} */
FivDialog.prototype.duration;
/** @type {?} */
FivDialog.prototype.inDuration;
/** @type {?} */
FivDialog.prototype.outDuration;
/** @type {?} */
FivDialog.prototype.outPosition;
/** @type {?} */
FivDialog.prototype.toPosition;
/** @type {?} */
FivDialog.prototype.translate;
/** @type {?} */
FivDialog.prototype.fivClose;
/** @type {?} */
FivDialog.prototype.fivDurationOver;
/** @type {?} */
FivDialog.prototype.fivOpen;
/** @type {?} */
FivDialog.prototype.overlay;
/** @type {?} */
FivDialog.prototype.bar;
/** @type {?} */
FivDialog.prototype.dialogRef;
/** @type {?} */
FivDialog.prototype.dialogState;
/** @type {?} */
FivDialog.prototype.currentPullProgress;
/**
* @type {?}
* @private
*/
FivDialog.prototype.renderer;
/**
* @type {?}
* @private
*/
FivDialog.prototype.domCtrl;
/**
* @type {?}
* @private
*/
FivDialog.prototype.animation;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.component.js","sourceRoot":"ng://@fivethree/core/","sources":["lib/dialog/dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { FivLoadingProgressBar } from './../loading-progress-bar/loading-progress-bar.component';\nimport {\n  EventEmitter,\n  Output,\n  Input,\n  TemplateRef,\n  Type,\n  ElementRef,\n  Renderer2\n} from '@angular/core';\nimport { Component, OnInit, ViewChild } from '@angular/core';\nimport { FivOverlay } from '../overlay/overlay.component';\nimport {\n  trigger,\n  transition,\n  style,\n  animate,\n  state,\n  AnimationBuilder\n} from '@angular/animations';\nimport { DomController } from '@ionic/angular';\nexport type Content<T> = TemplateRef<T> | Type<T>;\n\n@Component({\n  selector: 'fiv-dialog',\n  templateUrl: './dialog.component.html',\n  styleUrls: ['./dialog.component.scss'],\n  animations: [\n    trigger('slide', [\n      transition('out => top', [\n        style({ top: '0', transform: 'translateY(-100%) {{translateX}}' }),\n        animate('220ms ease-out')\n      ]),\n      transition('out => center', [\n        style({\n          top: '50%',\n          transform: 'translateY(-50%) {{translateX}} scale(0)',\n          opacity: 0\n        }),\n        animate(\n          '220ms ease-out',\n          style({\n            top: '50%',\n            transform: 'translateY(-50%) {{translateX}} scale(1)',\n            opacity: 1\n          })\n        )\n      ]),\n      transition('out => bottom', [\n        style({ bottom: '0', transform: 'translateY(100%) {{translateX}}' }),\n        animate('220ms ease-out')\n      ]),\n      transition('top => out', [\n        style({ top: '0', transform: '*' }),\n        animate(\n          '140ms ease-in',\n          style({ top: '0', transform: 'translateY(-100%) {{translateX}}' })\n        )\n      ]),\n      transition('center => out', [\n        style({\n          top: '50%',\n          transform: '*',\n          opacity: 1\n        }),\n        animate(\n          '140ms ease-in',\n          style({\n            top: '50%',\n            transform: 'translateY(-50%) {{translateX}} scale(0)',\n            opacity: 0\n          })\n        )\n      ]),\n      transition('bottom => out', [\n        style({ bottom: '0', transform: '*' }),\n        animate(\n          '140ms ease-in',\n          style({ bottom: '0', transform: 'translateY(100%) {{translateX}}' })\n        )\n      ])\n      // state('bottom', style({ bottom: '0', transform: '*' })),\n      // state('top', style({ top: '0', transform: '*' })),\n      // state('center', style({ top: '50%', transform: 'translateY(-50%) {{translateX}}' }))\n    ]),\n    trigger('fade', [\n      transition(\n        'out => *',\n        [\n          style({ opacity: '{{opacity}}' }),\n          animate('{{inDuration}} ease-out', style({ opacity: '1' }))\n        ],\n        { params: { opacity: 0, inDuration: '250ms' } }\n      ),\n      transition(\n        '* => out',\n        [\n          style({ opacity: '1' }),\n          animate('{{outDuration}} ease-in', style({ opacity: '0' }))\n        ],\n        { params: { opacity: 0, outDuration: '200ms' } }\n      ),\n      state('out', style({ opacity: '0' }))\n    ])\n  ]\n})\nexport class FivDialog implements OnInit {\n  @Input() verticalAlign: 'bottom' | 'center' | 'top' = 'top';\n  @Input() horizontalAlign: 'left' | 'middle' | 'right' = 'middle';\n  @Input() shape: 'fill' | 'card' = 'card';\n  @Input() priority = 20001;\n\n  @Input() backdrop = true;\n  @Input() backdropDismiss = true;\n  @Input() pullEnabled = true;\n  @Input() duration: number;\n  // animation data\n  @Input() inDuration = 160;\n  @Input() outDuration = 120;\n  outPosition = '-100%';\n  toPosition = '0px';\n  translate = '0px';\n\n  @Output() fivClose: EventEmitter<FivDialog> = new EventEmitter();\n  @Output() fivDurationOver: EventEmitter<FivDialog> = new EventEmitter();\n  @Output() fivOpen: EventEmitter<FivDialog> = new EventEmitter();\n  @ViewChild(FivOverlay, { static: false }) overlay: FivOverlay;\n  @ViewChild(FivLoadingProgressBar, { static: false })\n  bar: FivLoadingProgressBar;\n  @ViewChild('dialog', { static: false }) dialogRef: ElementRef;\n\n  dialogState: 'top' | 'center' | 'bottom' | 'out' = 'out';\n  currentPullProgress: number;\n\n  ngOnInit(): void {}\n\n  constructor(\n    private renderer: Renderer2,\n    private domCtrl: DomController,\n    private animation: AnimationBuilder\n  ) {}\n\n  open() {\n    this.overlay.show(this.priority);\n\n    this.dialogState = this.verticalAlign;\n    if (this.duration) {\n      this.bar.shrinkIn(this.duration);\n    }\n  }\n\n  doneShrinking() {\n    this.fivDurationOver.emit(this);\n  }\n\n  close() {\n    this.dialogState = 'out';\n    this.bar.stopProgressAnimation();\n  }\n\n  backdropClick() {\n    if (this.backdropDismiss) {\n      this.close();\n    }\n  }\n\n  animationDone(event) {\n    if (event.fromState !== 'void' && event.toState === 'out') {\n      this.transformDialog(0);\n      this.overlay.hide();\n      this.fivClose.emit(this);\n    }\n  }\n\n  backdropAnimDone(event) {\n    if (event.fromState === 'out' && event.toState !== 'void') {\n      this.fivOpen.emit(this);\n    }\n  }\n\n  onRefresh() {\n    this.close();\n  }\n\n  fivCancel() {\n    this.resetDialog(this.currentPullProgress);\n  }\n\n  transformDialog(progress: number) {\n    this.currentPullProgress = progress;\n    this.domCtrl.write(() => {\n      if (this.verticalAlign === 'bottom') {\n        this.renderer.setStyle(\n          this.dialogRef.nativeElement,\n          'margin-bottom',\n          `-${progress * 120}px`\n        );\n      } else if (this.verticalAlign === 'top') {\n        this.renderer.setStyle(\n          this.dialogRef.nativeElement,\n          'margin-top',\n          `-${progress * 120}px`\n        );\n      } else if (this.verticalAlign === 'center') {\n        this.renderer.setStyle(\n          this.dialogRef.nativeElement,\n          'margin-top',\n          `${progress * 120}px`\n        );\n      }\n    });\n  }\n\n  resetDialog(progress: number) {\n    let reset;\n    if (this.verticalAlign === 'bottom') {\n      reset = this.animation.build([\n        style({ 'margin-bottom': `-${progress * 120}px` }),\n        animate('150ms', style({ 'margin-bottom': `0px` }))\n      ]);\n    } else if (this.verticalAlign === 'top') {\n      reset = this.animation.build([\n        style({ 'margin-top': `-${progress * 120}px` }),\n        animate('150ms', style({ 'margin-top': `0px` }))\n      ]);\n    } else if (this.verticalAlign === 'center') {\n      reset = this.animation.build([\n        style({ 'margin-top': `${progress * 120}px` }),\n        animate('150ms', style({ 'margin-top': `0px` }))\n      ]);\n    }\n\n    const animation = reset.create(this.dialogRef.nativeElement);\n    animation.play();\n    animation.onDone(() => {\n      animation.destroy();\n      this.transformDialog(0);\n    });\n  }\n}\n"]}