UNPKG

@fivethree/core

Version:
313 lines 31.1 kB
/** * @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"]}