UNPKG

@fivethree/core

Version:
349 lines 32.6 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'; var FivDialog = /** @class */ (function () { function FivDialog(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 {?} */ FivDialog.prototype.ngOnInit = /** * @return {?} */ function () { }; /** * @return {?} */ FivDialog.prototype.open = /** * @return {?} */ function () { this.overlay.show(this.priority); this.dialogState = this.verticalAlign; if (this.duration) { this.bar.shrinkIn(this.duration); } }; /** * @return {?} */ FivDialog.prototype.doneShrinking = /** * @return {?} */ function () { this.fivDurationOver.emit(this); }; /** * @return {?} */ FivDialog.prototype.close = /** * @return {?} */ function () { this.dialogState = 'out'; this.bar.stopProgressAnimation(); }; /** * @return {?} */ FivDialog.prototype.backdropClick = /** * @return {?} */ function () { if (this.backdropDismiss) { this.close(); } }; /** * @param {?} event * @return {?} */ FivDialog.prototype.animationDone = /** * @param {?} event * @return {?} */ function (event) { if (event.fromState !== 'void' && event.toState === 'out') { this.transformDialog(0); this.overlay.hide(); this.fivClose.emit(this); } }; /** * @param {?} event * @return {?} */ FivDialog.prototype.backdropAnimDone = /** * @param {?} event * @return {?} */ function (event) { if (event.fromState === 'out' && event.toState !== 'void') { this.fivOpen.emit(this); } }; /** * @return {?} */ FivDialog.prototype.onRefresh = /** * @return {?} */ function () { this.close(); }; /** * @return {?} */ FivDialog.prototype.fivCancel = /** * @return {?} */ function () { this.resetDialog(this.currentPullProgress); }; /** * @param {?} progress * @return {?} */ FivDialog.prototype.transformDialog = /** * @param {?} progress * @return {?} */ function (progress) { var _this = this; this.currentPullProgress = progress; this.domCtrl.write((/** * @return {?} */ function () { 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 {?} */ FivDialog.prototype.resetDialog = /** * @param {?} progress * @return {?} */ function (progress) { var _this = this; /** @type {?} */ var 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 {?} */ var animation = reset.create(this.dialogRef.nativeElement); animation.play(); animation.onDone((/** * @return {?} */ function () { 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 = function () { return [ { 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 },] }] }; return FivDialog; }()); export { FivDialog }; 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"]}